1 /* 2 * Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 * 23 */ 24 25 #ifndef SHARE_CI_CIINSTANCEKLASS_HPP 26 #define SHARE_CI_CIINSTANCEKLASS_HPP 27 28 #include "ci/ciConstantPoolCache.hpp" 29 #include "ci/ciFlags.hpp" 30 #include "ci/ciKlass.hpp" 31 #include "ci/ciSymbol.hpp" 32 #include "oops/instanceKlass.hpp" 33 34 // ciInstanceKlass 35 // 36 // This class represents a Klass* in the HotSpot virtual machine 37 // whose Klass part is an InstanceKlass. It may or may not 38 // be loaded. 39 class ciInstanceKlass : public ciKlass { 40 CI_PACKAGE_ACCESS 41 friend class ciBytecodeStream; 42 friend class ciEnv; 43 friend class ciExceptionHandler; 44 friend class ciMethod; 45 friend class ciField; 46 friend class ciReplay; 47 friend class CompileTrainingData; 48 49 private: 50 enum SubklassValue { subklass_unknown, subklass_false, subklass_true }; 51 52 jobject _loader; 53 jobject _protection_domain; 54 55 InstanceKlass::ClassState _init_state; // state of class 56 bool _is_shared; 57 bool _has_finalizer; 58 SubklassValue _has_subklass; 59 bool _has_nonstatic_fields; 60 bool _has_nonstatic_concrete_methods; 61 bool _is_hidden; 62 bool _is_record; 63 bool _has_trusted_loader; 64 65 ciFlags _flags; 66 67 // Lazy fields get filled in only upon request. 68 ciInstanceKlass* _super; 69 ciInstance* _java_mirror; 70 71 ciConstantPoolCache* _field_cache; // cached map index->field 72 GrowableArray<ciField*>* _nonstatic_fields; 73 int _has_injected_fields; // any non static injected fields? lazily initialized. 74 75 // The possible values of the _implementor fall into following three cases: 76 // null: no implementor. 77 // A ciInstanceKlass that's not itself: one implementor. 78 // Itself: more than one implementor. 79 ciInstanceKlass* _implementor; 80 GrowableArray<ciInstanceKlass*>* _transitive_interfaces; 81 82 void compute_injected_fields(); 83 bool compute_injected_fields_helper(); 84 void compute_transitive_interfaces(); 85 86 protected: 87 ciInstanceKlass(Klass* k); 88 ciInstanceKlass(ciSymbol* name, jobject loader, jobject protection_domain); 89 90 InstanceKlass* get_instanceKlass() const { 91 return InstanceKlass::cast(get_Klass()); 92 } 93 94 oop loader(); 95 jobject loader_handle(); 96 97 oop protection_domain(); 98 jobject protection_domain_handle(); 99 100 const char* type_string() { return "ciInstanceKlass"; } 101 102 bool is_in_package_impl(const char* packagename, int len); 103 104 void print_impl(outputStream* st); 105 106 ciConstantPoolCache* field_cache(); 107 108 bool is_shared() { return _is_shared; } 109 110 void compute_shared_init_state(); 111 bool compute_shared_has_subklass(); 112 int compute_nonstatic_fields(); 113 GrowableArray<ciField*>* compute_nonstatic_fields_impl(GrowableArray<ciField*>* super_fields); 114 bool compute_has_trusted_loader(); 115 116 // Update the init_state for shared klasses 117 void update_if_shared(InstanceKlass::ClassState expected) { 118 if (_is_shared && _init_state != expected) { 119 if (is_loaded()) compute_shared_init_state(); 120 } 121 } 122 123 static InstanceKlass::ClassState compute_init_state(InstanceKlass* ik); 124 125 public: 126 // Has this klass been initialized? 127 bool is_initialized() { 128 update_if_shared(InstanceKlass::fully_initialized); 129 return _init_state == InstanceKlass::fully_initialized; 130 } 131 bool is_not_initialized() { 132 update_if_shared(InstanceKlass::fully_initialized); 133 return _init_state < InstanceKlass::being_initialized; 134 } 135 // Is this klass being initialized? 136 bool is_being_initialized() { 137 update_if_shared(InstanceKlass::being_initialized); 138 return _init_state == InstanceKlass::being_initialized; 139 } 140 // Has this klass been linked? 141 bool is_linked() { 142 update_if_shared(InstanceKlass::linked); 143 return _init_state >= InstanceKlass::linked; 144 } 145 // Is this klass in error state? 146 bool is_in_error_state() { 147 update_if_shared(InstanceKlass::initialization_error); 148 return _init_state == InstanceKlass::initialization_error; 149 } 150 151 // General klass information. 152 ciFlags flags() { 153 assert(is_loaded(), "must be loaded"); 154 return _flags; 155 } 156 bool has_finalizer() { 157 assert(is_loaded(), "must be loaded"); 158 return _has_finalizer; } 159 bool has_subklass() { 160 assert(is_loaded(), "must be loaded"); 161 // Ignore cached subklass_false case. 162 // It could be invalidated by concurrent class loading and 163 // can result in type paradoxes during compilation when 164 // a subclass is observed, but has_subklass() returns false. 165 if (_has_subklass == subklass_true) { 166 return true; 167 } 168 if (flags().is_final()) { 169 return false; 170 } 171 return compute_shared_has_subklass(); 172 } 173 174 jint layout_helper_size_in_bytes() { 175 return Klass::layout_helper_size_in_bytes(layout_helper()); 176 } 177 jint size_helper() { 178 return (Klass::layout_helper_size_in_bytes(layout_helper()) 179 >> LogHeapWordSize); 180 } 181 jint has_nonstatic_fields() { 182 assert(is_loaded(), "must be loaded"); 183 return _has_nonstatic_fields; } 184 ciInstanceKlass* super(); 185 jint nof_implementors() { 186 ciInstanceKlass* impl; 187 assert(is_loaded(), "must be loaded"); 188 impl = implementor(); 189 if (impl == nullptr) { 190 return 0; 191 } else if (impl != this) { 192 return 1; 193 } else { 194 return 2; 195 } 196 } 197 bool has_nonstatic_concrete_methods() { 198 assert(is_loaded(), "must be loaded"); 199 return _has_nonstatic_concrete_methods; 200 } 201 202 bool is_hidden() const { 203 return _is_hidden; 204 } 205 206 bool is_record() const { 207 return _is_record; 208 } 209 210 ciInstanceKlass* get_canonical_holder(int offset); 211 ciField* get_field_by_offset(int field_offset, bool is_static); 212 ciField* get_field_by_name(ciSymbol* name, ciSymbol* signature, bool is_static); 213 214 // total number of nonstatic fields (including inherited): 215 int nof_nonstatic_fields() { 216 if (_nonstatic_fields == nullptr) 217 return compute_nonstatic_fields(); 218 else 219 return _nonstatic_fields->length(); 220 } 221 222 bool has_injected_fields() { 223 if (_has_injected_fields == -1) { 224 compute_injected_fields(); 225 } 226 return _has_injected_fields > 0 ? true : false; 227 } 228 229 bool has_object_fields() const; 230 231 // nth nonstatic field (presented by ascending address) 232 ciField* nonstatic_field_at(int i) { 233 assert(_nonstatic_fields != nullptr, ""); 234 return _nonstatic_fields->at(i); 235 } 236 237 ciInstanceKlass* unique_concrete_subklass(); 238 bool has_finalizable_subclass(); 239 240 bool contains_field_offset(int offset); 241 242 // Get the instance of java.lang.Class corresponding to 243 // this klass. This instance is used for locking of 244 // synchronized static methods of this klass. 245 ciInstance* java_mirror(); 246 247 // Java access flags 248 bool is_public () { return flags().is_public(); } 249 bool is_final () { return flags().is_final(); } 250 bool is_super () { return flags().is_super(); } 251 bool is_interface () { return flags().is_interface(); } 252 bool is_abstract () { return flags().is_abstract(); } 253 254 ciMethod* find_method(ciSymbol* name, ciSymbol* signature); 255 // Note: To find a method from name and type strings, use ciSymbol::make, 256 // but consider adding to vmSymbols.hpp instead. 257 258 bool is_leaf_type(); 259 ciInstanceKlass* implementor(); 260 261 ciInstanceKlass* unique_implementor() { 262 assert(is_loaded(), "must be loaded"); 263 ciInstanceKlass* impl = implementor(); 264 return (impl != this ? impl : nullptr); 265 } 266 267 // Is the defining class loader of this class the default loader? 268 bool uses_default_loader() const; 269 270 bool is_java_lang_Object() const; 271 272 BasicType box_klass_type() const; 273 bool is_box_klass() const; 274 bool is_boxed_value_offset(int offset) const; 275 276 // Is this klass in the given package? 277 bool is_in_package(const char* packagename) { 278 return is_in_package(packagename, (int) strlen(packagename)); 279 } 280 bool is_in_package(const char* packagename, int len); 281 282 // What kind of ciObject is this? 283 bool is_instance_klass() const { return true; } 284 285 virtual ciKlass* exact_klass() { 286 if (is_loaded() && is_final() && !is_interface()) { 287 return this; 288 } 289 return nullptr; 290 } 291 292 bool can_be_instantiated() { 293 assert(is_loaded(), "must be loaded"); 294 return !is_interface() && !is_abstract(); 295 } 296 297 bool has_trusted_loader() const { 298 return _has_trusted_loader; 299 } 300 GrowableArray<ciInstanceKlass*>* transitive_interfaces() const; 301 302 // Replay support 303 304 // Dump the current state of this klass for compilation replay. 305 virtual void dump_replay_data(outputStream* out); 306 307 static void dump_replay_instanceKlass(outputStream* out, InstanceKlass* ik); 308 309 310 // Return stable class name suitable for replay file. 311 const char *replay_name() const; 312 313 #ifdef ASSERT 314 bool debug_final_field_at(int offset); 315 bool debug_stable_field_at(int offset); 316 #endif 317 }; 318 319 #endif // SHARE_CI_CIINSTANCEKLASS_HPP