8058092: Test vm/mlvm/meth/stress/compiler/deoptimize. Assert in src/share/vm/classfile/systemDictionary.cpp: MH intrinsic invariant
Throw exception if unable to compile an MH intrinsic Reviewed-by: kvn
This commit is contained in:
parent
2d59d215e2
commit
7275456c3a
@ -52,6 +52,7 @@
|
|||||||
#include "oops/typeArrayKlass.hpp"
|
#include "oops/typeArrayKlass.hpp"
|
||||||
#include "prims/jvmtiEnvBase.hpp"
|
#include "prims/jvmtiEnvBase.hpp"
|
||||||
#include "prims/methodHandles.hpp"
|
#include "prims/methodHandles.hpp"
|
||||||
|
#include "runtime/arguments.hpp"
|
||||||
#include "runtime/biasedLocking.hpp"
|
#include "runtime/biasedLocking.hpp"
|
||||||
#include "runtime/fieldType.hpp"
|
#include "runtime/fieldType.hpp"
|
||||||
#include "runtime/handles.inline.hpp"
|
#include "runtime/handles.inline.hpp"
|
||||||
@ -2274,7 +2275,11 @@ methodHandle SystemDictionary::find_method_handle_intrinsic(vmIntrinsics::ID iid
|
|||||||
m = Method::make_method_handle_intrinsic(iid, signature, CHECK_(empty));
|
m = Method::make_method_handle_intrinsic(iid, signature, CHECK_(empty));
|
||||||
CompileBroker::compile_method(m, InvocationEntryBci, CompLevel_highest_tier,
|
CompileBroker::compile_method(m, InvocationEntryBci, CompLevel_highest_tier,
|
||||||
methodHandle(), CompileThreshold, "MH", CHECK_(empty));
|
methodHandle(), CompileThreshold, "MH", CHECK_(empty));
|
||||||
|
// Check if we need to have compiled code but we don't.
|
||||||
|
if (!Arguments::is_interpreter_only() && !m->has_compiled_code()) {
|
||||||
|
THROW_MSG_(vmSymbols::java_lang_VirtualMachineError(),
|
||||||
|
"out of space in CodeCache for method handle intrinsic", empty);
|
||||||
|
}
|
||||||
// Now grab the lock. We might have to throw away the new method,
|
// Now grab the lock. We might have to throw away the new method,
|
||||||
// if a racing thread has managed to install one at the same time.
|
// if a racing thread has managed to install one at the same time.
|
||||||
{
|
{
|
||||||
@ -2288,7 +2293,7 @@ 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() &&
|
assert(Arguments::is_interpreter_only() || (spe->method()->has_compiled_code() &&
|
||||||
spe->method()->code()->entry_point() == spe->method()->from_compiled_entry()),
|
spe->method()->code()->entry_point() == spe->method()->from_compiled_entry()),
|
||||||
"MH intrinsic invariant");
|
"MH intrinsic invariant");
|
||||||
return spe->method();
|
return spe->method();
|
||||||
|
@ -591,6 +591,8 @@ class Arguments : AllStatic {
|
|||||||
|
|
||||||
// Operation modi
|
// Operation modi
|
||||||
static Mode mode() { return _mode; }
|
static Mode mode() { return _mode; }
|
||||||
|
static bool is_interpreter_only() { return mode() == _int; }
|
||||||
|
|
||||||
|
|
||||||
// Utility: copies src into buf, replacing "%%" with "%" and "%p" with pid.
|
// Utility: copies src into buf, replacing "%%" with "%" and "%p" with pid.
|
||||||
static bool copy_expand_pid(const char* src, size_t srclen, char* buf, size_t buflen);
|
static bool copy_expand_pid(const char* src, size_t srclen, char* buf, size_t buflen);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user