diff --git a/src/hotspot/share/classfile/classLoader.cpp b/src/hotspot/share/classfile/classLoader.cpp index c1b3535b444..b65816a32f8 100644 --- a/src/hotspot/share/classfile/classLoader.cpp +++ b/src/hotspot/share/classfile/classLoader.cpp @@ -500,7 +500,7 @@ void ClassLoader::trace_class_path(const char* msg, const char* name) { } } -void ClassLoader::setup_bootstrap_search_path(TRAPS) { +void ClassLoader::setup_bootstrap_search_path(Thread* current) { const char* sys_class_path = Arguments::get_sysclasspath(); assert(sys_class_path != NULL, "System boot class path must not be NULL"); if (PrintSharedArchiveAndExit) { @@ -509,19 +509,19 @@ void ClassLoader::setup_bootstrap_search_path(TRAPS) { } else { trace_class_path("bootstrap loader class path=", sys_class_path); } - setup_bootstrap_search_path_impl(sys_class_path, CHECK); + setup_bootstrap_search_path_impl(current, sys_class_path); } #if INCLUDE_CDS -void ClassLoader::setup_app_search_path(const char *class_path, TRAPS) { +void ClassLoader::setup_app_search_path(Thread* current, const char *class_path) { Arguments::assert_is_dumping_archive(); - ResourceMark rm; + ResourceMark rm(current); ClasspathStream cp_stream(class_path); while (cp_stream.has_next()) { const char* path = cp_stream.get_next(); - update_class_path_entry_list(path, false, false, false, CHECK); + update_class_path_entry_list(current, path, false, false, false); } } @@ -541,7 +541,7 @@ void ClassLoader::add_to_module_path_entries(const char* path, } // Add a module path to the _module_path_entries list. -void ClassLoader::setup_module_search_path(const char* path, TRAPS) { +void ClassLoader::setup_module_search_path(Thread* current, const char* path) { Arguments::assert_is_dumping_archive(); struct stat st; if (os::stat(path, &st) != 0) { @@ -551,14 +551,11 @@ void ClassLoader::setup_module_search_path(const char* path, TRAPS) { } // File or directory found ClassPathEntry* new_entry = NULL; - new_entry = create_class_path_entry(path, &st, true /* throw_exception */, - false /*is_boot_append */, false /* from_class_path_attr */, CHECK); - if (new_entry == NULL) { - return; + new_entry = create_class_path_entry(current, path, &st, + false /*is_boot_append */, false /* from_class_path_attr */); + if (new_entry != NULL) { + add_to_module_path_entries(path, new_entry); } - - add_to_module_path_entries(path, new_entry); - return; } #endif // INCLUDE_CDS @@ -595,7 +592,7 @@ void ClassLoader::setup_patch_mod_entries() { struct stat st; if (os::stat(path, &st) == 0) { // File or directory found - ClassPathEntry* new_entry = create_class_path_entry(path, &st, false, false, false, CHECK); + ClassPathEntry* new_entry = create_class_path_entry(THREAD, path, &st, false, false); // If the path specification is valid, enter it into this module's list if (new_entry != NULL) { module_cpl->add_to_list(new_entry); @@ -627,8 +624,8 @@ bool ClassLoader::is_in_patch_mod_entries(Symbol* module_name) { } // Set up the _jrt_entry if present and boot append path -void ClassLoader::setup_bootstrap_search_path_impl(const char *class_path, TRAPS) { - ResourceMark rm(THREAD); +void ClassLoader::setup_bootstrap_search_path_impl(Thread* current, const char *class_path) { + ResourceMark rm(current); ClasspathStream cp_stream(class_path); bool set_base_piece = true; @@ -652,7 +649,7 @@ void ClassLoader::setup_bootstrap_search_path_impl(const char *class_path, TRAPS struct stat st; if (os::stat(path, &st) == 0) { // Directory found - ClassPathEntry* new_entry = create_class_path_entry(path, &st, false, false, false, CHECK); + ClassPathEntry* new_entry = create_class_path_entry(current, path, &st, false, false); // Check for a jimage if (Arguments::has_jimage()) { @@ -669,19 +666,19 @@ void ClassLoader::setup_bootstrap_search_path_impl(const char *class_path, TRAPS } else { // Every entry on the system boot class path after the initial base piece, // which is set by os::set_boot_path(), is considered an appended entry. - update_class_path_entry_list(path, false, true, false, CHECK); + update_class_path_entry_list(current, path, false, true, false); } } } // During an exploded modules build, each module defined to the boot loader // will be added to the ClassLoader::_exploded_entries array. -void ClassLoader::add_to_exploded_build_list(Symbol* module_sym, TRAPS) { +void ClassLoader::add_to_exploded_build_list(Thread* current, Symbol* module_sym) { assert(!ClassLoader::has_jrt_entry(), "Exploded build not applicable"); assert(_exploded_entries != NULL, "_exploded_entries was not initialized"); // Find the module's symbol - ResourceMark rm(THREAD); + ResourceMark rm(current); const char *module_name = module_sym->as_C_string(); const char *home = Arguments::get_java_home(); const char file_sep = os::file_separator()[0]; @@ -693,7 +690,7 @@ void ClassLoader::add_to_exploded_build_list(Symbol* module_sym, TRAPS) { struct stat st; if (os::stat(path, &st) == 0) { // Directory found - ClassPathEntry* new_entry = create_class_path_entry(path, &st, false, false, false, CHECK); + ClassPathEntry* new_entry = create_class_path_entry(current, path, &st, false, false); // If the path specification is valid, enter it into this module's list. // There is no need to check for duplicate modules in the exploded entry list, @@ -703,7 +700,7 @@ void ClassLoader::add_to_exploded_build_list(Symbol* module_sym, TRAPS) { ModuleClassPathList* module_cpl = new ModuleClassPathList(module_sym); module_cpl->add_to_list(new_entry); { - MutexLocker ml(THREAD, Module_lock); + MutexLocker ml(current, Module_lock); _exploded_entries->push(module_cpl); } log_info(class, load)("path: %s", path); @@ -719,12 +716,11 @@ jzfile* ClassLoader::open_zip_file(const char* canonical_path, char** error_msg, return (*ZipOpen)(canonical_path, error_msg); } -ClassPathEntry* ClassLoader::create_class_path_entry(const char *path, const struct stat* st, - bool throw_exception, +ClassPathEntry* ClassLoader::create_class_path_entry(Thread* current, + const char *path, const struct stat* st, bool is_boot_append, - bool from_class_path_attr, - TRAPS) { - JavaThread* thread = THREAD->as_Java_thread(); + bool from_class_path_attr) { + JavaThread* thread = current->as_Java_thread(); ClassPathEntry* new_entry = NULL; if ((st->st_mode & S_IFMT) == S_IFREG) { ResourceMark rm(thread); @@ -732,12 +728,7 @@ ClassPathEntry* ClassLoader::create_class_path_entry(const char *path, const str // Canonicalized filename const char* canonical_path = get_canonical_path(path, thread); if (canonical_path == NULL) { - // This matches the classic VM - if (throw_exception) { - THROW_MSG_(vmSymbols::java_io_IOException(), "Bad pathname", NULL); - } else { - return NULL; - } + return NULL; } jint error; JImageFile* jimage =(*JImageOpen)(canonical_path, &error); @@ -749,21 +740,7 @@ ClassPathEntry* ClassLoader::create_class_path_entry(const char *path, const str if (zip != NULL && error_msg == NULL) { new_entry = new ClassPathZipEntry(zip, path, is_boot_append, from_class_path_attr); } else { - char *msg; - if (error_msg == NULL) { - msg = NEW_RESOURCE_ARRAY_IN_THREAD(thread, char, strlen(path) + 128); ; - jio_snprintf(msg, strlen(path) + 127, "error in opening JAR file %s", path); - } else { - int len = (int)(strlen(path) + strlen(error_msg) + 128); - msg = NEW_RESOURCE_ARRAY_IN_THREAD(thread, char, len); ; - jio_snprintf(msg, len - 1, "error in opening JAR file <%s> %s", error_msg, path); - } - // Don't complain about bad jar files added via -Xbootclasspath/a:. - if (throw_exception && is_init_completed()) { - THROW_MSG_(vmSymbols::java_lang_ClassNotFoundException(), msg, NULL); - } else { - return NULL; - } + return NULL; } } log_info(class, path)("opened: %s", path); @@ -834,10 +811,10 @@ void ClassLoader::add_to_boot_append_entries(ClassPathEntry *new_entry) { // Note that at dump time, ClassLoader::_app_classpath_entries are NOT used for // loading app classes. Instead, the app class are loaded by the // jdk/internal/loader/ClassLoaders$AppClassLoader instance. -void ClassLoader::add_to_app_classpath_entries(const char* path, +void ClassLoader::add_to_app_classpath_entries(Thread* current, + const char* path, ClassPathEntry* entry, - bool check_for_duplicates, - TRAPS) { + bool check_for_duplicates) { #if INCLUDE_CDS assert(entry != NULL, "ClassPathEntry should not be NULL"); ClassPathEntry* e = _app_classpath_entries; @@ -861,22 +838,22 @@ void ClassLoader::add_to_app_classpath_entries(const char* path, } if (entry->is_jar_file()) { - ClassLoaderExt::process_jar_manifest(entry, check_for_duplicates, CHECK); + ClassLoaderExt::process_jar_manifest(current, entry, check_for_duplicates); } #endif } // Returns true IFF the file/dir exists and the entry was successfully created. -bool ClassLoader::update_class_path_entry_list(const char *path, +bool ClassLoader::update_class_path_entry_list(Thread* current, + const char *path, bool check_for_duplicates, bool is_boot_append, - bool from_class_path_attr, - TRAPS) { + bool from_class_path_attr) { struct stat st; if (os::stat(path, &st) == 0) { // File or directory found ClassPathEntry* new_entry = NULL; - new_entry = create_class_path_entry(path, &st, /*throw_exception=*/true, is_boot_append, from_class_path_attr, CHECK_false); + new_entry = create_class_path_entry(current, path, &st, is_boot_append, from_class_path_attr); if (new_entry == NULL) { return false; } @@ -886,7 +863,7 @@ bool ClassLoader::update_class_path_entry_list(const char *path, if (is_boot_append) { add_to_boot_append_entries(new_entry); } else { - add_to_app_classpath_entries(path, new_entry, check_for_duplicates, CHECK_false); + add_to_app_classpath_entries(current, path, new_entry, check_for_duplicates); } return true; } else { @@ -1116,10 +1093,10 @@ ClassPathEntry* find_first_module_cpe(ModuleEntry* mod_entry, // Search either the patch-module or exploded build entries for class. -ClassFileStream* ClassLoader::search_module_entries(const GrowableArray* const module_list, +ClassFileStream* ClassLoader::search_module_entries(Thread* current, + const GrowableArray* const module_list, const char* const class_name, - const char* const file_name, - TRAPS) { + const char* const file_name) { ClassFileStream* stream = NULL; // Find the class' defining module in the boot loader's module entry table @@ -1146,7 +1123,7 @@ ClassFileStream* ClassLoader::search_module_entries(const GrowableArrayopen_stream(THREAD, file_name); + stream = e->open_stream(current, file_name); // No context.check is required since CDS is not supported // for an exploded modules build or if --patch-module is specified. if (NULL != stream) { @@ -1218,7 +1195,7 @@ InstanceKlass* ClassLoader::load_class(Symbol* name, bool search_append_only, TR // is not supported with UseSharedSpaces, it is not supported with DynamicDumpSharedSpaces. assert(!DynamicDumpSharedSpaces, "sanity"); if (!DumpSharedSpaces) { - stream = search_module_entries(_patch_mod_entries, class_name, file_name, CHECK_NULL); + stream = search_module_entries(THREAD, _patch_mod_entries, class_name, file_name); } } @@ -1230,7 +1207,7 @@ InstanceKlass* ClassLoader::load_class(Symbol* name, bool search_append_only, TR } else { // Exploded build - attempt to locate class in its defining module's location. assert(_exploded_entries != NULL, "No exploded build entries present"); - stream = search_module_entries(_exploded_entries, class_name, file_name, CHECK_NULL); + stream = search_module_entries(THREAD, _exploded_entries, class_name, file_name); } } @@ -1441,7 +1418,7 @@ void ClassLoader::initialize(TRAPS) { // lookup java library entry points load_java_library(); // jimage library entry points are loaded below, in lookup_vm_options - setup_bootstrap_search_path(CHECK); + setup_bootstrap_search_path(THREAD); } char* lookup_vm_resource(JImageFile *jimage, const char *jimage_version, const char *path) { @@ -1478,15 +1455,15 @@ char* ClassLoader::lookup_vm_options() { } #if INCLUDE_CDS -void ClassLoader::initialize_shared_path(TRAPS) { +void ClassLoader::initialize_shared_path(Thread* current) { if (Arguments::is_dumping_archive()) { - ClassLoaderExt::setup_search_paths(CHECK); + ClassLoaderExt::setup_search_paths(current); } } void ClassLoader::initialize_module_path(TRAPS) { if (Arguments::is_dumping_archive()) { - ClassLoaderExt::setup_module_paths(CHECK); + ClassLoaderExt::setup_module_paths(THREAD); FileMapInfo::allocate_shared_path_table(CHECK); } } @@ -1551,7 +1528,7 @@ void classLoader_init1() { } // Complete the ClassPathEntry setup for the boot loader -void ClassLoader::classLoader_init2(TRAPS) { +void ClassLoader::classLoader_init2(Thread* current) { // Setup the list of module/path pairs for --patch-module processing // This must be done after the SymbolTable is created in order // to use fast_compare on module names instead of a string compare. @@ -1576,7 +1553,7 @@ void ClassLoader::classLoader_init2(TRAPS) { assert(_exploded_entries == NULL, "Should only get initialized once"); _exploded_entries = new (ResourceObj::C_HEAP, mtModule) GrowableArray(EXPLODED_ENTRY_SIZE, mtModule); - add_to_exploded_build_list(vmSymbols::java_base(), CHECK); + add_to_exploded_build_list(current, vmSymbols::java_base()); } } diff --git a/src/hotspot/share/classfile/classLoader.hpp b/src/hotspot/share/classfile/classLoader.hpp index e8789e88b6d..79cdfc1e11e 100644 --- a/src/hotspot/share/classfile/classLoader.hpp +++ b/src/hotspot/share/classfile/classLoader.hpp @@ -222,12 +222,12 @@ class ClassLoader: AllStatic { CDS_ONLY(static ClassPathEntry* _last_app_classpath_entry;) CDS_ONLY(static ClassPathEntry* _module_path_entries;) CDS_ONLY(static ClassPathEntry* _last_module_path_entry;) - CDS_ONLY(static void setup_app_search_path(const char* class_path, TRAPS);) - CDS_ONLY(static void setup_module_search_path(const char* path, TRAPS);) - static void add_to_app_classpath_entries(const char* path, + CDS_ONLY(static void setup_app_search_path(Thread* current, const char* class_path);) + CDS_ONLY(static void setup_module_search_path(Thread* current, const char* path);) + static void add_to_app_classpath_entries(Thread* current, + const char* path, ClassPathEntry* entry, - bool check_for_duplicates, - TRAPS); + bool check_for_duplicates); CDS_ONLY(static void add_to_module_path_entries(const char* path, ClassPathEntry* entry);) public: @@ -241,8 +241,8 @@ class ClassLoader: AllStatic { // - setup the boot loader's system class path // - setup the boot loader's patch mod entries, if present // - create the ModuleEntry for java.base - static void setup_bootstrap_search_path(TRAPS); - static void setup_bootstrap_search_path_impl(const char *class_path, TRAPS); + static void setup_bootstrap_search_path(Thread* current); + static void setup_bootstrap_search_path_impl(Thread* current, const char *class_path); static void setup_patch_mod_entries(); static void create_javabase(); @@ -258,10 +258,10 @@ class ClassLoader: AllStatic { static jzfile* open_zip_file(const char* canonical_path, char** error_msg, JavaThread* thread); public: - static ClassPathEntry* create_class_path_entry(const char *path, const struct stat* st, - bool throw_exception, + static ClassPathEntry* create_class_path_entry(Thread* current, + const char *path, const struct stat* st, bool is_boot_append, - bool from_class_path_attr, TRAPS); + bool from_class_path_attr); // Canonicalizes path names, so strcmp will work properly. This is mainly // to avoid confusing the zip library @@ -270,11 +270,11 @@ class ClassLoader: AllStatic { int class_name_len); static PackageEntry* get_package_entry(Symbol* pkg_name, ClassLoaderData* loader_data); static int crc32(int crc, const char* buf, int len); - static bool update_class_path_entry_list(const char *path, + static bool update_class_path_entry_list(Thread* current, + const char *path, bool check_for_duplicates, bool is_boot_append, - bool from_class_path_attr, - TRAPS); + bool from_class_path_attr); static void print_bootclasspath(); // Timing @@ -311,12 +311,13 @@ class ClassLoader: AllStatic { static void close_jrt_image(); // Add a module's exploded directory to the boot loader's exploded module build list - static void add_to_exploded_build_list(Symbol* module_name, TRAPS); + static void add_to_exploded_build_list(Thread* current, Symbol* module_name); // Attempt load of individual class from either the patched or exploded modules build lists - static ClassFileStream* search_module_entries(const GrowableArray* const module_list, + static ClassFileStream* search_module_entries(Thread* current, + const GrowableArray* const module_list, const char* const class_name, - const char* const file_name, TRAPS); + const char* const file_name); // Load individual .class file static InstanceKlass* load_class(Symbol* class_name, bool search_append_only, TRAPS); @@ -337,8 +338,8 @@ class ClassLoader: AllStatic { // Initialization static void initialize(TRAPS); - static void classLoader_init2(TRAPS); - CDS_ONLY(static void initialize_shared_path(TRAPS);) + static void classLoader_init2(Thread* current); + CDS_ONLY(static void initialize_shared_path(Thread* current);) CDS_ONLY(static void initialize_module_path(TRAPS);) static int compute_Object_vtable(); diff --git a/src/hotspot/share/classfile/classLoaderExt.cpp b/src/hotspot/share/classfile/classLoaderExt.cpp index ae18db28f0f..c281e254de6 100644 --- a/src/hotspot/share/classfile/classLoaderExt.cpp +++ b/src/hotspot/share/classfile/classLoaderExt.cpp @@ -65,7 +65,7 @@ void ClassLoaderExt::append_boot_classpath(ClassPathEntry* new_entry) { ClassLoader::add_to_boot_append_entries(new_entry); } -void ClassLoaderExt::setup_app_search_path(TRAPS) { +void ClassLoaderExt::setup_app_search_path(Thread* current) { Arguments::assert_is_dumping_archive(); _app_class_paths_start_index = ClassLoader::num_boot_classpath_entries(); char* app_class_path = os::strdup(Arguments::get_appclasspath()); @@ -77,30 +77,30 @@ void ClassLoaderExt::setup_app_search_path(TRAPS) { trace_class_path("app loader class path (skipped)=", app_class_path); } else { trace_class_path("app loader class path=", app_class_path); - ClassLoader::setup_app_search_path(app_class_path, CHECK); + ClassLoader::setup_app_search_path(current, app_class_path); } } -void ClassLoaderExt::process_module_table(ModuleEntryTable* met, TRAPS) { - ResourceMark rm(THREAD); +void ClassLoaderExt::process_module_table(Thread* current, ModuleEntryTable* met) { + ResourceMark rm(current); for (int i = 0; i < met->table_size(); i++) { for (ModuleEntry* m = met->bucket(i); m != NULL;) { char* path = m->location()->as_C_string(); if (strncmp(path, "file:", 5) == 0) { path = ClassLoader::skip_uri_protocol(path); - ClassLoader::setup_module_search_path(path, CHECK); + ClassLoader::setup_module_search_path(current, path); } m = m->next(); } } } -void ClassLoaderExt::setup_module_paths(TRAPS) { +void ClassLoaderExt::setup_module_paths(Thread* current) { Arguments::assert_is_dumping_archive(); _app_module_paths_start_index = ClassLoader::num_boot_classpath_entries() + ClassLoader::num_app_classpath_entries(); - Handle system_class_loader (THREAD, SystemDictionary::java_system_loader()); + Handle system_class_loader (current, SystemDictionary::java_system_loader()); ModuleEntryTable* met = Modules::get_module_entry_table(system_class_loader); - process_module_table(met, CHECK); + process_module_table(current, met); } char* ClassLoaderExt::read_manifest(Thread* current, ClassPathEntry* entry, jint *manifest_size, bool clean_text) { @@ -163,11 +163,11 @@ char* ClassLoaderExt::get_class_path_attr(const char* jar_path, char* manifest, return found; } -void ClassLoaderExt::process_jar_manifest(ClassPathEntry* entry, - bool check_for_duplicates, TRAPS) { - ResourceMark rm(THREAD); +void ClassLoaderExt::process_jar_manifest(Thread* current, ClassPathEntry* entry, + bool check_for_duplicates) { + ResourceMark rm(current); jint manifest_size; - char* manifest = read_manifest(THREAD, entry, &manifest_size); + char* manifest = read_manifest(current, entry, &manifest_size); if (manifest == NULL) { return; @@ -207,13 +207,12 @@ void ClassLoaderExt::process_jar_manifest(ClassPathEntry* entry, size_t name_len = strlen(file_start); if (name_len > 0) { - ResourceMark rm(THREAD); + ResourceMark rm(current); size_t libname_len = dir_len + name_len; char* libname = NEW_RESOURCE_ARRAY(char, libname_len + 1); int n = os::snprintf(libname, libname_len + 1, "%.*s%s", dir_len, dir_name, file_start); assert((size_t)n == libname_len, "Unexpected number of characters in string"); - bool status = ClassLoader::update_class_path_entry_list(libname, true, false, true /* from_class_path_attr */, CHECK); - if (status) { + if (ClassLoader::update_class_path_entry_list(current, libname, true, false, true /* from_class_path_attr */)) { trace_class_path("library = ", libname); } else { trace_class_path("library (non-existent) = ", libname); @@ -226,8 +225,8 @@ void ClassLoaderExt::process_jar_manifest(ClassPathEntry* entry, } } -void ClassLoaderExt::setup_search_paths(TRAPS) { - ClassLoaderExt::setup_app_search_path(CHECK); +void ClassLoaderExt::setup_search_paths(Thread* current) { + ClassLoaderExt::setup_app_search_path(current); } void ClassLoaderExt::record_result(const s2 classpath_index, InstanceKlass* result) { @@ -327,10 +326,7 @@ ClassPathEntry* ClassLoaderExt::find_classpath_entry_from_cache(Thread* current, } ClassPathEntry* new_entry = NULL; - ExceptionMark em(current); - Thread* THREAD = current; // For exception macros. - new_entry = create_class_path_entry(path, &st, /*throw_exception=*/false, - false, false, CATCH); // will never throw + new_entry = create_class_path_entry(current, path, &st, false, false); if (new_entry == NULL) { return NULL; } diff --git a/src/hotspot/share/classfile/classLoaderExt.hpp b/src/hotspot/share/classfile/classLoaderExt.hpp index fc92802b25e..4e827ea2a9a 100644 --- a/src/hotspot/share/classfile/classLoaderExt.hpp +++ b/src/hotspot/share/classfile/classLoaderExt.hpp @@ -45,8 +45,8 @@ private: }; static char* get_class_path_attr(const char* jar_path, char* manifest, jint manifest_size); - static void setup_app_search_path(TRAPS); // Only when -Xshare:dump - static void process_module_table(ModuleEntryTable* met, TRAPS); + static void setup_app_search_path(Thread* current); // Only when -Xshare:dump + static void process_module_table(Thread* current, ModuleEntryTable* met); // index of first app JAR in shared classpath entry table static jshort _app_class_paths_start_index; // index of first modular JAR in shared modulepath entry table @@ -61,13 +61,13 @@ private: static ClassPathEntry* find_classpath_entry_from_cache(Thread* current, const char* path); public: - static void process_jar_manifest(ClassPathEntry* entry, bool check_for_duplicates, TRAPS); + static void process_jar_manifest(Thread* current, ClassPathEntry* entry, bool check_for_duplicates); // Called by JVMTI code to add boot classpath static void append_boot_classpath(ClassPathEntry* new_entry); - static void setup_search_paths(TRAPS); - static void setup_module_paths(TRAPS); + static void setup_search_paths(Thread* current); + static void setup_module_paths(Thread* current); static char* read_manifest(Thread* current, ClassPathEntry* entry, jint *manifest_size) { // Remove all the new-line continuations (which wrap long lines at 72 characters, see diff --git a/src/hotspot/share/classfile/modules.cpp b/src/hotspot/share/classfile/modules.cpp index f5b5fe8ada5..c49bc5d9a8d 100644 --- a/src/hotspot/share/classfile/modules.cpp +++ b/src/hotspot/share/classfile/modules.cpp @@ -451,7 +451,7 @@ void Modules::define_module(Handle module, jboolean is_open, jstring version, // If the module is defined to the boot loader and an exploded build is being // used, prepend /modules/modules_name to the system boot class path. if (h_loader.is_null() && !ClassLoader::has_jrt_entry()) { - ClassLoader::add_to_exploded_build_list(module_symbol, CHECK); + ClassLoader::add_to_exploded_build_list(THREAD, module_symbol); } #ifdef COMPILER2 diff --git a/src/hotspot/share/classfile/vmClasses.cpp b/src/hotspot/share/classfile/vmClasses.cpp index ff7b8f755a0..aeb4b2e9977 100644 --- a/src/hotspot/share/classfile/vmClasses.cpp +++ b/src/hotspot/share/classfile/vmClasses.cpp @@ -117,7 +117,7 @@ void vmClasses::resolve_all(TRAPS) { // Create the ModuleEntry for java.base. This call needs to be done here, // after vmSymbols::initialize() is called but before any classes are pre-loaded. - ClassLoader::classLoader_init2(CHECK); + ClassLoader::classLoader_init2(THREAD); // Preload commonly used klasses vmClassID scan = vmClassID::FIRST; diff --git a/src/hotspot/share/memory/filemap.cpp b/src/hotspot/share/memory/filemap.cpp index 2c520909ef0..9b08f93d5b2 100644 --- a/src/hotspot/share/memory/filemap.cpp +++ b/src/hotspot/share/memory/filemap.cpp @@ -2336,11 +2336,16 @@ ClassPathEntry* FileMapInfo::get_classpath_entry_for_jvmti(int i, TRAPS) { const char* path = scpe->name(); struct stat st; if (os::stat(path, &st) != 0) { - char *msg = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, strlen(path) + 128); ; - jio_snprintf(msg, strlen(path) + 127, "error in opening JAR file %s", path); + char *msg = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, strlen(path) + 128); + jio_snprintf(msg, strlen(path) + 127, "error in finding JAR file %s", path); THROW_MSG_(vmSymbols::java_io_IOException(), msg, NULL); } else { - ent = ClassLoader::create_class_path_entry(path, &st, /*throw_exception=*/true, false, false, CHECK_NULL); + ent = ClassLoader::create_class_path_entry(THREAD, path, &st, false, false); + if (ent == NULL) { + char *msg = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, strlen(path) + 128); + jio_snprintf(msg, strlen(path) + 127, "error in opening JAR file %s", path); + THROW_MSG_(vmSymbols::java_io_IOException(), msg, NULL); + } } } diff --git a/src/hotspot/share/memory/metaspaceShared.cpp b/src/hotspot/share/memory/metaspaceShared.cpp index 30f2c5ad44a..af3289a78fc 100644 --- a/src/hotspot/share/memory/metaspaceShared.cpp +++ b/src/hotspot/share/memory/metaspaceShared.cpp @@ -602,12 +602,7 @@ void MetaspaceShared::prepare_for_dumping() { Arguments::assert_is_dumping_archive(); Arguments::check_unsupported_dumping_properties(); - EXCEPTION_MARK; - ClassLoader::initialize_shared_path(THREAD); - if (HAS_PENDING_EXCEPTION) { - java_lang_Throwable::print(PENDING_EXCEPTION, tty); - vm_exit_during_initialization("ClassLoader::initialize_shared_path() failed unexpectedly"); - } + ClassLoader::initialize_shared_path(Thread::current()); } // Preload classes from a list, populate the shared spaces and dump to a