diff --git a/src/hotspot/share/classfile/systemDictionary.cpp b/src/hotspot/share/classfile/systemDictionary.cpp index 133d88c9326..8db26511494 100644 --- a/src/hotspot/share/classfile/systemDictionary.cpp +++ b/src/hotspot/share/classfile/systemDictionary.cpp @@ -956,19 +956,6 @@ InstanceKlass* SystemDictionary::resolve_from_stream(ClassFileStream* st, #if INCLUDE_CDS -// Load a class for boot loader from the shared spaces. This also -// forces the superclass and all interfaces to be loaded. -InstanceKlass* SystemDictionary::load_shared_boot_class(Symbol* class_name, - PackageEntry* pkg_entry, - TRAPS) { - assert(UseSharedSpaces, "Sanity check"); - InstanceKlass* ik = SystemDictionaryShared::find_builtin_class(class_name); - if (ik != NULL && ik->is_shared_boot_class()) { - return load_shared_class(ik, Handle(), Handle(), NULL, pkg_entry, THREAD); - } - return NULL; -} - // Check if a shared class can be loaded by the specific classloader. bool SystemDictionary::is_shared_class_visible(Symbol* class_name, InstanceKlass* ik, @@ -1289,7 +1276,11 @@ InstanceKlass* SystemDictionary::load_instance_class_impl(Symbol* class_name, Ha if (UseSharedSpaces) { PerfTraceTime vmtimer(ClassLoader::perf_shared_classload_time()); - k = load_shared_boot_class(class_name, pkg_entry, THREAD); + InstanceKlass* ik = SystemDictionaryShared::find_builtin_class(class_name); + if (ik != NULL && ik->is_shared_boot_class() && !ik->shared_loading_failed()) { + SharedClassLoadingMark slm(THREAD, ik); + k = load_shared_class(ik, class_loader, Handle(), NULL, pkg_entry, CHECK_NULL); + } } #endif @@ -1301,6 +1292,7 @@ InstanceKlass* SystemDictionary::load_instance_class_impl(Symbol* class_name, Ha // find_or_define_instance_class may return a different InstanceKlass if (k != NULL) { + CDS_ONLY(SharedClassLoadingMark slm(THREAD, k);) k = find_or_define_instance_class(class_name, class_loader, k, CHECK_NULL); } return k; diff --git a/src/hotspot/share/classfile/systemDictionary.hpp b/src/hotspot/share/classfile/systemDictionary.hpp index e8c99cb79c6..f4d40685ddc 100644 --- a/src/hotspot/share/classfile/systemDictionary.hpp +++ b/src/hotspot/share/classfile/systemDictionary.hpp @@ -376,9 +376,6 @@ protected: const ClassFileStream *cfs, PackageEntry* pkg_entry, TRAPS); - static InstanceKlass* load_shared_boot_class(Symbol* class_name, - PackageEntry* pkg_entry, - TRAPS); static Handle get_loader_lock_or_null(Handle class_loader); static InstanceKlass* find_or_define_instance_class(Symbol* class_name, Handle class_loader, diff --git a/src/hotspot/share/classfile/systemDictionaryShared.cpp b/src/hotspot/share/classfile/systemDictionaryShared.cpp index 0b25b1bb137..019db1d88c3 100644 --- a/src/hotspot/share/classfile/systemDictionaryShared.cpp +++ b/src/hotspot/share/classfile/systemDictionaryShared.cpp @@ -1018,6 +1018,7 @@ InstanceKlass* SystemDictionaryShared::find_or_load_shared_class( k = load_shared_class_for_builtin_loader(name, class_loader, THREAD); if (k != NULL) { + SharedClassLoadingMark slm(THREAD, k); k = find_or_define_instance_class(name, class_loader, k, CHECK_NULL); } } @@ -1047,11 +1048,10 @@ InstanceKlass* SystemDictionaryShared::load_shared_class_for_builtin_loader( assert(UseSharedSpaces, "must be"); InstanceKlass* ik = find_builtin_class(class_name); - if (ik != NULL) { - if ((ik->is_shared_app_class() && - SystemDictionary::is_system_class_loader(class_loader())) || - (ik->is_shared_platform_class() && - SystemDictionary::is_platform_class_loader(class_loader()))) { + if (ik != NULL && !ik->shared_loading_failed()) { + if ((SystemDictionary::is_system_class_loader(class_loader()) && ik->is_shared_app_class()) || + (SystemDictionary::is_platform_class_loader(class_loader()) && ik->is_shared_platform_class())) { + SharedClassLoadingMark slm(THREAD, ik); PackageEntry* pkg_entry = get_package_entry_from_class(ik, class_loader); Handle protection_domain = SystemDictionaryShared::init_security_info(class_loader, ik, pkg_entry, CHECK_NULL); diff --git a/src/hotspot/share/classfile/systemDictionaryShared.hpp b/src/hotspot/share/classfile/systemDictionaryShared.hpp index 227d69304cf..42474bbe3d3 100644 --- a/src/hotspot/share/classfile/systemDictionaryShared.hpp +++ b/src/hotspot/share/classfile/systemDictionaryShared.hpp @@ -112,6 +112,23 @@ class LambdaProxyClassDictionary; class RunTimeSharedClassInfo; class RunTimeSharedDictionary; +class SharedClassLoadingMark { + private: + Thread* THREAD; + InstanceKlass* _klass; + public: + SharedClassLoadingMark(Thread* current, InstanceKlass* ik) : THREAD(current), _klass(ik) {} + ~SharedClassLoadingMark() { + assert(THREAD != NULL, "Current thread is NULL"); + assert(_klass != NULL, "InstanceKlass is NULL"); + if (HAS_PENDING_EXCEPTION) { + if (_klass->is_shared()) { + _klass->set_shared_loading_failed(); + } + } + } +}; + class SystemDictionaryShared: public SystemDictionary { friend class ExcludeDumpTimeSharedClasses; public: diff --git a/src/hotspot/share/oops/instanceKlass.cpp b/src/hotspot/share/oops/instanceKlass.cpp index 838ec33f818..4a6c81ab840 100644 --- a/src/hotspot/share/oops/instanceKlass.cpp +++ b/src/hotspot/share/oops/instanceKlass.cpp @@ -2496,6 +2496,7 @@ void InstanceKlass::restore_unshareable_info(ClassLoaderData* loader_data, Handl // before the InstanceKlass is added to the SystemDictionary. Make // sure the current state is