51 jobject _loader;
52 jobject _protection_domain;
53
54 InstanceKlass::ClassState _init_state; // state of class
55 bool _is_shared;
56 bool _has_finalizer;
57 SubklassValue _has_subklass;
58 bool _has_nonstatic_fields;
59 bool _has_nonstatic_concrete_methods;
60 bool _is_hidden;
61 bool _is_record;
62 bool _has_trusted_loader;
63
64 ciFlags _flags;
65
66 // Lazy fields get filled in only upon request.
67 ciInstanceKlass* _super;
68 ciInstance* _java_mirror;
69
70 ciConstantPoolCache* _field_cache; // cached map index->field
71 GrowableArray<ciField*>* _nonstatic_fields;
72 int _has_injected_fields; // any non static injected fields? lazily initialized.
73
74 // The possible values of the _implementor fall into following three cases:
75 // null: no implementor.
76 // A ciInstanceKlass that's not itself: one implementor.
77 // Itself: more than one implementor.
78 ciInstanceKlass* _implementor;
79 GrowableArray<ciInstanceKlass*>* _transitive_interfaces;
80
81 void compute_injected_fields();
82 bool compute_injected_fields_helper();
83 void compute_transitive_interfaces();
84
85 protected:
86 ciInstanceKlass(Klass* k);
87 ciInstanceKlass(ciSymbol* name, jobject loader, jobject protection_domain);
88
89 InstanceKlass* get_instanceKlass() const {
90 return InstanceKlass::cast(get_Klass());
91 }
92
93 oop loader();
94 jobject loader_handle();
95
96 oop protection_domain();
97 jobject protection_domain_handle();
98
99 const char* type_string() { return "ciInstanceKlass"; }
100
101 bool is_in_package_impl(const char* packagename, int len);
102
103 void print_impl(outputStream* st);
104
105 ciConstantPoolCache* field_cache();
106
107 bool is_shared() { return _is_shared; }
108
109 void compute_shared_init_state();
110 bool compute_shared_has_subklass();
111 int compute_nonstatic_fields();
112 GrowableArray<ciField*>* compute_nonstatic_fields_impl(GrowableArray<ciField*>* super_fields);
113 bool compute_has_trusted_loader();
114
115 // Update the init_state for shared klasses
116 void update_if_shared(InstanceKlass::ClassState expected) {
117 if (_is_shared && _init_state != expected) {
118 if (is_loaded()) compute_shared_init_state();
119 }
120 }
121
122 public:
123 // Has this klass been initialized?
124 bool is_initialized() {
125 update_if_shared(InstanceKlass::fully_initialized);
126 return _init_state == InstanceKlass::fully_initialized;
127 }
128 bool is_not_initialized() {
129 update_if_shared(InstanceKlass::fully_initialized);
130 return _init_state < InstanceKlass::being_initialized;
131 }
132 // Is this klass being initialized?
190 } else {
191 return 2;
192 }
193 }
194 bool has_nonstatic_concrete_methods() {
195 assert(is_loaded(), "must be loaded");
196 return _has_nonstatic_concrete_methods;
197 }
198
199 bool is_hidden() const {
200 return _is_hidden;
201 }
202
203 bool is_record() const {
204 return _is_record;
205 }
206
207 ciInstanceKlass* get_canonical_holder(int offset);
208 ciField* get_field_by_offset(int field_offset, bool is_static);
209 ciField* get_field_by_name(ciSymbol* name, ciSymbol* signature, bool is_static);
210
211 // total number of nonstatic fields (including inherited):
212 int nof_nonstatic_fields() {
213 if (_nonstatic_fields == nullptr)
214 return compute_nonstatic_fields();
215 else
216 return _nonstatic_fields->length();
217 }
218
219 bool has_injected_fields() {
220 if (_has_injected_fields == -1) {
221 compute_injected_fields();
222 }
223 return _has_injected_fields > 0 ? true : false;
224 }
225
226 bool has_object_fields() const;
227
228 // nth nonstatic field (presented by ascending address)
229 ciField* nonstatic_field_at(int i) {
230 assert(_nonstatic_fields != nullptr, "");
231 return _nonstatic_fields->at(i);
232 }
233
234 ciInstanceKlass* unique_concrete_subklass();
235 bool has_finalizable_subclass();
236
237 bool contains_field_offset(int offset);
238
239 // Get the instance of java.lang.Class corresponding to
240 // this klass. This instance is used for locking of
241 // synchronized static methods of this klass.
242 ciInstance* java_mirror();
243
244 // Java access flags
245 bool is_public () { return flags().is_public(); }
246 bool is_final () { return flags().is_final(); }
247 bool is_super () { return flags().is_super(); }
248 bool is_interface () { return flags().is_interface(); }
249 bool is_abstract () { return flags().is_abstract(); }
250
251 ciMethod* find_method(ciSymbol* name, ciSymbol* signature);
252 // Note: To find a method from name and type strings, use ciSymbol::make,
253 // but consider adding to vmSymbols.hpp instead.
254
255 bool is_leaf_type();
256 ciInstanceKlass* implementor();
257
258 ciInstanceKlass* unique_implementor() {
259 assert(is_loaded(), "must be loaded");
260 ciInstanceKlass* impl = implementor();
261 return (impl != this ? impl : nullptr);
262 }
263
264 // Is the defining class loader of this class the default loader?
265 bool uses_default_loader() const;
266
267 bool is_java_lang_Object() const;
268
269 BasicType box_klass_type() const;
270 bool is_box_klass() const;
271 bool is_boxed_value_offset(int offset) const;
272
273 // Is this klass in the given package?
274 bool is_in_package(const char* packagename) {
275 return is_in_package(packagename, (int) strlen(packagename));
276 }
277 bool is_in_package(const char* packagename, int len);
278
279 // What kind of ciObject is this?
280 bool is_instance_klass() const { return true; }
281
282 virtual ciKlass* exact_klass() {
283 if (is_loaded() && is_final() && !is_interface()) {
|
51 jobject _loader;
52 jobject _protection_domain;
53
54 InstanceKlass::ClassState _init_state; // state of class
55 bool _is_shared;
56 bool _has_finalizer;
57 SubklassValue _has_subklass;
58 bool _has_nonstatic_fields;
59 bool _has_nonstatic_concrete_methods;
60 bool _is_hidden;
61 bool _is_record;
62 bool _has_trusted_loader;
63
64 ciFlags _flags;
65
66 // Lazy fields get filled in only upon request.
67 ciInstanceKlass* _super;
68 ciInstance* _java_mirror;
69
70 ciConstantPoolCache* _field_cache; // cached map index->field
71 public:
72 GrowableArray<ciField*>* _nonstatic_fields;
73 private:
74 int _has_injected_fields; // any non static injected fields? lazily initialized.
75
76 // The possible values of the _implementor fall into following three cases:
77 // null: no implementor.
78 // A ciInstanceKlass that's not itself: one implementor.
79 // Itself: more than one implementor.
80 ciInstanceKlass* _implementor;
81 GrowableArray<ciInstanceKlass*>* _transitive_interfaces;
82
83 void compute_injected_fields();
84 bool compute_injected_fields_helper();
85 void compute_transitive_interfaces();
86
87 protected:
88 ciInstanceKlass(Klass* k);
89 ciInstanceKlass(ciSymbol* name, jobject loader, jobject protection_domain, BasicType bt = T_OBJECT); // for unloaded klasses
90
91 InstanceKlass* get_instanceKlass() const {
92 return InstanceKlass::cast(get_Klass());
93 }
94
95 oop loader();
96 jobject loader_handle();
97
98 oop protection_domain();
99 jobject protection_domain_handle();
100
101 const char* type_string() { return "ciInstanceKlass"; }
102
103 bool is_in_package_impl(const char* packagename, int len);
104
105 void print_impl(outputStream* st);
106
107 ciConstantPoolCache* field_cache();
108
109 bool is_shared() { return _is_shared; }
110
111 void compute_shared_init_state();
112 bool compute_shared_has_subklass();
113 virtual int compute_nonstatic_fields();
114 GrowableArray<ciField*>* compute_nonstatic_fields_impl(GrowableArray<ciField*>* super_fields, bool flatten = true);
115 bool compute_has_trusted_loader();
116
117 // Update the init_state for shared klasses
118 void update_if_shared(InstanceKlass::ClassState expected) {
119 if (_is_shared && _init_state != expected) {
120 if (is_loaded()) compute_shared_init_state();
121 }
122 }
123
124 public:
125 // Has this klass been initialized?
126 bool is_initialized() {
127 update_if_shared(InstanceKlass::fully_initialized);
128 return _init_state == InstanceKlass::fully_initialized;
129 }
130 bool is_not_initialized() {
131 update_if_shared(InstanceKlass::fully_initialized);
132 return _init_state < InstanceKlass::being_initialized;
133 }
134 // Is this klass being initialized?
192 } else {
193 return 2;
194 }
195 }
196 bool has_nonstatic_concrete_methods() {
197 assert(is_loaded(), "must be loaded");
198 return _has_nonstatic_concrete_methods;
199 }
200
201 bool is_hidden() const {
202 return _is_hidden;
203 }
204
205 bool is_record() const {
206 return _is_record;
207 }
208
209 ciInstanceKlass* get_canonical_holder(int offset);
210 ciField* get_field_by_offset(int field_offset, bool is_static);
211 ciField* get_field_by_name(ciSymbol* name, ciSymbol* signature, bool is_static);
212 // get field descriptor at field_offset ignoring flattening
213 ciField* get_non_flat_field_by_offset(int field_offset);
214
215 // total number of nonstatic fields (including inherited):
216 int nof_nonstatic_fields() {
217 if (_nonstatic_fields == nullptr) {
218 return compute_nonstatic_fields();
219 } else {
220 return _nonstatic_fields->length();
221 }
222 }
223
224 bool has_injected_fields() {
225 if (_has_injected_fields == -1) {
226 compute_injected_fields();
227 }
228 return _has_injected_fields > 0 ? true : false;
229 }
230
231 bool has_object_fields() const;
232
233 // nth nonstatic field (presented by ascending address)
234 ciField* nonstatic_field_at(int i) {
235 assert(_nonstatic_fields != nullptr, "");
236 return _nonstatic_fields->at(i);
237 }
238
239 ciInstanceKlass* unique_concrete_subklass();
240 bool has_finalizable_subclass();
241
242 bool contains_field_offset(int offset);
243
244 // Get the instance of java.lang.Class corresponding to
245 // this klass. This instance is used for locking of
246 // synchronized static methods of this klass.
247 ciInstance* java_mirror();
248
249 // Java access flags
250 bool is_public () { return flags().is_public(); }
251 bool is_final () { return flags().is_final(); }
252 bool is_interface () { return flags().is_interface(); }
253 bool is_abstract () { return flags().is_abstract(); }
254 bool is_abstract_value_klass() { return is_abstract() && !flags().is_identity(); }
255
256 ciMethod* find_method(ciSymbol* name, ciSymbol* signature);
257 // Note: To find a method from name and type strings, use ciSymbol::make,
258 // but consider adding to vmSymbols.hpp instead.
259
260 bool is_leaf_type();
261 ciInstanceKlass* implementor();
262
263 ciInstanceKlass* unique_implementor() {
264 assert(is_loaded(), "must be loaded");
265 ciInstanceKlass* impl = implementor();
266 return (impl != this ? impl : nullptr);
267 }
268
269 virtual bool can_be_inline_klass(bool is_exact = false);
270
271 // Is the defining class loader of this class the default loader?
272 bool uses_default_loader() const;
273
274 bool is_java_lang_Object() const;
275
276 BasicType box_klass_type() const;
277 bool is_box_klass() const;
278 bool is_boxed_value_offset(int offset) const;
279
280 // Is this klass in the given package?
281 bool is_in_package(const char* packagename) {
282 return is_in_package(packagename, (int) strlen(packagename));
283 }
284 bool is_in_package(const char* packagename, int len);
285
286 // What kind of ciObject is this?
287 bool is_instance_klass() const { return true; }
288
289 virtual ciKlass* exact_klass() {
290 if (is_loaded() && is_final() && !is_interface()) {
|