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