From fc7955d5fc2fc8256b43aab3bf4fd52234388bf0 Mon Sep 17 00:00:00 2001 From: Nils Eliasson Date: Mon, 20 Nov 2017 09:50:27 +0100 Subject: [PATCH] 8160548: Inconsistent inlining behavior with CompileOnly Can_be_compiled should not affect inlining Reviewed-by: thartmann --- src/hotspot/share/opto/bytecodeInfo.cpp | 1 - src/hotspot/share/opto/parse1.cpp | 2 +- test/hotspot/jtreg/compiler/whitebox/DeoptimizeFramesTest.java | 2 ++ 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/src/hotspot/share/opto/bytecodeInfo.cpp b/src/hotspot/share/opto/bytecodeInfo.cpp index 2558c77e0e4..c3d70097e13 100644 --- a/src/hotspot/share/opto/bytecodeInfo.cpp +++ b/src/hotspot/share/opto/bytecodeInfo.cpp @@ -478,7 +478,6 @@ const char* InlineTree::check_can_parse(ciMethod* callee) { // Certain methods cannot be parsed at all: if ( callee->is_native()) return "native method"; if ( callee->is_abstract()) return "abstract method"; - if (!callee->can_be_compiled()) return "not compilable (disabled)"; if (!callee->has_balanced_monitors()) return "not compilable (unbalanced monitors)"; if ( callee->get_flow_analysis()->failing()) return "not compilable (flow analysis failed)"; return NULL; diff --git a/src/hotspot/share/opto/parse1.cpp b/src/hotspot/share/opto/parse1.cpp index 84d40d469d0..9a7571a95ae 100644 --- a/src/hotspot/share/opto/parse1.cpp +++ b/src/hotspot/share/opto/parse1.cpp @@ -487,7 +487,7 @@ Parse::Parse(JVMState* caller, ciMethod* parse_method, float expected_uses) log->elem("observe that='has_exception_handlers'"); } - assert(method()->can_be_compiled(), "Can not parse this method, cutout earlier"); + assert(InlineTree::check_can_parse(method()) == NULL, "Can not parse this method, cutout earlier"); assert(method()->has_balanced_monitors(), "Can not parse unbalanced monitors, cutout earlier"); // Always register dependence if JVMTI is enabled, because diff --git a/test/hotspot/jtreg/compiler/whitebox/DeoptimizeFramesTest.java b/test/hotspot/jtreg/compiler/whitebox/DeoptimizeFramesTest.java index 87c66ceb39e..6001b7704eb 100644 --- a/test/hotspot/jtreg/compiler/whitebox/DeoptimizeFramesTest.java +++ b/test/hotspot/jtreg/compiler/whitebox/DeoptimizeFramesTest.java @@ -39,6 +39,7 @@ * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xmixed -XX:-UseCounterDecay * -XX:CompileCommand=compileonly,compiler.whitebox.DeoptimizeFramesTest$TestCaseImpl::method + * -XX:CompileCommand=dontinline,java.util.concurrent.Phaser::* * -XX:+IgnoreUnrecognizedVMOptions -XX:-DeoptimizeRandom -XX:-DeoptimizeALot * compiler.whitebox.DeoptimizeFramesTest false */ @@ -110,6 +111,7 @@ public class DeoptimizeFramesTest extends CompilerWhiteBoxTest { String.format("compilation %d can't be available", nm.compile_id)); } } else { + Asserts.assertNE(nm2, null, "must not be null"); Asserts.assertEQ(nm.compile_id, nm2.compile_id, "should be the same nmethod"); } }