8173404: C2: wrong nmethod dependency can be recorded for CallSite.target
Reviewed-by: kvn
This commit is contained in:
parent
cdae3f8fba
commit
81e25c58fb
@ -373,7 +373,7 @@ const Type* Type::make_constant_from_field(ciField* field, ciInstance* holder,
|
||||
if (con_type != NULL && field->is_call_site_target()) {
|
||||
ciCallSite* call_site = holder->as_call_site();
|
||||
if (!call_site->is_constant_call_site()) {
|
||||
ciMethodHandle* target = call_site->get_target();
|
||||
ciMethodHandle* target = con.as_object()->as_method_handle();
|
||||
Compile::current()->dependencies()->assert_call_site_target_value(call_site, target);
|
||||
}
|
||||
}
|
||||
|
@ -23,7 +23,6 @@
|
||||
|
||||
/**
|
||||
* @test
|
||||
* @modules java.base/jdk.internal.misc
|
||||
* @library /test/lib /
|
||||
*
|
||||
* @run driver compiler.jsr292.ContinuousCallSiteTargetChange
|
||||
@ -31,6 +30,7 @@
|
||||
|
||||
package compiler.jsr292;
|
||||
|
||||
import jdk.test.lib.Asserts;
|
||||
import jdk.test.lib.process.OutputAnalyzer;
|
||||
import jdk.test.lib.process.ProcessTools;
|
||||
|
||||
@ -39,15 +39,26 @@ import java.lang.invoke.MethodHandle;
|
||||
import java.lang.invoke.MethodHandles;
|
||||
import java.lang.invoke.MethodType;
|
||||
import java.lang.invoke.MutableCallSite;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
public class ContinuousCallSiteTargetChange {
|
||||
static void testServer() throws Exception {
|
||||
static final int ITERATIONS = Integer.parseInt(System.getProperty("iterations", "50"));
|
||||
|
||||
static void runTest(Class<?> test, String... extraArgs) throws Exception {
|
||||
List<String> argsList = new ArrayList<>(
|
||||
List.of("-XX:+IgnoreUnrecognizedVMOptions",
|
||||
"-XX:PerBytecodeRecompilationCutoff=10", "-XX:PerMethodRecompilationCutoff=10",
|
||||
"-XX:+PrintCompilation", "-XX:+UnlockDiagnosticVMOptions", "-XX:+PrintInlining"));
|
||||
|
||||
argsList.addAll(Arrays.asList(extraArgs));
|
||||
|
||||
argsList.add(test.getName());
|
||||
argsList.add(Integer.toString(ITERATIONS));
|
||||
|
||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
||||
"-XX:+IgnoreUnrecognizedVMOptions",
|
||||
"-server", "-XX:-TieredCompilation", "-Xbatch",
|
||||
"-XX:PerBytecodeRecompilationCutoff=10", "-XX:PerMethodRecompilationCutoff=10",
|
||||
"-XX:+PrintCompilation", "-XX:+UnlockDiagnosticVMOptions", "-XX:+PrintInlining",
|
||||
Test.class.getName(), "100");
|
||||
argsList.toArray(new String[argsList.size()]));
|
||||
|
||||
OutputAnalyzer analyzer = new OutputAnalyzer(pb.start());
|
||||
|
||||
@ -55,30 +66,42 @@ public class ContinuousCallSiteTargetChange {
|
||||
|
||||
analyzer.shouldNotContain("made not compilable");
|
||||
analyzer.shouldNotContain("decompile_count > PerMethodRecompilationCutoff");
|
||||
|
||||
}
|
||||
|
||||
static void testClient() throws Exception {
|
||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
||||
"-XX:+IgnoreUnrecognizedVMOptions",
|
||||
"-client", "-XX:+TieredCompilation", "-XX:TieredStopAtLevel=1", "-Xbatch",
|
||||
"-XX:PerBytecodeRecompilationCutoff=10", "-XX:PerMethodRecompilationCutoff=10",
|
||||
"-XX:+PrintCompilation", "-XX:+UnlockDiagnosticVMOptions", "-XX:+PrintInlining",
|
||||
Test.class.getName(), "100");
|
||||
static void testServer(Class<?> test, String... args) throws Exception {
|
||||
List<String> extraArgsList = new ArrayList<>(
|
||||
List.of("-server", "-XX:-TieredCompilation"));
|
||||
extraArgsList.addAll(Arrays.asList(args));
|
||||
|
||||
OutputAnalyzer analyzer = new OutputAnalyzer(pb.start());
|
||||
runTest(test, extraArgsList.toArray(new String[extraArgsList.size()]));
|
||||
}
|
||||
|
||||
analyzer.shouldHaveExitValue(0);
|
||||
static void testClient(Class<?> test, String... args) throws Exception {
|
||||
List<String> extraArgsList = new ArrayList<>(
|
||||
List.of("-client", "-XX:+TieredCompilation", "-XX:TieredStopAtLevel=1"));
|
||||
extraArgsList.addAll(Arrays.asList(args));
|
||||
|
||||
analyzer.shouldNotContain("made not compilable");
|
||||
analyzer.shouldNotContain("decompile_count > PerMethodRecompilationCutoff");
|
||||
runTest(test, extraArgsList.toArray(new String[extraArgsList.size()]));
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
testServer();
|
||||
testClient();
|
||||
testServer(RecompilationTest.class, "-Xbatch");
|
||||
testClient(RecompilationTest.class, "-Xbatch");
|
||||
|
||||
testServer(PingPongTest.class);
|
||||
testClient(PingPongTest.class);
|
||||
}
|
||||
|
||||
static class Test {
|
||||
static MethodHandle findStatic(Class<?> cls, String name, MethodType mt) {
|
||||
try {
|
||||
return MethodHandles.lookup().findStatic(cls, name, mt);
|
||||
} catch (Exception e) {
|
||||
throw new Error(e);
|
||||
}
|
||||
}
|
||||
|
||||
static class RecompilationTest {
|
||||
static final MethodType mt = MethodType.methodType(void.class);
|
||||
static final CallSite cs = new MutableCallSite(mt);
|
||||
|
||||
@ -96,7 +119,7 @@ public class ContinuousCallSiteTargetChange {
|
||||
}
|
||||
|
||||
static void iteration() throws Throwable {
|
||||
MethodHandle mh1 = MethodHandles.lookup().findStatic(ContinuousCallSiteTargetChange.Test.class, "f", mt);
|
||||
MethodHandle mh1 = findStatic(RecompilationTest.class, "f", mt);
|
||||
cs.setTarget(mh1);
|
||||
for (int i = 0; i < 20_000; i++) {
|
||||
test1();
|
||||
@ -111,4 +134,38 @@ public class ContinuousCallSiteTargetChange {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static class PingPongTest {
|
||||
static final MethodType mt = MethodType.methodType(void.class);
|
||||
static final CallSite cs = new MutableCallSite(mt);
|
||||
|
||||
static final MethodHandle mh = cs.dynamicInvoker();
|
||||
|
||||
static final MethodHandle ping = findStatic(PingPongTest.class, "ping", mt);
|
||||
static final MethodHandle pong = findStatic(PingPongTest.class, "pong", mt);
|
||||
|
||||
static void ping() {
|
||||
Asserts.assertEQ(cs.getTarget(), ping, "wrong call site target");
|
||||
cs.setTarget(pong);
|
||||
}
|
||||
|
||||
static void pong() {
|
||||
Asserts.assertEQ(cs.getTarget(), pong, "wrong call site target");
|
||||
cs.setTarget(ping);
|
||||
}
|
||||
|
||||
static void iteration() throws Throwable {
|
||||
cs.setTarget(ping);
|
||||
for (int i = 0; i < 20_000; i++) {
|
||||
mh.invokeExact();
|
||||
}
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws Throwable {
|
||||
int iterations = Integer.parseInt(args[0]);
|
||||
for (int i = 0; i < iterations; i++) {
|
||||
iteration();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user