59 // Instance variables
60 Klass* element_klass() const { return _element_klass; }
61 void set_element_klass(Klass* k) { _element_klass = k; }
62 Klass** element_klass_addr() { return &_element_klass; }
63
64 Klass* bottom_klass() const { return _bottom_klass; }
65 void set_bottom_klass(Klass* k) { _bottom_klass = k; }
66 Klass** bottom_klass_addr() { return &_bottom_klass; }
67
68 ModuleEntry* module() const;
69 PackageEntry* package() const;
70
71 // Compiler/Interpreter offset
72 static ByteSize element_klass_offset() { return byte_offset_of(ObjArrayKlass, _element_klass); }
73
74 // Dispatched operation
75 bool can_be_primary_super_slow() const;
76 GrowableArray<Klass*>* compute_secondary_supers(int num_extra_slots,
77 Array<InstanceKlass*>* transitive_interfaces);
78 DEBUG_ONLY(bool is_objArray_klass_slow() const { return true; })
79 size_t oop_size(oop obj) const;
80
81 // Allocation
82 static ObjArrayKlass* allocate_objArray_klass(ClassLoaderData* loader_data,
83 int n, Klass* element_klass, TRAPS);
84
85 oop multi_allocate(int rank, jint* sizes, TRAPS);
86
87 // Copying
88 void copy_array(arrayOop s, int src_pos, arrayOop d, int dst_pos, int length, TRAPS);
89
90 // Compute protection domain
91 oop protection_domain() const { return bottom_klass()->protection_domain(); }
92
93 virtual void metaspace_pointers_do(MetaspaceClosure* iter);
94
95 private:
96 // Either oop or narrowOop depending on UseCompressedOops.
97 // must be called from within ObjArrayKlass.cpp
98 void do_copy(arrayOop s, size_t src_offset,
99 arrayOop d, size_t dst_offset,
|
59 // Instance variables
60 Klass* element_klass() const { return _element_klass; }
61 void set_element_klass(Klass* k) { _element_klass = k; }
62 Klass** element_klass_addr() { return &_element_klass; }
63
64 Klass* bottom_klass() const { return _bottom_klass; }
65 void set_bottom_klass(Klass* k) { _bottom_klass = k; }
66 Klass** bottom_klass_addr() { return &_bottom_klass; }
67
68 ModuleEntry* module() const;
69 PackageEntry* package() const;
70
71 // Compiler/Interpreter offset
72 static ByteSize element_klass_offset() { return byte_offset_of(ObjArrayKlass, _element_klass); }
73
74 // Dispatched operation
75 bool can_be_primary_super_slow() const;
76 GrowableArray<Klass*>* compute_secondary_supers(int num_extra_slots,
77 Array<InstanceKlass*>* transitive_interfaces);
78 DEBUG_ONLY(bool is_objArray_klass_slow() const { return true; })
79 size_t oop_size(oop obj, markWord) const;
80
81 // Allocation
82 static ObjArrayKlass* allocate_objArray_klass(ClassLoaderData* loader_data,
83 int n, Klass* element_klass, TRAPS);
84
85 oop multi_allocate(int rank, jint* sizes, TRAPS);
86
87 // Copying
88 void copy_array(arrayOop s, int src_pos, arrayOop d, int dst_pos, int length, TRAPS);
89
90 // Compute protection domain
91 oop protection_domain() const { return bottom_klass()->protection_domain(); }
92
93 virtual void metaspace_pointers_do(MetaspaceClosure* iter);
94
95 private:
96 // Either oop or narrowOop depending on UseCompressedOops.
97 // must be called from within ObjArrayKlass.cpp
98 void do_copy(arrayOop s, size_t src_offset,
99 arrayOop d, size_t dst_offset,
|