提交 da540d83 编写于 作者: T twisti

7106774: JSR 292: nightly test inlineMHTarget fails with wrong result

Reviewed-by: kvn
上级 2d58f7c2
...@@ -234,6 +234,13 @@ class Bytecode_invoke: public Bytecode_member_ref { ...@@ -234,6 +234,13 @@ class Bytecode_invoke: public Bytecode_member_ref {
is_invokespecial() || is_invokespecial() ||
is_invokedynamic(); } is_invokedynamic(); }
bool is_method_handle_invoke() const {
return (is_invokedynamic() ||
(is_invokevirtual() &&
method()->constants()->klass_ref_at_noresolve(index()) == vmSymbols::java_lang_invoke_MethodHandle() &&
methodOopDesc::is_method_handle_invoke_name(name())));
}
// Helper to skip verification. Used is_valid() to check if the result is really an invoke // Helper to skip verification. Used is_valid() to check if the result is really an invoke
inline friend Bytecode_invoke Bytecode_invoke_check(methodHandle method, int bci); inline friend Bytecode_invoke Bytecode_invoke_check(methodHandle method, int bci);
}; };
......
...@@ -388,12 +388,8 @@ Deoptimization::UnrollBlock* Deoptimization::fetch_unroll_info_helper(JavaThread ...@@ -388,12 +388,8 @@ Deoptimization::UnrollBlock* Deoptimization::fetch_unroll_info_helper(JavaThread
bool caller_was_method_handle = false; bool caller_was_method_handle = false;
if (deopt_sender.is_interpreted_frame()) { if (deopt_sender.is_interpreted_frame()) {
methodHandle method = deopt_sender.interpreter_frame_method(); methodHandle method = deopt_sender.interpreter_frame_method();
Bytecode_invoke cur = Bytecode_invoke_check(method, Bytecode_invoke cur = Bytecode_invoke_check(method, deopt_sender.interpreter_frame_bci());
deopt_sender.interpreter_frame_bci()); if (cur.is_method_handle_invoke()) {
if (cur.code() == Bytecodes::_invokedynamic ||
(cur.code() == Bytecodes::_invokevirtual &&
method->constants()->klass_ref_at_noresolve(cur.index()) == vmSymbols::java_lang_invoke_MethodHandle() &&
methodOopDesc::is_method_handle_invoke_name(cur.name()))) {
// Method handle invokes may involve fairly arbitrary chains of // Method handle invokes may involve fairly arbitrary chains of
// calls so it's impossible to know how much actual space the // calls so it's impossible to know how much actual space the
// caller has for locals. // caller has for locals.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册