1 /*
2 * Copyright (c) 1997, 2024, 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 *
29 #include "cds/cdsEnumKlass.hpp"
30 #include "cds/classListWriter.hpp"
31 #include "cds/heapShared.hpp"
32 #include "cds/metaspaceShared.hpp"
33 #include "classfile/classFileParser.hpp"
34 #include "classfile/classFileStream.hpp"
35 #include "classfile/classLoader.hpp"
36 #include "classfile/classLoaderData.inline.hpp"
37 #include "classfile/javaClasses.hpp"
38 #include "classfile/moduleEntry.hpp"
39 #include "classfile/systemDictionary.hpp"
40 #include "classfile/systemDictionaryShared.hpp"
41 #include "classfile/verifier.hpp"
42 #include "classfile/vmClasses.hpp"
43 #include "classfile/vmSymbols.hpp"
44 #include "code/codeCache.hpp"
45 #include "code/dependencyContext.hpp"
46 #include "compiler/compilationPolicy.hpp"
47 #include "compiler/compileBroker.hpp"
48 #include "gc/shared/collectedHeap.inline.hpp"
49 #include "interpreter/bytecodeStream.hpp"
50 #include "interpreter/oopMapCache.hpp"
51 #include "interpreter/rewriter.hpp"
52 #include "jvm.h"
53 #include "jvmtifiles/jvmti.h"
54 #include "logging/log.hpp"
55 #include "klass.inline.hpp"
56 #include "logging/logMessage.hpp"
57 #include "logging/logStream.hpp"
58 #include "memory/allocation.inline.hpp"
59 #include "memory/iterator.inline.hpp"
60 #include "memory/metadataFactory.hpp"
61 #include "memory/metaspaceClosure.hpp"
62 #include "memory/oopFactory.hpp"
63 #include "memory/resourceArea.hpp"
64 #include "memory/universe.hpp"
65 #include "oops/fieldStreams.inline.hpp"
66 #include "oops/constantPool.hpp"
67 #include "oops/instanceClassLoaderKlass.hpp"
68 #include "oops/instanceKlass.inline.hpp"
69 #include "oops/instanceMirrorKlass.hpp"
70 #include "oops/instanceOop.hpp"
71 #include "oops/instanceStackChunkKlass.hpp"
72 #include "oops/klass.inline.hpp"
73 #include "oops/method.hpp"
74 #include "oops/oop.inline.hpp"
75 #include "oops/recordComponent.hpp"
76 #include "oops/symbol.hpp"
77 #include "prims/jvmtiExport.hpp"
78 #include "prims/jvmtiRedefineClasses.hpp"
79 #include "prims/jvmtiThreadState.hpp"
80 #include "prims/methodComparator.hpp"
81 #include "runtime/arguments.hpp"
82 #include "runtime/deoptimization.hpp"
83 #include "runtime/atomic.hpp"
84 #include "runtime/fieldDescriptor.inline.hpp"
85 #include "runtime/handles.inline.hpp"
86 #include "runtime/javaCalls.hpp"
87 #include "runtime/javaThread.inline.hpp"
88 #include "runtime/mutexLocker.hpp"
89 #include "runtime/orderAccess.hpp"
90 #include "runtime/os.inline.hpp"
91 #include "runtime/reflection.hpp"
92 #include "runtime/synchronizer.hpp"
93 #include "runtime/threads.hpp"
94 #include "services/classLoadingService.hpp"
95 #include "services/finalizerService.hpp"
96 #include "services/threadService.hpp"
97 #include "utilities/dtrace.hpp"
98 #include "utilities/events.hpp"
99 #include "utilities/macros.hpp"
100 #include "utilities/stringUtils.hpp"
101 #include "utilities/pair.hpp"
102 #ifdef COMPILER1
103 #include "c1/c1_Compiler.hpp"
104 #endif
105 #if INCLUDE_JFR
106 #include "jfr/jfrEvents.hpp"
107 #endif
108
109 #ifdef DTRACE_ENABLED
110
111
845 }
846
847 if (log_is_enabled(Info, cds, init)) {
848 ResourceMark rm;
849 log_info(cds, init)("%s (aot-inited)", external_name());
850 }
851
852 link_class(CHECK);
853
854 #ifdef ASSERT
855 {
856 Handle h_init_lock(THREAD, init_lock());
857 ObjectLocker ol(h_init_lock, THREAD);
858 assert(!is_initialized(), "sanity");
859 assert(!is_being_initialized(), "sanity");
860 assert(!is_in_error_state(), "sanity");
861 }
862 #endif
863
864 set_init_thread(THREAD);
865 AOTClassInitializer::call_runtime_setup(THREAD, this);
866 set_initialization_state_and_notify(fully_initialized, CHECK);
867 }
868 #endif
869
870 bool InstanceKlass::verify_code(TRAPS) {
871 // 1) Verify the bytecodes
872 return Verifier::verify(this, should_verify_class(), THREAD);
873 }
874
875 void InstanceKlass::link_class(TRAPS) {
876 assert(is_loaded(), "must be loaded");
877 if (!is_linked()) {
878 link_class_impl(CHECK);
879 }
880 }
881
882 // Called to verify that a class can link during initialization, without
883 // throwing a VerifyError.
884 bool InstanceKlass::link_class_or_fail(TRAPS) {
885 assert(is_loaded(), "must be loaded");
886 if (!is_linked()) {
1040 return true;
1041 }
1042
1043 // Rewrite the byte codes of all of the methods of a class.
1044 // The rewriter must be called exactly once. Rewriting must happen after
1045 // verification but before the first method of the class is executed.
1046 void InstanceKlass::rewrite_class(TRAPS) {
1047 assert(is_loaded(), "must be loaded");
1048 if (is_rewritten()) {
1049 assert(is_shared(), "rewriting an unshared class?");
1050 return;
1051 }
1052 Rewriter::rewrite(this, CHECK);
1053 set_rewritten();
1054 }
1055
1056 // Now relocate and link method entry points after class is rewritten.
1057 // This is outside is_rewritten flag. In case of an exception, it can be
1058 // executed more than once.
1059 void InstanceKlass::link_methods(TRAPS) {
1060 PerfTraceTime timer(ClassLoader::perf_ik_link_methods_time());
1061
1062 int len = methods()->length();
1063 for (int i = len-1; i >= 0; i--) {
1064 methodHandle m(THREAD, methods()->at(i));
1065
1066 // Set up method entry points for compiler and interpreter .
1067 m->link_method(m, CHECK);
1068 }
1069 }
1070
1071 // Eagerly initialize superinterfaces that declare default methods (concrete instance: any access)
1072 void InstanceKlass::initialize_super_interfaces(TRAPS) {
1073 assert (has_nonstatic_concrete_methods(), "caller should have checked this");
1074 for (int i = 0; i < local_interfaces()->length(); ++i) {
1075 InstanceKlass* ik = local_interfaces()->at(i);
1076
1077 // Initialization is depth first search ie. we start with top of the inheritance tree
1078 // has_nonstatic_concrete_methods drives searching superinterfaces since it
1079 // means has_nonstatic_concrete_methods in its superinterface hierarchy
1080 if (ik->has_nonstatic_concrete_methods()) {
1081 ik->initialize_super_interfaces(CHECK);
1082 }
1083
1084 // Only initialize() interfaces that "declare" concrete methods.
1149 assert_locked_or_safepoint(ClassInitError_lock);
1150 InitErrorTableCleaner cleaner;
1151 if (_initialization_error_table != nullptr) {
1152 _initialization_error_table->unlink(&cleaner);
1153 }
1154 }
1155
1156 void InstanceKlass::initialize_impl(TRAPS) {
1157 HandleMark hm(THREAD);
1158
1159 // Make sure klass is linked (verified) before initialization
1160 // A class could already be verified, since it has been reflected upon.
1161 link_class(CHECK);
1162
1163 DTRACE_CLASSINIT_PROBE(required, -1);
1164
1165 bool wait = false;
1166
1167 JavaThread* jt = THREAD;
1168
1169 bool debug_logging_enabled = log_is_enabled(Debug, class, init);
1170
1171 // refer to the JVM book page 47 for description of steps
1172 // Step 1
1173 {
1174 Handle h_init_lock(THREAD, init_lock());
1175 ObjectLocker ol(h_init_lock, jt);
1176
1177 // Step 2
1178 // If we were to use wait() instead of waitInterruptibly() then
1179 // we might end up throwing IE from link/symbol resolution sites
1180 // that aren't expected to throw. This would wreak havoc. See 6320309.
1181 while (is_being_initialized() && !is_reentrant_initialization(jt)) {
1182 if (debug_logging_enabled) {
1183 ResourceMark rm(jt);
1184 log_debug(class, init)("Thread \"%s\" waiting for initialization of %s by thread \"%s\"",
1185 jt->name(), external_name(), init_thread_name());
1186 }
1187 wait = true;
1188 jt->set_class_to_be_initialized(this);
1287 PerfClassTraceTime timer(ClassLoader::perf_class_init_time(),
1288 ClassLoader::perf_class_init_selftime(),
1289 ClassLoader::perf_classes_inited(),
1290 jt->get_thread_stat()->perf_recursion_counts_addr(),
1291 jt->get_thread_stat()->perf_timers_addr(),
1292 PerfClassTraceTime::CLASS_CLINIT);
1293 call_class_initializer(THREAD);
1294 } else {
1295 // The elapsed time is so small it's not worth counting.
1296 if (UsePerfData) {
1297 ClassLoader::perf_classes_inited()->inc();
1298 }
1299 call_class_initializer(THREAD);
1300 }
1301 }
1302
1303 // Step 9
1304 if (!HAS_PENDING_EXCEPTION) {
1305 set_initialization_state_and_notify(fully_initialized, CHECK);
1306 debug_only(vtable().verify(tty, true);)
1307 }
1308 else {
1309 // Step 10 and 11
1310 Handle e(THREAD, PENDING_EXCEPTION);
1311 CLEAR_PENDING_EXCEPTION;
1312 // JVMTI has already reported the pending exception
1313 // JVMTI internal flag reset is needed in order to report ExceptionInInitializerError
1314 JvmtiExport::clear_detected_exception(jt);
1315 {
1316 EXCEPTION_MARK;
1317 add_initialization_error(THREAD, e);
1318 set_initialization_state_and_notify(initialization_error, THREAD);
1319 CLEAR_PENDING_EXCEPTION; // ignore any exception thrown, class initialization error is thrown below
1320 // JVMTI has already reported the pending exception
1321 // JVMTI internal flag reset is needed in order to report ExceptionInInitializerError
1322 JvmtiExport::clear_detected_exception(jt);
1323 }
1324 DTRACE_CLASSINIT_PROBE_WAIT(error, -1, wait);
1325 if (e->is_a(vmClasses::Error_klass())) {
1326 THROW_OOP(e());
1327 } else {
1328 JavaCallArguments args(e);
1329 THROW_ARG(vmSymbols::java_lang_ExceptionInInitializerError(),
1330 vmSymbols::throwable_void_signature(),
1331 &args);
1332 }
1333 }
1334 DTRACE_CLASSINIT_PROBE_WAIT(end, -1, wait);
1335 }
1336
1337
1338 void InstanceKlass::set_initialization_state_and_notify(ClassState state, TRAPS) {
1339 Handle h_init_lock(THREAD, init_lock());
1340 if (h_init_lock() != nullptr) {
1341 ObjectLocker ol(h_init_lock, THREAD);
1342 set_init_thread(nullptr); // reset _init_thread before changing _init_state
1343 set_init_state(state);
1344 fence_and_clear_init_lock();
1345 ol.notify_all(CHECK);
1346 } else {
1347 assert(h_init_lock() != nullptr, "The initialization state should never be set twice");
1348 set_init_thread(nullptr); // reset _init_thread before changing _init_state
1349 set_init_state(state);
1350 }
1351 }
1352
1353 // Update hierarchy. This is done before the new klass has been added to the SystemDictionary. The Compile_lock
1354 // is grabbed, to ensure that the compiler is not using the class hierarchy.
1355 void InstanceKlass::add_to_hierarchy(JavaThread* current) {
1356 assert(!SafepointSynchronize::is_at_safepoint(), "must NOT be at safepoint");
1357
1547 tty->print("Registered ");
1548 i->print_value_on(tty);
1549 tty->print_cr(" (" PTR_FORMAT ") as finalizable", p2i(i));
1550 }
1551 instanceHandle h_i(THREAD, i);
1552 // Pass the handle as argument, JavaCalls::call expects oop as jobjects
1553 JavaValue result(T_VOID);
1554 JavaCallArguments args(h_i);
1555 methodHandle mh(THREAD, Universe::finalizer_register_method());
1556 JavaCalls::call(&result, mh, &args, CHECK_NULL);
1557 MANAGEMENT_ONLY(FinalizerService::on_register(h_i(), THREAD);)
1558 return h_i();
1559 }
1560
1561 instanceOop InstanceKlass::allocate_instance(TRAPS) {
1562 assert(!is_abstract() && !is_interface(), "Should not create this object");
1563 size_t size = size_helper(); // Query before forming handle.
1564 return (instanceOop)Universe::heap()->obj_allocate(this, size, CHECK_NULL);
1565 }
1566
1567 instanceOop InstanceKlass::allocate_instance(oop java_class, TRAPS) {
1568 Klass* k = java_lang_Class::as_Klass(java_class);
1569 if (k == nullptr) {
1570 ResourceMark rm(THREAD);
1571 THROW_(vmSymbols::java_lang_InstantiationException(), nullptr);
1572 }
1573 InstanceKlass* ik = cast(k);
1574 ik->check_valid_for_instantiation(false, CHECK_NULL);
1575 ik->initialize(CHECK_NULL);
1576 return ik->allocate_instance(THREAD);
1577 }
1578
1579 instanceHandle InstanceKlass::allocate_instance_handle(TRAPS) {
1580 return instanceHandle(THREAD, allocate_instance(THREAD));
1581 }
1582
1583 void InstanceKlass::check_valid_for_instantiation(bool throwError, TRAPS) {
1584 if (is_interface() || is_abstract()) {
1585 ResourceMark rm(THREAD);
1586 THROW_MSG(throwError ? vmSymbols::java_lang_InstantiationError()
1587 : vmSymbols::java_lang_InstantiationException(), external_name());
1615 }
1616
1617 ArrayKlass* InstanceKlass::array_klass_or_null(int n) {
1618 // Need load-acquire for lock-free read
1619 ObjArrayKlass* oak = array_klasses_acquire();
1620 if (oak == nullptr) {
1621 return nullptr;
1622 } else {
1623 return oak->array_klass_or_null(n);
1624 }
1625 }
1626
1627 ArrayKlass* InstanceKlass::array_klass(TRAPS) {
1628 return array_klass(1, THREAD);
1629 }
1630
1631 ArrayKlass* InstanceKlass::array_klass_or_null() {
1632 return array_klass_or_null(1);
1633 }
1634
1635 static int call_class_initializer_counter = 0; // for debugging
1636
1637 Method* InstanceKlass::class_initializer() const {
1638 Method* clinit = find_method(
1639 vmSymbols::class_initializer_name(), vmSymbols::void_method_signature());
1640 if (clinit != nullptr && clinit->has_valid_initializer_flags()) {
1641 return clinit;
1642 }
1643 return nullptr;
1644 }
1645
1646 void InstanceKlass::call_class_initializer(TRAPS) {
1647 if (ReplayCompiles &&
1648 (ReplaySuppressInitializers == 1 ||
1649 (ReplaySuppressInitializers >= 2 && class_loader() != nullptr))) {
1650 // Hide the existence of the initializer for the purpose of replaying the compile
1651 return;
1652 }
1653
1654 #if INCLUDE_CDS
1655 // This is needed to ensure the consistency of the archived heap objects.
1656 if (has_aot_initialized_mirror() && CDSConfig::is_loading_heap()) {
1657 AOTClassInitializer::call_runtime_setup(THREAD, this);
1658 return;
1659 } else if (has_archived_enum_objs()) {
1660 assert(is_shared(), "must be");
1661 bool initialized = CDSEnumKlass::initialize_enum_klass(this, CHECK);
1662 if (initialized) {
1663 return;
1664 }
1665 }
1666 #endif
1667
1668 methodHandle h_method(THREAD, class_initializer());
1669 assert(!is_initialized(), "we cannot initialize twice");
1670 LogTarget(Info, class, init) lt;
1671 if (lt.is_enabled()) {
1672 ResourceMark rm(THREAD);
1673 LogStream ls(lt);
1674 ls.print("%d Initializing ", call_class_initializer_counter++);
1675 name()->print_value_on(&ls);
1676 ls.print_cr("%s (" PTR_FORMAT ") by thread \"%s\"",
1677 h_method() == nullptr ? "(no method)" : "", p2i(this),
1678 THREAD->name());
1679 }
1680 if (h_method() != nullptr) {
1681 ThreadInClassInitializer ticl(THREAD, this); // Track class being initialized
1682 JavaCallArguments args; // No arguments
1683 JavaValue result(T_VOID);
1684 JavaCalls::call(&result, h_method, &args, CHECK); // Static call (no args)
1685 }
1686 }
1687
1688 // If a class that implements this interface is initialized, is the JVM required
1689 // to first execute a <clinit> method declared in this interface,
1690 // or (if also_check_supers==true) any of the super types of this interface?
1691 //
1692 // JVMS 5.5. Initialization, step 7: Next, if C is a class rather than
1693 // an interface, then let SC be its superclass and let SI1, ..., SIn
1694 // be all superinterfaces of C (whether direct or indirect) that
1695 // declare at least one non-abstract, non-static method.
1696 //
1697 // So when an interface is initialized, it does not look at its
1698 // supers. But a proper class will ensure that all of its supers have
1699 // run their <clinit> methods, except that it disregards interfaces
1700 // that lack a non-static concrete method (i.e., a default method).
1701 // Therefore, you should probably call this method only when the
1702 // current class is a super of some proper class, not an interface.
1703 bool InstanceKlass::interface_needs_clinit_execution_as_super(bool also_check_supers) const {
1704 assert(is_interface(), "must be");
1705
2470 }
2471 }
2472 if (new_jmeths != 0) {
2473 Method::ensure_jmethod_ids(class_loader_data(), new_jmeths);
2474 }
2475 }
2476
2477 // Lookup a jmethodID, null if not found. Do no blocking, no allocations, no handles
2478 jmethodID InstanceKlass::jmethod_id_or_null(Method* method) {
2479 int idnum = method->method_idnum();
2480 jmethodID* jmeths = methods_jmethod_ids_acquire();
2481 return (jmeths != nullptr) ? jmeths[idnum + 1] : nullptr;
2482 }
2483
2484 inline DependencyContext InstanceKlass::dependencies() {
2485 DependencyContext dep_context(&_dep_context, &_dep_context_last_cleaned);
2486 return dep_context;
2487 }
2488
2489 void InstanceKlass::mark_dependent_nmethods(DeoptimizationScope* deopt_scope, KlassDepChange& changes) {
2490 dependencies().mark_dependent_nmethods(deopt_scope, changes);
2491 }
2492
2493 void InstanceKlass::add_dependent_nmethod(nmethod* nm) {
2494 dependencies().add_dependent_nmethod(nm);
2495 }
2496
2497 void InstanceKlass::clean_dependency_context() {
2498 dependencies().clean_unloading_dependents();
2499 }
2500
2501 #ifndef PRODUCT
2502 void InstanceKlass::print_dependent_nmethods(bool verbose) {
2503 dependencies().print_dependent_nmethods(verbose);
2504 }
2505
2506 bool InstanceKlass::is_dependent_nmethod(nmethod* nm) {
2507 return dependencies().is_dependent_nmethod(nm);
2508 }
2509 #endif //PRODUCT
2510
2607 for (int i = 0; i < nof_interfaces; i ++, ioe ++) {
2608 if (ioe->interface_klass() != nullptr) {
2609 it->push(ioe->interface_klass_addr());
2610 itableMethodEntry* ime = ioe->first_method_entry(this);
2611 int n = klassItable::method_count_for_interface(ioe->interface_klass());
2612 for (int index = 0; index < n; index ++) {
2613 it->push(ime[index].method_addr());
2614 }
2615 }
2616 }
2617 }
2618
2619 it->push(&_nest_host);
2620 it->push(&_nest_members);
2621 it->push(&_permitted_subclasses);
2622 it->push(&_record_components);
2623 }
2624
2625 #if INCLUDE_CDS
2626 void InstanceKlass::remove_unshareable_info() {
2627
2628 if (is_linked()) {
2629 assert(can_be_verified_at_dumptime(), "must be");
2630 // Remember this so we can avoid walking the hierarchy at runtime.
2631 set_verified_at_dump_time();
2632 }
2633
2634 Klass::remove_unshareable_info();
2635
2636 if (SystemDictionaryShared::has_class_failed_verification(this)) {
2637 // Classes are attempted to link during dumping and may fail,
2638 // but these classes are still in the dictionary and class list in CLD.
2639 // If the class has failed verification, there is nothing else to remove.
2640 return;
2641 }
2642
2643 // Reset to the 'allocated' state to prevent any premature accessing to
2644 // a shared class at runtime while the class is still being loaded and
2645 // restored. A class' init_state is set to 'loaded' at runtime when it's
2646 // being added to class hierarchy (see InstanceKlass:::add_to_hierarchy()).
2647 _init_state = allocated;
2648
2649 { // Otherwise this needs to take out the Compile_lock.
2650 assert(SafepointSynchronize::is_at_safepoint(), "only called at safepoint");
2651 init_implementor();
2652 }
2671 _osr_nmethods_head = nullptr;
2672 #if INCLUDE_JVMTI
2673 _breakpoints = nullptr;
2674 _previous_versions = nullptr;
2675 _cached_class_file = nullptr;
2676 _jvmti_cached_class_field_map = nullptr;
2677 #endif
2678
2679 _init_thread = nullptr;
2680 _methods_jmethod_ids = nullptr;
2681 _jni_ids = nullptr;
2682 _oop_map_cache = nullptr;
2683 if (CDSConfig::is_dumping_invokedynamic() && HeapShared::is_lambda_proxy_klass(this)) {
2684 // keep _nest_host
2685 } else {
2686 // clear _nest_host to ensure re-load at runtime
2687 _nest_host = nullptr;
2688 }
2689 init_shared_package_entry();
2690 _dep_context_last_cleaned = 0;
2691
2692 remove_unshareable_flags();
2693 }
2694
2695 void InstanceKlass::remove_unshareable_flags() {
2696 // clear all the flags/stats that shouldn't be in the archived version
2697 assert(!is_scratch_class(), "must be");
2698 assert(!has_been_redefined(), "must be");
2699 #if INCLUDE_JVMTI
2700 set_is_being_redefined(false);
2701 #endif
2702 set_has_resolved_methods(false);
2703 }
2704
2705 void InstanceKlass::remove_java_mirror() {
2706 Klass::remove_java_mirror();
2707
2708 // do array classes also.
2709 if (array_klasses() != nullptr) {
2710 array_klasses()->remove_java_mirror();
2781
2782 // restore constant pool resolved references
2783 constants()->restore_unshareable_info(CHECK);
2784
2785 if (array_klasses() != nullptr) {
2786 // To get a consistent list of classes we need MultiArray_lock to ensure
2787 // array classes aren't observed while they are being restored.
2788 RecursiveLocker rl(MultiArray_lock, THREAD);
2789 assert(this == array_klasses()->bottom_klass(), "sanity");
2790 // Array classes have null protection domain.
2791 // --> see ArrayKlass::complete_create_array_klass()
2792 array_klasses()->restore_unshareable_info(class_loader_data(), Handle(), CHECK);
2793 }
2794
2795 // Initialize @ValueBased class annotation if not already set in the archived klass.
2796 if (DiagnoseSyncOnValueBasedClasses && has_value_based_class_annotation() && !is_value_based()) {
2797 set_is_value_based();
2798 }
2799 }
2800
2801 // Check if a class or any of its supertypes has a version older than 50.
2802 // CDS will not perform verification of old classes during dump time because
2803 // without changing the old verifier, the verification constraint cannot be
2804 // retrieved during dump time.
2805 // Verification of archived old classes will be performed during run time.
2806 bool InstanceKlass::can_be_verified_at_dumptime() const {
2807 if (MetaspaceShared::is_in_shared_metaspace(this)) {
2808 // This is a class that was dumped into the base archive, so we know
2809 // it was verified at dump time.
2810 return true;
2811 }
2812 if (major_version() < 50 /*JAVA_6_VERSION*/) {
2813 return false;
2814 }
2815 if (java_super() != nullptr && !java_super()->can_be_verified_at_dumptime()) {
2816 return false;
2817 }
2818 Array<InstanceKlass*>* interfaces = local_interfaces();
2819 int len = interfaces->length();
2820 for (int i = 0; i < len; i++) {
2821 if (!interfaces->at(i)->can_be_verified_at_dumptime()) {
2822 return false;
2823 }
2824 }
2825 return true;
2826 }
2827
2828 int InstanceKlass::shared_class_loader_type() const {
2829 if (is_shared_boot_class()) {
2830 return ClassLoader::BOOT_LOADER;
2831 } else if (is_shared_platform_class()) {
2832 return ClassLoader::PLATFORM_LOADER;
2833 } else if (is_shared_app_class()) {
2834 return ClassLoader::APP_LOADER;
2835 } else {
2836 return ClassLoader::OTHER;
2837 }
2838 }
2839 #endif // INCLUDE_CDS
2840
2841 #if INCLUDE_JVMTI
2842 static void clear_all_breakpoints(Method* m) {
2843 m->clear_all_breakpoints();
2844 }
2845 #endif
2846
2847 void InstanceKlass::unload_class(InstanceKlass* ik) {
2848
2849 if (ik->is_scratch_class()) {
2850 assert(ik->dependencies().is_empty(), "dependencies should be empty for scratch classes");
2851 return;
2852 }
2853 assert(ik->is_loaded(), "class should be loaded " PTR_FORMAT, p2i(ik));
2854
2855 // Release dependencies.
2856 ik->dependencies().remove_all_dependents();
2857
2858 // notify the debugger
3596 static void print_vtable(intptr_t* start, int len, outputStream* st) {
3597 for (int i = 0; i < len; i++) {
3598 intptr_t e = start[i];
3599 st->print("%d : " INTPTR_FORMAT, i, e);
3600 if (MetaspaceObj::is_valid((Metadata*)e)) {
3601 st->print(" ");
3602 ((Metadata*)e)->print_value_on(st);
3603 }
3604 st->cr();
3605 }
3606 }
3607
3608 static void print_vtable(vtableEntry* start, int len, outputStream* st) {
3609 return print_vtable(reinterpret_cast<intptr_t*>(start), len, st);
3610 }
3611
3612 const char* InstanceKlass::init_state_name() const {
3613 return state_names[init_state()];
3614 }
3615
3616 void InstanceKlass::print_on(outputStream* st) const {
3617 assert(is_klass(), "must be klass");
3618 Klass::print_on(st);
3619
3620 st->print(BULLET"instance size: %d", size_helper()); st->cr();
3621 st->print(BULLET"klass size: %d", size()); st->cr();
3622 st->print(BULLET"access: "); access_flags().print_on(st); st->cr();
3623 st->print(BULLET"flags: "); _misc_flags.print_on(st); st->cr();
3624 st->print(BULLET"state: "); st->print_cr("%s", init_state_name());
3625 st->print(BULLET"name: "); name()->print_value_on(st); st->cr();
3626 st->print(BULLET"super: "); Metadata::print_value_on_maybe_null(st, super()); st->cr();
3627 st->print(BULLET"sub: ");
3628 Klass* sub = subklass();
3629 int n;
3630 for (n = 0; sub != nullptr; n++, sub = sub->next_sibling()) {
3631 if (n < MaxSubklassPrintSize) {
3632 sub->print_value_on(st);
3633 st->print(" ");
3634 }
3635 }
3925 nullptr;
3926 // caller can be null, for example, during a JVMTI VM_Init hook
3927 if (caller != nullptr) {
3928 info_stream.print(" source: instance of %s", caller->external_name());
3929 } else {
3930 // source is unknown
3931 }
3932 } else {
3933 oop class_loader = loader_data->class_loader();
3934 info_stream.print(" source: %s", class_loader->klass()->external_name());
3935 }
3936 } else {
3937 assert(this->is_shared(), "must be");
3938 if (MetaspaceShared::is_shared_dynamic((void*)this)) {
3939 info_stream.print(" source: shared objects file (top)");
3940 } else {
3941 info_stream.print(" source: shared objects file");
3942 }
3943 }
3944
3945 msg.info("%s", info_stream.as_string());
3946
3947 if (log_is_enabled(Debug, class, load)) {
3948 stringStream debug_stream;
3949
3950 // Class hierarchy info
3951 debug_stream.print(" klass: " PTR_FORMAT " super: " PTR_FORMAT,
3952 p2i(this), p2i(superklass()));
3953
3954 // Interfaces
3955 if (local_interfaces() != nullptr && local_interfaces()->length() > 0) {
3956 debug_stream.print(" interfaces:");
3957 int length = local_interfaces()->length();
3958 for (int i = 0; i < length; i++) {
3959 debug_stream.print(" " PTR_FORMAT,
3960 p2i(InstanceKlass::cast(local_interfaces()->at(i))));
3961 }
3962 }
3963
3964 // Class loader
|
1 /*
2 * Copyright (c) 1997, 2025, 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 *
29 #include "cds/cdsEnumKlass.hpp"
30 #include "cds/classListWriter.hpp"
31 #include "cds/heapShared.hpp"
32 #include "cds/metaspaceShared.hpp"
33 #include "classfile/classFileParser.hpp"
34 #include "classfile/classFileStream.hpp"
35 #include "classfile/classLoader.hpp"
36 #include "classfile/classLoaderData.inline.hpp"
37 #include "classfile/javaClasses.hpp"
38 #include "classfile/moduleEntry.hpp"
39 #include "classfile/systemDictionary.hpp"
40 #include "classfile/systemDictionaryShared.hpp"
41 #include "classfile/verifier.hpp"
42 #include "classfile/vmClasses.hpp"
43 #include "classfile/vmSymbols.hpp"
44 #include "code/codeCache.hpp"
45 #include "code/dependencyContext.hpp"
46 #include "compiler/compilationPolicy.hpp"
47 #include "compiler/compileBroker.hpp"
48 #include "gc/shared/collectedHeap.inline.hpp"
49 #include "interpreter/bytecodeHistogram.hpp"
50 #include "interpreter/bytecodeStream.hpp"
51 #include "interpreter/oopMapCache.hpp"
52 #include "interpreter/rewriter.hpp"
53 #include "jvm.h"
54 #include "jvmtifiles/jvmti.h"
55 #include "logging/log.hpp"
56 #include "klass.inline.hpp"
57 #include "logging/logMessage.hpp"
58 #include "logging/logStream.hpp"
59 #include "memory/allocation.inline.hpp"
60 #include "memory/iterator.inline.hpp"
61 #include "memory/metadataFactory.hpp"
62 #include "memory/metaspaceClosure.hpp"
63 #include "memory/oopFactory.hpp"
64 #include "memory/resourceArea.hpp"
65 #include "memory/universe.hpp"
66 #include "oops/fieldStreams.inline.hpp"
67 #include "oops/constantPool.hpp"
68 #include "oops/instanceClassLoaderKlass.hpp"
69 #include "oops/instanceKlass.inline.hpp"
70 #include "oops/instanceMirrorKlass.hpp"
71 #include "oops/instanceOop.hpp"
72 #include "oops/instanceStackChunkKlass.hpp"
73 #include "oops/klass.inline.hpp"
74 #include "oops/method.hpp"
75 #include "oops/oop.inline.hpp"
76 #include "oops/recordComponent.hpp"
77 #include "oops/symbol.hpp"
78 #include "oops/trainingData.hpp"
79 #include "prims/jvmtiExport.hpp"
80 #include "prims/jvmtiRedefineClasses.hpp"
81 #include "prims/jvmtiThreadState.hpp"
82 #include "prims/methodComparator.hpp"
83 #include "runtime/arguments.hpp"
84 #include "runtime/deoptimization.hpp"
85 #include "runtime/atomic.hpp"
86 #include "runtime/fieldDescriptor.inline.hpp"
87 #include "runtime/handles.inline.hpp"
88 #include "runtime/javaCalls.hpp"
89 #include "runtime/javaThread.inline.hpp"
90 #include "runtime/mutexLocker.hpp"
91 #include "runtime/orderAccess.hpp"
92 #include "runtime/os.inline.hpp"
93 #include "runtime/reflection.hpp"
94 #include "runtime/runtimeUpcalls.hpp"
95 #include "runtime/synchronizer.hpp"
96 #include "runtime/threads.hpp"
97 #include "services/classLoadingService.hpp"
98 #include "services/finalizerService.hpp"
99 #include "services/threadService.hpp"
100 #include "utilities/dtrace.hpp"
101 #include "utilities/events.hpp"
102 #include "utilities/macros.hpp"
103 #include "utilities/stringUtils.hpp"
104 #include "utilities/pair.hpp"
105 #ifdef COMPILER1
106 #include "c1/c1_Compiler.hpp"
107 #endif
108 #if INCLUDE_JFR
109 #include "jfr/jfrEvents.hpp"
110 #endif
111
112 #ifdef DTRACE_ENABLED
113
114
848 }
849
850 if (log_is_enabled(Info, cds, init)) {
851 ResourceMark rm;
852 log_info(cds, init)("%s (aot-inited)", external_name());
853 }
854
855 link_class(CHECK);
856
857 #ifdef ASSERT
858 {
859 Handle h_init_lock(THREAD, init_lock());
860 ObjectLocker ol(h_init_lock, THREAD);
861 assert(!is_initialized(), "sanity");
862 assert(!is_being_initialized(), "sanity");
863 assert(!is_in_error_state(), "sanity");
864 }
865 #endif
866
867 set_init_thread(THREAD);
868 set_initialization_state_and_notify(fully_initialized, CHECK);
869 AOTClassInitializer::call_runtime_setup(THREAD, this);
870 }
871 #endif
872
873 bool InstanceKlass::verify_code(TRAPS) {
874 // 1) Verify the bytecodes
875 return Verifier::verify(this, should_verify_class(), THREAD);
876 }
877
878 void InstanceKlass::link_class(TRAPS) {
879 assert(is_loaded(), "must be loaded");
880 if (!is_linked()) {
881 link_class_impl(CHECK);
882 }
883 }
884
885 // Called to verify that a class can link during initialization, without
886 // throwing a VerifyError.
887 bool InstanceKlass::link_class_or_fail(TRAPS) {
888 assert(is_loaded(), "must be loaded");
889 if (!is_linked()) {
1043 return true;
1044 }
1045
1046 // Rewrite the byte codes of all of the methods of a class.
1047 // The rewriter must be called exactly once. Rewriting must happen after
1048 // verification but before the first method of the class is executed.
1049 void InstanceKlass::rewrite_class(TRAPS) {
1050 assert(is_loaded(), "must be loaded");
1051 if (is_rewritten()) {
1052 assert(is_shared(), "rewriting an unshared class?");
1053 return;
1054 }
1055 Rewriter::rewrite(this, CHECK);
1056 set_rewritten();
1057 }
1058
1059 // Now relocate and link method entry points after class is rewritten.
1060 // This is outside is_rewritten flag. In case of an exception, it can be
1061 // executed more than once.
1062 void InstanceKlass::link_methods(TRAPS) {
1063 PerfTraceElapsedTime timer(ClassLoader::perf_ik_link_methods_time());
1064
1065 int len = methods()->length();
1066 for (int i = len-1; i >= 0; i--) {
1067 methodHandle m(THREAD, methods()->at(i));
1068 RuntimeUpcalls::install_upcalls(m);
1069
1070 // Set up method entry points for compiler and interpreter .
1071 m->link_method(m, CHECK);
1072 }
1073 }
1074
1075 // Eagerly initialize superinterfaces that declare default methods (concrete instance: any access)
1076 void InstanceKlass::initialize_super_interfaces(TRAPS) {
1077 assert (has_nonstatic_concrete_methods(), "caller should have checked this");
1078 for (int i = 0; i < local_interfaces()->length(); ++i) {
1079 InstanceKlass* ik = local_interfaces()->at(i);
1080
1081 // Initialization is depth first search ie. we start with top of the inheritance tree
1082 // has_nonstatic_concrete_methods drives searching superinterfaces since it
1083 // means has_nonstatic_concrete_methods in its superinterface hierarchy
1084 if (ik->has_nonstatic_concrete_methods()) {
1085 ik->initialize_super_interfaces(CHECK);
1086 }
1087
1088 // Only initialize() interfaces that "declare" concrete methods.
1153 assert_locked_or_safepoint(ClassInitError_lock);
1154 InitErrorTableCleaner cleaner;
1155 if (_initialization_error_table != nullptr) {
1156 _initialization_error_table->unlink(&cleaner);
1157 }
1158 }
1159
1160 void InstanceKlass::initialize_impl(TRAPS) {
1161 HandleMark hm(THREAD);
1162
1163 // Make sure klass is linked (verified) before initialization
1164 // A class could already be verified, since it has been reflected upon.
1165 link_class(CHECK);
1166
1167 DTRACE_CLASSINIT_PROBE(required, -1);
1168
1169 bool wait = false;
1170
1171 JavaThread* jt = THREAD;
1172
1173 if (ForceProfiling) {
1174 // Preallocate MDOs.
1175 for (int i = 0; i < methods()->length(); i++) {
1176 assert(!HAS_PENDING_EXCEPTION, "");
1177 methodHandle m(THREAD, methods()->at(i));
1178 Method::build_profiling_method_data(m, THREAD);
1179 if (HAS_PENDING_EXCEPTION) {
1180 ResourceMark rm;
1181 log_warning(cds)("MDO preallocation failed for %s", external_name());
1182 CLEAR_PENDING_EXCEPTION;
1183 break;
1184 }
1185 }
1186 }
1187
1188 bool debug_logging_enabled = log_is_enabled(Debug, class, init);
1189
1190 // refer to the JVM book page 47 for description of steps
1191 // Step 1
1192 {
1193 Handle h_init_lock(THREAD, init_lock());
1194 ObjectLocker ol(h_init_lock, jt);
1195
1196 // Step 2
1197 // If we were to use wait() instead of waitInterruptibly() then
1198 // we might end up throwing IE from link/symbol resolution sites
1199 // that aren't expected to throw. This would wreak havoc. See 6320309.
1200 while (is_being_initialized() && !is_reentrant_initialization(jt)) {
1201 if (debug_logging_enabled) {
1202 ResourceMark rm(jt);
1203 log_debug(class, init)("Thread \"%s\" waiting for initialization of %s by thread \"%s\"",
1204 jt->name(), external_name(), init_thread_name());
1205 }
1206 wait = true;
1207 jt->set_class_to_be_initialized(this);
1306 PerfClassTraceTime timer(ClassLoader::perf_class_init_time(),
1307 ClassLoader::perf_class_init_selftime(),
1308 ClassLoader::perf_classes_inited(),
1309 jt->get_thread_stat()->perf_recursion_counts_addr(),
1310 jt->get_thread_stat()->perf_timers_addr(),
1311 PerfClassTraceTime::CLASS_CLINIT);
1312 call_class_initializer(THREAD);
1313 } else {
1314 // The elapsed time is so small it's not worth counting.
1315 if (UsePerfData) {
1316 ClassLoader::perf_classes_inited()->inc();
1317 }
1318 call_class_initializer(THREAD);
1319 }
1320 }
1321
1322 // Step 9
1323 if (!HAS_PENDING_EXCEPTION) {
1324 set_initialization_state_and_notify(fully_initialized, CHECK);
1325 debug_only(vtable().verify(tty, true);)
1326 CompilationPolicy::replay_training_at_init(this, THREAD);
1327 }
1328 else {
1329 // Step 10 and 11
1330 Handle e(THREAD, PENDING_EXCEPTION);
1331 CLEAR_PENDING_EXCEPTION;
1332 // JVMTI has already reported the pending exception
1333 // JVMTI internal flag reset is needed in order to report ExceptionInInitializerError
1334 JvmtiExport::clear_detected_exception(jt);
1335 {
1336 EXCEPTION_MARK;
1337 add_initialization_error(THREAD, e);
1338 set_initialization_state_and_notify(initialization_error, THREAD);
1339 CLEAR_PENDING_EXCEPTION; // ignore any exception thrown, class initialization error is thrown below
1340 // JVMTI has already reported the pending exception
1341 // JVMTI internal flag reset is needed in order to report ExceptionInInitializerError
1342 JvmtiExport::clear_detected_exception(jt);
1343 }
1344 DTRACE_CLASSINIT_PROBE_WAIT(error, -1, wait);
1345 if (e->is_a(vmClasses::Error_klass())) {
1346 THROW_OOP(e());
1347 } else {
1348 JavaCallArguments args(e);
1349 THROW_ARG(vmSymbols::java_lang_ExceptionInInitializerError(),
1350 vmSymbols::throwable_void_signature(),
1351 &args);
1352 }
1353 }
1354 DTRACE_CLASSINIT_PROBE_WAIT(end, -1, wait);
1355 }
1356
1357 void InstanceKlass::set_initialization_state_and_notify(ClassState state, TRAPS) {
1358 Handle h_init_lock(THREAD, init_lock());
1359 if (h_init_lock() != nullptr) {
1360 ObjectLocker ol(h_init_lock, THREAD);
1361 set_init_thread(nullptr); // reset _init_thread before changing _init_state
1362 set_init_state(state);
1363 fence_and_clear_init_lock();
1364 ol.notify_all(CHECK);
1365 } else {
1366 assert(h_init_lock() != nullptr, "The initialization state should never be set twice");
1367 set_init_thread(nullptr); // reset _init_thread before changing _init_state
1368 set_init_state(state);
1369 }
1370 }
1371
1372 // Update hierarchy. This is done before the new klass has been added to the SystemDictionary. The Compile_lock
1373 // is grabbed, to ensure that the compiler is not using the class hierarchy.
1374 void InstanceKlass::add_to_hierarchy(JavaThread* current) {
1375 assert(!SafepointSynchronize::is_at_safepoint(), "must NOT be at safepoint");
1376
1566 tty->print("Registered ");
1567 i->print_value_on(tty);
1568 tty->print_cr(" (" PTR_FORMAT ") as finalizable", p2i(i));
1569 }
1570 instanceHandle h_i(THREAD, i);
1571 // Pass the handle as argument, JavaCalls::call expects oop as jobjects
1572 JavaValue result(T_VOID);
1573 JavaCallArguments args(h_i);
1574 methodHandle mh(THREAD, Universe::finalizer_register_method());
1575 JavaCalls::call(&result, mh, &args, CHECK_NULL);
1576 MANAGEMENT_ONLY(FinalizerService::on_register(h_i(), THREAD);)
1577 return h_i();
1578 }
1579
1580 instanceOop InstanceKlass::allocate_instance(TRAPS) {
1581 assert(!is_abstract() && !is_interface(), "Should not create this object");
1582 size_t size = size_helper(); // Query before forming handle.
1583 return (instanceOop)Universe::heap()->obj_allocate(this, size, CHECK_NULL);
1584 }
1585
1586 instanceOop InstanceKlass::allocate_instance(oop java_class,
1587 const char* who,
1588 TRAPS) {
1589 Klass* k = java_lang_Class::as_Klass(java_class);
1590 if (k == nullptr) {
1591 ResourceMark rm(THREAD);
1592 THROW_(vmSymbols::java_lang_InstantiationException(), nullptr);
1593 }
1594 InstanceKlass* ik = cast(k);
1595 ik->check_valid_for_instantiation(false, CHECK_NULL);
1596 ik->initialize(CHECK_NULL);
1597 return ik->allocate_instance(THREAD);
1598 }
1599
1600 instanceHandle InstanceKlass::allocate_instance_handle(TRAPS) {
1601 return instanceHandle(THREAD, allocate_instance(THREAD));
1602 }
1603
1604 void InstanceKlass::check_valid_for_instantiation(bool throwError, TRAPS) {
1605 if (is_interface() || is_abstract()) {
1606 ResourceMark rm(THREAD);
1607 THROW_MSG(throwError ? vmSymbols::java_lang_InstantiationError()
1608 : vmSymbols::java_lang_InstantiationException(), external_name());
1636 }
1637
1638 ArrayKlass* InstanceKlass::array_klass_or_null(int n) {
1639 // Need load-acquire for lock-free read
1640 ObjArrayKlass* oak = array_klasses_acquire();
1641 if (oak == nullptr) {
1642 return nullptr;
1643 } else {
1644 return oak->array_klass_or_null(n);
1645 }
1646 }
1647
1648 ArrayKlass* InstanceKlass::array_klass(TRAPS) {
1649 return array_klass(1, THREAD);
1650 }
1651
1652 ArrayKlass* InstanceKlass::array_klass_or_null() {
1653 return array_klass_or_null(1);
1654 }
1655
1656 Method* InstanceKlass::class_initializer() const {
1657 Method* clinit = find_method(
1658 vmSymbols::class_initializer_name(), vmSymbols::void_method_signature());
1659 if (clinit != nullptr && clinit->has_valid_initializer_flags()) {
1660 return clinit;
1661 }
1662 return nullptr;
1663 }
1664
1665 void InstanceKlass::call_class_initializer(TRAPS) {
1666 if (ReplayCompiles &&
1667 (ReplaySuppressInitializers == 1 ||
1668 (ReplaySuppressInitializers >= 2 && class_loader() != nullptr))) {
1669 // Hide the existence of the initializer for the purpose of replaying the compile
1670 return;
1671 }
1672
1673 #if INCLUDE_CDS
1674 // This is needed to ensure the consistency of the archived heap objects.
1675 if (has_aot_initialized_mirror() && CDSConfig::is_loading_heap()) {
1676 AOTClassInitializer::call_runtime_setup(THREAD, this);
1677 return;
1678 } else if (has_archived_enum_objs()) {
1679 assert(is_shared(), "must be");
1680 bool initialized = CDSEnumKlass::initialize_enum_klass(this, CHECK);
1681 if (initialized) {
1682 return;
1683 }
1684 }
1685 #endif
1686
1687 methodHandle h_method(THREAD, class_initializer());
1688 assert(!is_initialized(), "we cannot initialize twice");
1689
1690 #if 0
1691 // FIXME -- revive this code added to leyden/premain for <clinit> profiling
1692 int init_id = log_class_init(THREAD, this);
1693 if (h_method() != nullptr) {
1694 JavaCallArguments args; // No arguments
1695 JavaValue result(T_VOID);
1696 InstanceKlass* outer = THREAD->set_class_being_initialized(this);
1697 jlong bc_start = (CountBytecodesPerThread ? THREAD->bc_counter_value() : BytecodeCounter::counter_value());
1698
1699 elapsedTimer timer;
1700 {
1701 PerfPauseTimer pt(THREAD->current_rt_call_timer(), THREAD->profile_rt_calls());
1702 PauseRuntimeCallProfiling prcp(THREAD, THREAD->profile_rt_calls());
1703
1704 timer.start();
1705 JavaCalls::call(&result, h_method, &args, THREAD); // Static call (no args)
1706 timer.stop();
1707 }
1708
1709 jlong bc_end = (CountBytecodesPerThread ? THREAD->bc_counter_value() : BytecodeCounter::counter_value());
1710
1711 jlong bc_executed = (bc_end - bc_start);
1712 if (UsePerfData && outer == nullptr) { // outermost clinit
1713 THREAD->inc_clinit_bc_counter_value(bc_executed);
1714 ClassLoader::perf_class_init_bytecodes_count()->inc(bc_executed);
1715 }
1716
1717 THREAD->set_class_being_initialized(outer);
1718
1719 LogStreamHandle(Debug, init) log;
1720 if (log.is_enabled()) {
1721 ResourceMark rm(THREAD);
1722 log.print("%d Initialized in %.3fms (total: " JLONG_FORMAT "ms); ",
1723 init_id, timer.seconds() * 1000.0, ClassLoader::class_init_time_ms());
1724 if (CountBytecodes || CountBytecodesPerThread) {
1725 log.print("executed " JLONG_FORMAT " bytecodes; ", bc_executed);
1726 }
1727 name()->print_value_on(&log);
1728 log.print_cr(" by thread " PTR_FORMAT " \"%s\" (" PTR_FORMAT ")",
1729 p2i(THREAD), THREAD->name(), p2i(this));
1730 }
1731 }
1732 LogTarget(Info, class, init) lt;
1733 if (lt.is_enabled()) {
1734 ResourceMark rm(THREAD);
1735 LogStream ls(lt);
1736 ls.print("%d Initialized ", init_id);
1737 name()->print_value_on(&ls);
1738 ls.print_cr("%s (" PTR_FORMAT ") by thread \"%s\"",
1739 h_method() == nullptr ? "(no method)" : "", p2i(this),
1740 THREAD->name());
1741 }
1742 #else
1743 static int call_class_initializer_counter = 0; // for debugging
1744 LogTarget(Info, class, init) lt;
1745 if (lt.is_enabled()) {
1746 ResourceMark rm(THREAD);
1747 LogStream ls(lt);
1748 ls.print("%d Initializing ", call_class_initializer_counter++);
1749 name()->print_value_on(&ls);
1750 ls.print_cr("%s (" PTR_FORMAT ") by thread \"%s\"",
1751 h_method() == nullptr ? "(no method)" : "", p2i(this),
1752 THREAD->name());
1753 }
1754 if (h_method() != nullptr) {
1755 ThreadInClassInitializer ticl(THREAD, this); // Track class being initialized
1756 JavaCallArguments args; // No arguments
1757 JavaValue result(T_VOID);
1758 JavaCalls::call(&result, h_method, &args, CHECK); // Static call (no args)
1759 }
1760 #endif
1761 }
1762
1763 // If a class that implements this interface is initialized, is the JVM required
1764 // to first execute a <clinit> method declared in this interface,
1765 // or (if also_check_supers==true) any of the super types of this interface?
1766 //
1767 // JVMS 5.5. Initialization, step 7: Next, if C is a class rather than
1768 // an interface, then let SC be its superclass and let SI1, ..., SIn
1769 // be all superinterfaces of C (whether direct or indirect) that
1770 // declare at least one non-abstract, non-static method.
1771 //
1772 // So when an interface is initialized, it does not look at its
1773 // supers. But a proper class will ensure that all of its supers have
1774 // run their <clinit> methods, except that it disregards interfaces
1775 // that lack a non-static concrete method (i.e., a default method).
1776 // Therefore, you should probably call this method only when the
1777 // current class is a super of some proper class, not an interface.
1778 bool InstanceKlass::interface_needs_clinit_execution_as_super(bool also_check_supers) const {
1779 assert(is_interface(), "must be");
1780
2545 }
2546 }
2547 if (new_jmeths != 0) {
2548 Method::ensure_jmethod_ids(class_loader_data(), new_jmeths);
2549 }
2550 }
2551
2552 // Lookup a jmethodID, null if not found. Do no blocking, no allocations, no handles
2553 jmethodID InstanceKlass::jmethod_id_or_null(Method* method) {
2554 int idnum = method->method_idnum();
2555 jmethodID* jmeths = methods_jmethod_ids_acquire();
2556 return (jmeths != nullptr) ? jmeths[idnum + 1] : nullptr;
2557 }
2558
2559 inline DependencyContext InstanceKlass::dependencies() {
2560 DependencyContext dep_context(&_dep_context, &_dep_context_last_cleaned);
2561 return dep_context;
2562 }
2563
2564 void InstanceKlass::mark_dependent_nmethods(DeoptimizationScope* deopt_scope, KlassDepChange& changes) {
2565 dependencies().mark_dependent_nmethods(deopt_scope, changes, this);
2566 }
2567
2568 void InstanceKlass::add_dependent_nmethod(nmethod* nm) {
2569 dependencies().add_dependent_nmethod(nm);
2570 }
2571
2572 void InstanceKlass::clean_dependency_context() {
2573 dependencies().clean_unloading_dependents();
2574 }
2575
2576 #ifndef PRODUCT
2577 void InstanceKlass::print_dependent_nmethods(bool verbose) {
2578 dependencies().print_dependent_nmethods(verbose);
2579 }
2580
2581 bool InstanceKlass::is_dependent_nmethod(nmethod* nm) {
2582 return dependencies().is_dependent_nmethod(nm);
2583 }
2584 #endif //PRODUCT
2585
2682 for (int i = 0; i < nof_interfaces; i ++, ioe ++) {
2683 if (ioe->interface_klass() != nullptr) {
2684 it->push(ioe->interface_klass_addr());
2685 itableMethodEntry* ime = ioe->first_method_entry(this);
2686 int n = klassItable::method_count_for_interface(ioe->interface_klass());
2687 for (int index = 0; index < n; index ++) {
2688 it->push(ime[index].method_addr());
2689 }
2690 }
2691 }
2692 }
2693
2694 it->push(&_nest_host);
2695 it->push(&_nest_members);
2696 it->push(&_permitted_subclasses);
2697 it->push(&_record_components);
2698 }
2699
2700 #if INCLUDE_CDS
2701 void InstanceKlass::remove_unshareable_info() {
2702 if (is_linked()) {
2703 assert(can_be_verified_at_dumptime(), "must be");
2704 // Remember this so we can avoid walking the hierarchy at runtime.
2705 set_verified_at_dump_time();
2706 }
2707 _misc_flags.set_has_init_deps_processed(false);
2708
2709 Klass::remove_unshareable_info();
2710
2711 if (SystemDictionaryShared::has_class_failed_verification(this)) {
2712 // Classes are attempted to link during dumping and may fail,
2713 // but these classes are still in the dictionary and class list in CLD.
2714 // If the class has failed verification, there is nothing else to remove.
2715 return;
2716 }
2717
2718 // Reset to the 'allocated' state to prevent any premature accessing to
2719 // a shared class at runtime while the class is still being loaded and
2720 // restored. A class' init_state is set to 'loaded' at runtime when it's
2721 // being added to class hierarchy (see InstanceKlass:::add_to_hierarchy()).
2722 _init_state = allocated;
2723
2724 { // Otherwise this needs to take out the Compile_lock.
2725 assert(SafepointSynchronize::is_at_safepoint(), "only called at safepoint");
2726 init_implementor();
2727 }
2746 _osr_nmethods_head = nullptr;
2747 #if INCLUDE_JVMTI
2748 _breakpoints = nullptr;
2749 _previous_versions = nullptr;
2750 _cached_class_file = nullptr;
2751 _jvmti_cached_class_field_map = nullptr;
2752 #endif
2753
2754 _init_thread = nullptr;
2755 _methods_jmethod_ids = nullptr;
2756 _jni_ids = nullptr;
2757 _oop_map_cache = nullptr;
2758 if (CDSConfig::is_dumping_invokedynamic() && HeapShared::is_lambda_proxy_klass(this)) {
2759 // keep _nest_host
2760 } else {
2761 // clear _nest_host to ensure re-load at runtime
2762 _nest_host = nullptr;
2763 }
2764 init_shared_package_entry();
2765 _dep_context_last_cleaned = 0;
2766 DEBUG_ONLY(_shared_class_load_count = 0);
2767
2768 remove_unshareable_flags();
2769 }
2770
2771 void InstanceKlass::remove_unshareable_flags() {
2772 // clear all the flags/stats that shouldn't be in the archived version
2773 assert(!is_scratch_class(), "must be");
2774 assert(!has_been_redefined(), "must be");
2775 #if INCLUDE_JVMTI
2776 set_is_being_redefined(false);
2777 #endif
2778 set_has_resolved_methods(false);
2779 }
2780
2781 void InstanceKlass::remove_java_mirror() {
2782 Klass::remove_java_mirror();
2783
2784 // do array classes also.
2785 if (array_klasses() != nullptr) {
2786 array_klasses()->remove_java_mirror();
2857
2858 // restore constant pool resolved references
2859 constants()->restore_unshareable_info(CHECK);
2860
2861 if (array_klasses() != nullptr) {
2862 // To get a consistent list of classes we need MultiArray_lock to ensure
2863 // array classes aren't observed while they are being restored.
2864 RecursiveLocker rl(MultiArray_lock, THREAD);
2865 assert(this == array_klasses()->bottom_klass(), "sanity");
2866 // Array classes have null protection domain.
2867 // --> see ArrayKlass::complete_create_array_klass()
2868 array_klasses()->restore_unshareable_info(class_loader_data(), Handle(), CHECK);
2869 }
2870
2871 // Initialize @ValueBased class annotation if not already set in the archived klass.
2872 if (DiagnoseSyncOnValueBasedClasses && has_value_based_class_annotation() && !is_value_based()) {
2873 set_is_value_based();
2874 }
2875 }
2876
2877 bool InstanceKlass::can_be_verified_at_dumptime() const {
2878 if (CDSConfig::preserve_all_dumptime_verification_states(this)) {
2879 return true;
2880 }
2881
2882 if (MetaspaceShared::is_in_shared_metaspace(this)) {
2883 // This is a class that was dumped into the base archive, so we know
2884 // it was verified at dump time.
2885 return true;
2886 }
2887
2888 // Check if a class or any of its supertypes has a version older than 50.
2889 // CDS will not perform verification of old classes during dump time because
2890 // without changing the old verifier, the verification constraint cannot be
2891 // retrieved during dump time.
2892 // Verification of archived old classes will be performed during run time.
2893 if (major_version() < 50 /*JAVA_6_VERSION*/) {
2894 return false;
2895 }
2896 if (java_super() != nullptr && !java_super()->can_be_verified_at_dumptime()) {
2897 return false;
2898 }
2899 Array<InstanceKlass*>* interfaces = local_interfaces();
2900 int len = interfaces->length();
2901 for (int i = 0; i < len; i++) {
2902 if (!interfaces->at(i)->can_be_verified_at_dumptime()) {
2903 return false;
2904 }
2905 }
2906 return true;
2907 }
2908
2909 int InstanceKlass::shared_class_loader_type() const {
2910 if (is_shared_boot_class()) {
2911 return ClassLoader::BOOT_LOADER;
2912 } else if (is_shared_platform_class()) {
2913 return ClassLoader::PLATFORM_LOADER;
2914 } else if (is_shared_app_class()) {
2915 return ClassLoader::APP_LOADER;
2916 } else {
2917 return ClassLoader::OTHER;
2918 }
2919 }
2920
2921 #endif // INCLUDE_CDS
2922
2923 #if INCLUDE_JVMTI
2924 static void clear_all_breakpoints(Method* m) {
2925 m->clear_all_breakpoints();
2926 }
2927 #endif
2928
2929 void InstanceKlass::unload_class(InstanceKlass* ik) {
2930
2931 if (ik->is_scratch_class()) {
2932 assert(ik->dependencies().is_empty(), "dependencies should be empty for scratch classes");
2933 return;
2934 }
2935 assert(ik->is_loaded(), "class should be loaded " PTR_FORMAT, p2i(ik));
2936
2937 // Release dependencies.
2938 ik->dependencies().remove_all_dependents();
2939
2940 // notify the debugger
3678 static void print_vtable(intptr_t* start, int len, outputStream* st) {
3679 for (int i = 0; i < len; i++) {
3680 intptr_t e = start[i];
3681 st->print("%d : " INTPTR_FORMAT, i, e);
3682 if (MetaspaceObj::is_valid((Metadata*)e)) {
3683 st->print(" ");
3684 ((Metadata*)e)->print_value_on(st);
3685 }
3686 st->cr();
3687 }
3688 }
3689
3690 static void print_vtable(vtableEntry* start, int len, outputStream* st) {
3691 return print_vtable(reinterpret_cast<intptr_t*>(start), len, st);
3692 }
3693
3694 const char* InstanceKlass::init_state_name() const {
3695 return state_names[init_state()];
3696 }
3697
3698 const char* InstanceKlass::state2name(ClassState s) {
3699 return state_names[s];
3700 }
3701
3702 void InstanceKlass::print_on(outputStream* st) const {
3703 assert(is_klass(), "must be klass");
3704 Klass::print_on(st);
3705
3706 st->print(BULLET"instance size: %d", size_helper()); st->cr();
3707 st->print(BULLET"klass size: %d", size()); st->cr();
3708 st->print(BULLET"access: "); access_flags().print_on(st); st->cr();
3709 st->print(BULLET"flags: "); _misc_flags.print_on(st); st->cr();
3710 st->print(BULLET"state: "); st->print_cr("%s", init_state_name());
3711 st->print(BULLET"name: "); name()->print_value_on(st); st->cr();
3712 st->print(BULLET"super: "); Metadata::print_value_on_maybe_null(st, super()); st->cr();
3713 st->print(BULLET"sub: ");
3714 Klass* sub = subklass();
3715 int n;
3716 for (n = 0; sub != nullptr; n++, sub = sub->next_sibling()) {
3717 if (n < MaxSubklassPrintSize) {
3718 sub->print_value_on(st);
3719 st->print(" ");
3720 }
3721 }
4011 nullptr;
4012 // caller can be null, for example, during a JVMTI VM_Init hook
4013 if (caller != nullptr) {
4014 info_stream.print(" source: instance of %s", caller->external_name());
4015 } else {
4016 // source is unknown
4017 }
4018 } else {
4019 oop class_loader = loader_data->class_loader();
4020 info_stream.print(" source: %s", class_loader->klass()->external_name());
4021 }
4022 } else {
4023 assert(this->is_shared(), "must be");
4024 if (MetaspaceShared::is_shared_dynamic((void*)this)) {
4025 info_stream.print(" source: shared objects file (top)");
4026 } else {
4027 info_stream.print(" source: shared objects file");
4028 }
4029 }
4030
4031 info_stream.print(" loader:");
4032 if (is_shared()) {
4033 info_stream.print(" %s", SystemDictionaryShared::class_loader_name_for_shared((Klass*)this));
4034 } else if (loader_data == ClassLoaderData::the_null_class_loader_data()) {
4035 info_stream.print(" boot_loader");
4036 } else {
4037 oop class_loader = loader_data->class_loader();
4038 if (class_loader != nullptr) {
4039 info_stream.print(" %s", class_loader->klass()->external_name());
4040 oop cl_name_and_id = java_lang_ClassLoader::nameAndId(class_loader);
4041 if (cl_name_and_id != nullptr) {
4042 info_stream.print(" %s", java_lang_String::as_utf8_string(cl_name_and_id));
4043 }
4044 } else {
4045 info_stream.print(" null");
4046 }
4047 }
4048 msg.info("%s", info_stream.as_string());
4049
4050 if (log_is_enabled(Debug, class, load)) {
4051 stringStream debug_stream;
4052
4053 // Class hierarchy info
4054 debug_stream.print(" klass: " PTR_FORMAT " super: " PTR_FORMAT,
4055 p2i(this), p2i(superklass()));
4056
4057 // Interfaces
4058 if (local_interfaces() != nullptr && local_interfaces()->length() > 0) {
4059 debug_stream.print(" interfaces:");
4060 int length = local_interfaces()->length();
4061 for (int i = 0; i < length; i++) {
4062 debug_stream.print(" " PTR_FORMAT,
4063 p2i(InstanceKlass::cast(local_interfaces()->at(i))));
4064 }
4065 }
4066
4067 // Class loader
|