8145270: Need to eagerly initialize JVMCI compiler under -Xcomp
Reviewed-by: twisti
This commit is contained in:
parent
6f27a97d77
commit
08a2e337c7
@ -56,6 +56,7 @@
|
|||||||
#if INCLUDE_JVMCI
|
#if INCLUDE_JVMCI
|
||||||
#include "jvmci/jvmciCompiler.hpp"
|
#include "jvmci/jvmciCompiler.hpp"
|
||||||
#include "jvmci/jvmciRuntime.hpp"
|
#include "jvmci/jvmciRuntime.hpp"
|
||||||
|
#include "jvmci/jvmciJavaClasses.hpp"
|
||||||
#include "runtime/vframe.hpp"
|
#include "runtime/vframe.hpp"
|
||||||
#endif
|
#endif
|
||||||
#ifdef COMPILER2
|
#ifdef COMPILER2
|
||||||
@ -498,7 +499,7 @@ CompilerCounters::CompilerCounters() {
|
|||||||
// CompileBroker::compilation_init
|
// CompileBroker::compilation_init
|
||||||
//
|
//
|
||||||
// Initialize the Compilation object
|
// Initialize the Compilation object
|
||||||
void CompileBroker::compilation_init() {
|
void CompileBroker::compilation_init(TRAPS) {
|
||||||
_last_method_compiled[0] = '\0';
|
_last_method_compiled[0] = '\0';
|
||||||
|
|
||||||
// No need to initialize compilation system if we do not use it.
|
// No need to initialize compilation system if we do not use it.
|
||||||
@ -529,6 +530,17 @@ void CompileBroker::compilation_init() {
|
|||||||
} else {
|
} else {
|
||||||
c1_count = JVMCIHostThreads;
|
c1_count = JVMCIHostThreads;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!UseInterpreter) {
|
||||||
|
// 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
|
||||||
|
@ -276,7 +276,7 @@ public:
|
|||||||
CompileQueue *q = compile_queue(comp_level);
|
CompileQueue *q = compile_queue(comp_level);
|
||||||
return q != NULL ? q->size() : 0;
|
return q != NULL ? q->size() : 0;
|
||||||
}
|
}
|
||||||
static void compilation_init();
|
static void compilation_init(TRAPS);
|
||||||
static void init_compiler_thread_log();
|
static void init_compiler_thread_log();
|
||||||
static nmethod* compile_method(const methodHandle& method,
|
static nmethod* compile_method(const methodHandle& method,
|
||||||
int osr_bci,
|
int osr_bci,
|
||||||
|
@ -3628,7 +3628,7 @@ jint Threads::create_vm(JavaVMInitArgs* args, bool* canTryAgain) {
|
|||||||
|
|
||||||
// initialize compiler(s)
|
// initialize compiler(s)
|
||||||
#if defined(COMPILER1) || defined(COMPILER2) || defined(SHARK) || INCLUDE_JVMCI
|
#if defined(COMPILER1) || defined(COMPILER2) || defined(SHARK) || INCLUDE_JVMCI
|
||||||
CompileBroker::compilation_init();
|
CompileBroker::compilation_init(CHECK_JNI_ERR);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Pre-initialize some JSR292 core classes to avoid deadlock during class loading.
|
// Pre-initialize some JSR292 core classes to avoid deadlock during class loading.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user