提交 38fd234f 编写于 作者: I iveresov

8056154: JVM crash with EXCEPTION_ACCESS_VIOLATION when there are many threads running

Summary: Don't make compiled MH intrinsics not entrant when redefining classes
Reviewed-by: kvn, vlivanov
上级 650e1a07
...@@ -2291,6 +2291,9 @@ methodHandle SystemDictionary::find_method_handle_intrinsic(vmIntrinsics::ID iid ...@@ -2291,6 +2291,9 @@ methodHandle SystemDictionary::find_method_handle_intrinsic(vmIntrinsics::ID iid
} }
assert(spe != NULL && spe->method() != NULL, ""); assert(spe != NULL && spe->method() != NULL, "");
assert(!UseCompiler || (spe->method()->has_compiled_code() &&
spe->method()->code()->entry_point() == spe->method()->from_compiled_entry()),
"MH intrinsic invariant");
return spe->method(); return spe->method();
} }
......
...@@ -712,8 +712,10 @@ int CodeCache::mark_for_evol_deoptimization(instanceKlassHandle dependee) { ...@@ -712,8 +712,10 @@ int CodeCache::mark_for_evol_deoptimization(instanceKlassHandle dependee) {
void CodeCache::mark_all_nmethods_for_deoptimization() { void CodeCache::mark_all_nmethods_for_deoptimization() {
MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag); MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag);
FOR_ALL_ALIVE_NMETHODS(nm) { FOR_ALL_ALIVE_NMETHODS(nm) {
if (!nm->method()->is_method_handle_intrinsic()) {
nm->mark_for_deoptimization(); nm->mark_for_deoptimization();
} }
}
} }
......
...@@ -595,6 +595,7 @@ void CompiledStaticCall::compute_entry(methodHandle m, StaticCallInfo& info) { ...@@ -595,6 +595,7 @@ void CompiledStaticCall::compute_entry(methodHandle m, StaticCallInfo& info) {
} else { } else {
// Callee is interpreted code. In any case entering the interpreter // Callee is interpreted code. In any case entering the interpreter
// puts a converter-frame on the stack to save arguments. // puts a converter-frame on the stack to save arguments.
assert(!m->is_method_handle_intrinsic(), "Compiled code should never call interpreter MH intrinsics");
info._to_interpreter = true; info._to_interpreter = true;
info._entry = m()->get_c2i_entry(); info._entry = m()->get_c2i_entry();
} }
......
...@@ -448,7 +448,10 @@ class nmethod : public CodeBlob { ...@@ -448,7 +448,10 @@ class nmethod : public CodeBlob {
// alive. It is used when an uncommon trap happens. Returns true // alive. It is used when an uncommon trap happens. Returns true
// if this thread changed the state of the nmethod or false if // if this thread changed the state of the nmethod or false if
// another thread performed the transition. // another thread performed the transition.
bool make_not_entrant() { return make_not_entrant_or_zombie(not_entrant); } bool make_not_entrant() {
assert(!method()->is_method_handle_intrinsic(), "Cannot make MH intrinsic not entrant");
return make_not_entrant_or_zombie(not_entrant);
}
bool make_zombie() { return make_not_entrant_or_zombie(zombie); } bool make_zombie() { return make_not_entrant_or_zombie(zombie); }
// used by jvmti to track if the unload event has been reported // used by jvmti to track if the unload event has been reported
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册