From 5a4de97cf03ffc4ee5a332b9920526aabbe97979 Mon Sep 17 00:00:00 2001 From: Christian Thalinger Date: Thu, 3 Nov 2011 01:43:26 -0700 Subject: [PATCH] 7106774: JSR 292: nightly test inlineMHTarget fails with wrong result Reviewed-by: kvn --- hotspot/src/share/vm/interpreter/bytecode.hpp | 7 +++++++ hotspot/src/share/vm/runtime/deoptimization.cpp | 8 ++------ 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/hotspot/src/share/vm/interpreter/bytecode.hpp b/hotspot/src/share/vm/interpreter/bytecode.hpp index 7fb50dffb99..107161a979e 100644 --- a/hotspot/src/share/vm/interpreter/bytecode.hpp +++ b/hotspot/src/share/vm/interpreter/bytecode.hpp @@ -234,6 +234,13 @@ class Bytecode_invoke: public Bytecode_member_ref { is_invokespecial() || 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 inline friend Bytecode_invoke Bytecode_invoke_check(methodHandle method, int bci); }; diff --git a/hotspot/src/share/vm/runtime/deoptimization.cpp b/hotspot/src/share/vm/runtime/deoptimization.cpp index 0c36d2d0cab..05771c31180 100644 --- a/hotspot/src/share/vm/runtime/deoptimization.cpp +++ b/hotspot/src/share/vm/runtime/deoptimization.cpp @@ -388,12 +388,8 @@ Deoptimization::UnrollBlock* Deoptimization::fetch_unroll_info_helper(JavaThread bool caller_was_method_handle = false; if (deopt_sender.is_interpreted_frame()) { methodHandle method = deopt_sender.interpreter_frame_method(); - Bytecode_invoke cur = Bytecode_invoke_check(method, - deopt_sender.interpreter_frame_bci()); - 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()))) { + Bytecode_invoke cur = Bytecode_invoke_check(method, deopt_sender.interpreter_frame_bci()); + if (cur.is_method_handle_invoke()) { // Method handle invokes may involve fairly arbitrary chains of // calls so it's impossible to know how much actual space the // caller has for locals.