|
29 | 29 | #include "classfile/classLoaderExt.hpp" |
30 | 30 | #include "classfile/javaClasses.inline.hpp" |
31 | 31 | #include "classfile/symbolTable.hpp" |
32 | | -#include "classfile/systemDictionaryShared.hpp" |
| 32 | +#include "classfile/systemDictionary.hpp" |
33 | 33 | #include "classfile/vmSymbols.hpp" |
34 | 34 | #include "memory/oopFactory.hpp" |
35 | 35 | #include "memory/resourceArea.hpp" |
|
39 | 39 | #include "runtime/javaCalls.hpp" |
40 | 40 | #include "services/threadService.hpp" |
41 | 41 |
|
| 42 | +InstanceKlass* UnregisteredClasses::_UnregisteredClassLoader_klass = nullptr; |
| 43 | + |
| 44 | +void UnregisteredClasses::initialize(TRAPS) { |
| 45 | + if (_UnregisteredClassLoader_klass == nullptr) { |
| 46 | + // no need for synchronization as this function is called single-threaded. |
| 47 | + Symbol* klass_name = SymbolTable::new_symbol("jdk/internal/misc/CDS$UnregisteredClassLoader"); |
| 48 | + Klass* k = SystemDictionary::resolve_or_fail(klass_name, true, CHECK); |
| 49 | + _UnregisteredClassLoader_klass = InstanceKlass::cast(k); |
| 50 | + } |
| 51 | +} |
| 52 | + |
42 | 53 | // Load the class of the given name from the location given by path. The path is specified by |
43 | 54 | // the "source:" in the class list file (see classListParser.cpp), and can be a directory or |
44 | 55 | // a JAR file. |
45 | | -InstanceKlass* UnregisteredClasses::load_class(Symbol* name, const char* path, TRAPS) { |
| 56 | +InstanceKlass* UnregisteredClasses::load_class(Symbol* name, const char* path, |
| 57 | + Handle super_class, objArrayHandle interfaces, TRAPS) { |
46 | 58 | assert(name != nullptr, "invariant"); |
47 | 59 | assert(DumpSharedSpaces, "this function is only used with -Xshare:dump"); |
48 | 60 |
|
49 | 61 | PerfClassTraceTime vmtimer(ClassLoader::perf_app_classload_time(), |
50 | 62 | THREAD->get_thread_stat()->perf_timers_addr(), |
51 | 63 | PerfClassTraceTime::CLASS_LOAD); |
52 | 64 |
|
| 65 | + // Call CDS$UnregisteredClassLoader::load(String name, Class<?> superClass, Class<?>[] interfaces) |
| 66 | + Symbol* methodName = SymbolTable::new_symbol("load"); |
| 67 | + Symbol* methodSignature = SymbolTable::new_symbol("(Ljava/lang/String;Ljava/lang/Class;[Ljava/lang/Class;)Ljava/lang/Class;"); |
53 | 68 | Symbol* path_symbol = SymbolTable::new_symbol(path); |
54 | | - Handle url_classloader = get_url_classloader(path_symbol, CHECK_NULL); |
| 69 | + Handle classloader = get_classloader(path_symbol, CHECK_NULL); |
55 | 70 | Handle ext_class_name = java_lang_String::externalize_classname(name, CHECK_NULL); |
56 | 71 |
|
57 | 72 | JavaValue result(T_OBJECT); |
58 | | - JavaCallArguments args(2); |
59 | | - args.set_receiver(url_classloader); |
| 73 | + JavaCallArguments args(3); |
| 74 | + args.set_receiver(classloader); |
60 | 75 | args.push_oop(ext_class_name); |
61 | | - args.push_int(JNI_FALSE); |
| 76 | + args.push_oop(super_class); |
| 77 | + args.push_oop(interfaces); |
62 | 78 | JavaCalls::call_virtual(&result, |
63 | | - vmClasses::URLClassLoader_klass(), |
64 | | - vmSymbols::loadClass_name(), |
65 | | - vmSymbols::string_boolean_class_signature(), |
| 79 | + UnregisteredClassLoader_klass(), |
| 80 | + methodName, |
| 81 | + methodSignature, |
66 | 82 | &args, |
67 | 83 | CHECK_NULL); |
68 | 84 | assert(result.get_type() == T_OBJECT, "just checking"); |
69 | 85 | oop obj = result.get_oop(); |
70 | 86 | return InstanceKlass::cast(java_lang_Class::as_Klass(obj)); |
71 | 87 | } |
72 | 88 |
|
73 | | -class URLClassLoaderTable : public ResourceHashtable< |
| 89 | +class UnregisteredClasses::ClassLoaderTable : public ResourceHashtable< |
74 | 90 | Symbol*, OopHandle, |
75 | 91 | 137, // prime number |
76 | 92 | AnyObj::C_HEAP> {}; |
77 | 93 |
|
78 | | -static URLClassLoaderTable* _url_classloader_table = nullptr; |
| 94 | +static UnregisteredClasses::ClassLoaderTable* _classloader_table = nullptr; |
79 | 95 |
|
80 | | -Handle UnregisteredClasses::create_url_classloader(Symbol* path, TRAPS) { |
| 96 | +Handle UnregisteredClasses::create_classloader(Symbol* path, TRAPS) { |
81 | 97 | ResourceMark rm(THREAD); |
82 | 98 | JavaValue result(T_OBJECT); |
83 | 99 | Handle path_string = java_lang_String::create_from_str(path->as_C_string(), CHECK_NH); |
84 | | - JavaCalls::call_static(&result, |
85 | | - vmClasses::jdk_internal_loader_ClassLoaders_klass(), |
86 | | - vmSymbols::toFileURL_name(), |
87 | | - vmSymbols::toFileURL_signature(), |
88 | | - path_string, CHECK_NH); |
89 | | - assert(result.get_type() == T_OBJECT, "just checking"); |
90 | | - oop url_h = result.get_oop(); |
91 | | - objArrayHandle urls = oopFactory::new_objArray_handle(vmClasses::URL_klass(), 1, CHECK_NH); |
92 | | - urls->obj_at_put(0, url_h); |
93 | | - |
94 | | - Handle url_classloader = JavaCalls::construct_new_instance( |
95 | | - vmClasses::URLClassLoader_klass(), |
96 | | - vmSymbols::url_array_classloader_void_signature(), |
97 | | - urls, Handle(), CHECK_NH); |
98 | | - return url_classloader; |
| 100 | + Handle classloader = JavaCalls::construct_new_instance( |
| 101 | + UnregisteredClassLoader_klass(), |
| 102 | + vmSymbols::string_void_signature(), |
| 103 | + path_string, CHECK_NH); |
| 104 | + return classloader; |
99 | 105 | } |
100 | 106 |
|
101 | | -Handle UnregisteredClasses::get_url_classloader(Symbol* path, TRAPS) { |
102 | | - if (_url_classloader_table == nullptr) { |
103 | | - _url_classloader_table = new (mtClass)URLClassLoaderTable(); |
| 107 | +Handle UnregisteredClasses::get_classloader(Symbol* path, TRAPS) { |
| 108 | + if (_classloader_table == nullptr) { |
| 109 | + _classloader_table = new (mtClass)ClassLoaderTable(); |
104 | 110 | } |
105 | | - OopHandle* url_classloader_ptr = _url_classloader_table->get(path); |
106 | | - if (url_classloader_ptr != nullptr) { |
107 | | - return Handle(THREAD, (*url_classloader_ptr).resolve()); |
| 111 | + OopHandle* classloader_ptr = _classloader_table->get(path); |
| 112 | + if (classloader_ptr != nullptr) { |
| 113 | + return Handle(THREAD, (*classloader_ptr).resolve()); |
108 | 114 | } else { |
109 | | - Handle url_classloader = create_url_classloader(path, CHECK_NH); |
110 | | - _url_classloader_table->put(path, OopHandle(Universe::vm_global(), url_classloader())); |
| 115 | + Handle classloader = create_classloader(path, CHECK_NH); |
| 116 | + _classloader_table->put(path, OopHandle(Universe::vm_global(), classloader())); |
111 | 117 | path->increment_refcount(); |
112 | | - return url_classloader; |
| 118 | + return classloader; |
113 | 119 | } |
114 | 120 | } |
0 commit comments