8160121: [JVMCI] JvmciNotifyBootstrapFinishedEventTest.java failed NoClassDefFoundError: jdk/vm/ci/runtime/JVMCI
Reviewed-by: kvn
This commit is contained in:
parent
490625cd8b
commit
b4aef2060b
@ -551,17 +551,6 @@ void CompileBroker::compilation_init(TRAPS) {
|
|||||||
} else {
|
} else {
|
||||||
c1_count = JVMCIHostThreads;
|
c1_count = JVMCIHostThreads;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!UseInterpreter || !BackgroundCompilation) {
|
|
||||||
// Force initialization of JVMCI compiler otherwise JVMCI
|
|
||||||
// compilations will not block until JVMCI is initialized
|
|
||||||
ResourceMark rm;
|
|
||||||
TempNewSymbol getCompiler = SymbolTable::new_symbol("getCompiler", CHECK);
|
|
||||||
TempNewSymbol sig = SymbolTable::new_symbol("()Ljdk/vm/ci/runtime/JVMCICompiler;", CHECK);
|
|
||||||
Handle jvmciRuntime = JVMCIRuntime::get_HotSpotJVMCIRuntime(CHECK);
|
|
||||||
JavaValue result(T_OBJECT);
|
|
||||||
JavaCalls::call_virtual(&result, jvmciRuntime, HotSpotJVMCIRuntime::klass(), getCompiler, sig, CHECK);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif // INCLUDE_JVMCI
|
#endif // INCLUDE_JVMCI
|
||||||
|
@ -612,6 +612,17 @@ JRT_ENTRY(jint, JVMCIRuntime::test_deoptimize_call_int(JavaThread* thread, int v
|
|||||||
return value;
|
return value;
|
||||||
JRT_END
|
JRT_END
|
||||||
|
|
||||||
|
void JVMCIRuntime::force_initialization(TRAPS) {
|
||||||
|
JVMCIRuntime::initialize_well_known_classes(CHECK);
|
||||||
|
|
||||||
|
ResourceMark rm;
|
||||||
|
TempNewSymbol getCompiler = SymbolTable::new_symbol("getCompiler", CHECK);
|
||||||
|
TempNewSymbol sig = SymbolTable::new_symbol("()Ljdk/vm/ci/runtime/JVMCICompiler;", CHECK);
|
||||||
|
Handle jvmciRuntime = JVMCIRuntime::get_HotSpotJVMCIRuntime(CHECK);
|
||||||
|
JavaValue result(T_OBJECT);
|
||||||
|
JavaCalls::call_virtual(&result, jvmciRuntime, HotSpotJVMCIRuntime::klass(), getCompiler, sig, CHECK);
|
||||||
|
}
|
||||||
|
|
||||||
// private static JVMCIRuntime JVMCI.initializeRuntime()
|
// private static JVMCIRuntime JVMCI.initializeRuntime()
|
||||||
JVM_ENTRY(jobject, JVM_GetJVMCIRuntime(JNIEnv *env, jclass c))
|
JVM_ENTRY(jobject, JVM_GetJVMCIRuntime(JNIEnv *env, jclass c))
|
||||||
if (!EnableJVMCI) {
|
if (!EnableJVMCI) {
|
||||||
|
@ -157,6 +157,9 @@ class JVMCIRuntime: public AllStatic {
|
|||||||
static void throw_klass_external_name_exception(JavaThread* thread, const char* exception, Klass* klass);
|
static void throw_klass_external_name_exception(JavaThread* thread, const char* exception, Klass* klass);
|
||||||
static void throw_class_cast_exception(JavaThread* thread, const char* exception, Klass* caster_klass, Klass* target_klass);
|
static void throw_class_cast_exception(JavaThread* thread, const char* exception, Klass* caster_klass, Klass* target_klass);
|
||||||
|
|
||||||
|
// Forces initialization of the JVMCI runtime.
|
||||||
|
static void force_initialization(TRAPS);
|
||||||
|
|
||||||
// Test only function
|
// Test only function
|
||||||
static int test_deoptimize_call_int(JavaThread* thread, int value);
|
static int test_deoptimize_call_int(JavaThread* thread, int value);
|
||||||
};
|
};
|
||||||
|
@ -238,10 +238,15 @@ void SimpleThresholdPolicy::compile(const methodHandle& mh, int bci, CompLevel l
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if INCLUDE_JVMCI
|
#if INCLUDE_JVMCI
|
||||||
// We can't compile with a JVMCI compiler until the module system is initialized.
|
// We can't compile with a JVMCI compiler until the module system is initialized past
|
||||||
if (level == CompLevel_full_optimization && UseJVMCICompiler && !Universe::is_module_initialized()) {
|
// phase 3. The JVMCI API itself isn't available until phase 2 and ServiceLoader isn't
|
||||||
|
// usable until after phase 3.
|
||||||
|
if (level == CompLevel_full_optimization && EnableJVMCI && UseJVMCICompiler) {
|
||||||
|
if (SystemDictionary::java_system_loader() == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
assert(Universe::is_module_initialized(), "must be");
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Check if the method can be compiled. If it cannot be compiled with C1, continue profiling
|
// Check if the method can be compiled. If it cannot be compiled with C1, continue profiling
|
||||||
|
@ -3770,6 +3770,13 @@ jint Threads::create_vm(JavaVMInitArgs* args, bool* canTryAgain) {
|
|||||||
// Final system initialization including security manager and system class loader
|
// Final system initialization including security manager and system class loader
|
||||||
call_initPhase3(CHECK_JNI_ERR);
|
call_initPhase3(CHECK_JNI_ERR);
|
||||||
|
|
||||||
|
#if INCLUDE_JVMCI
|
||||||
|
if (EnableJVMCI && UseJVMCICompiler && (!UseInterpreter || !BackgroundCompilation)) {
|
||||||
|
// 8145270: Force initialization of JVMCI runtime otherwise requests for blocking
|
||||||
|
// compilations via JVMCI will not actually block until JVMCI is initialized.
|
||||||
|
JVMCIRuntime::force_initialization(CHECK_JNI_ERR);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
// cache the system class loader
|
// cache the system class loader
|
||||||
SystemDictionary::compute_java_system_loader(CHECK_(JNI_ERR));
|
SystemDictionary::compute_java_system_loader(CHECK_(JNI_ERR));
|
||||||
|
|
||||||
|
@ -43,6 +43,8 @@
|
|||||||
* @run main ClassFileInstaller
|
* @run main ClassFileInstaller
|
||||||
* compiler.jvmci.common.JVMCIHelpers$EmptyHotspotCompiler
|
* compiler.jvmci.common.JVMCIHelpers$EmptyHotspotCompiler
|
||||||
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilerFactory
|
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilerFactory
|
||||||
|
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilationRequestResult
|
||||||
|
* compiler.jvmci.common.JVMCIHelpers$EmptyVMEventListener
|
||||||
* compiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest
|
* compiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest
|
||||||
* jdk.test.lib.Asserts
|
* jdk.test.lib.Asserts
|
||||||
* jdk.test.lib.Utils
|
* jdk.test.lib.Utils
|
||||||
|
@ -44,6 +44,8 @@
|
|||||||
* @run main ClassFileInstaller
|
* @run main ClassFileInstaller
|
||||||
* compiler.jvmci.common.JVMCIHelpers$EmptyHotspotCompiler
|
* compiler.jvmci.common.JVMCIHelpers$EmptyHotspotCompiler
|
||||||
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilerFactory
|
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilerFactory
|
||||||
|
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilationRequestResult
|
||||||
|
* compiler.jvmci.common.JVMCIHelpers$EmptyVMEventListener
|
||||||
* compiler.jvmci.events.JvmciNotifyInstallEventTest
|
* compiler.jvmci.events.JvmciNotifyInstallEventTest
|
||||||
* compiler.jvmci.common.CTVMUtilities
|
* compiler.jvmci.common.CTVMUtilities
|
||||||
* compiler.jvmci.common.testcases.SimpleClass
|
* compiler.jvmci.common.testcases.SimpleClass
|
||||||
|
@ -40,6 +40,8 @@
|
|||||||
* @run main ClassFileInstaller
|
* @run main ClassFileInstaller
|
||||||
* compiler.jvmci.common.JVMCIHelpers$EmptyHotspotCompiler
|
* compiler.jvmci.common.JVMCIHelpers$EmptyHotspotCompiler
|
||||||
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilerFactory
|
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilerFactory
|
||||||
|
* compiler.jvmci.common.JVMCIHelpers$EmptyCompilationRequestResult
|
||||||
|
* compiler.jvmci.common.JVMCIHelpers$EmptyVMEventListener
|
||||||
* compiler.jvmci.events.JvmciShutdownEventListener
|
* compiler.jvmci.events.JvmciShutdownEventListener
|
||||||
* @run main/othervm compiler.jvmci.events.JvmciShutdownEventTest
|
* @run main/othervm compiler.jvmci.events.JvmciShutdownEventTest
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user