From 2dbc9735ac409e938f28330f77335f4be1983b9f Mon Sep 17 00:00:00 2001 From: Mikael Vidstedt Date: Tue, 24 Apr 2018 21:40:10 -0700 Subject: [PATCH] 8202169: Reduce ctw_2 duration by parallelizing CtwRunner invocations Reviewed-by: kvn, iignatyev --- test/hotspot/jtreg/TEST.groups | 4 +- .../applications/ctw/modules/java_base.java | 6 +- .../applications/ctw/modules/java_base_2.java | 38 +++++++++ .../ctw/modules/java_desktop.java | 6 +- .../ctw/modules/java_desktop_2.java | 38 +++++++++ .../src/sun/hotspot/tools/ctw/CtwRunner.java | 82 ++++++++++++++++--- 6 files changed, 156 insertions(+), 18 deletions(-) create mode 100644 test/hotspot/jtreg/applications/ctw/modules/java_base_2.java create mode 100644 test/hotspot/jtreg/applications/ctw/modules/java_desktop_2.java diff --git a/test/hotspot/jtreg/TEST.groups b/test/hotspot/jtreg/TEST.groups index 5cd46140424..19c5262a97c 100644 --- a/test/hotspot/jtreg/TEST.groups +++ b/test/hotspot/jtreg/TEST.groups @@ -142,7 +142,9 @@ ctw_1 = \ ctw_2 = \ applications/ctw/modules/java_base.java \ - applications/ctw/modules/java_desktop.java + applications/ctw/modules/java_base_2.java \ + applications/ctw/modules/java_desktop.java \ + applications/ctw/modules/java_desktop_2.java ctw_3 = \ applications/ctw/modules/javafx_graphics.java \ diff --git a/test/hotspot/jtreg/applications/ctw/modules/java_base.java b/test/hotspot/jtreg/applications/ctw/modules/java_base.java index d332fcbc201..981369d0547 100644 --- a/test/hotspot/jtreg/applications/ctw/modules/java_base.java +++ b/test/hotspot/jtreg/applications/ctw/modules/java_base.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ /* * @test - * @summary run CTW for all classes from java.base module + * @summary run CTW for some classes from java.base module * * @library /test/lib / /testlibrary/ctw/src * @modules java.base/jdk.internal.jimage @@ -34,5 +34,5 @@ * @build sun.hotspot.WhiteBox * @run driver ClassFileInstaller sun.hotspot.WhiteBox * sun.hotspot.WhiteBox$WhiteBoxPermission - * @run main/timeout=7200 sun.hotspot.tools.ctw.CtwRunner modules:java.base + * @run main/timeout=7200 sun.hotspot.tools.ctw.CtwRunner modules:java.base 0% 50% */ diff --git a/test/hotspot/jtreg/applications/ctw/modules/java_base_2.java b/test/hotspot/jtreg/applications/ctw/modules/java_base_2.java new file mode 100644 index 00000000000..d462179d5fe --- /dev/null +++ b/test/hotspot/jtreg/applications/ctw/modules/java_base_2.java @@ -0,0 +1,38 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @summary run CTW for some classes from java.base module + * + * @library /test/lib / /testlibrary/ctw/src + * @modules java.base/jdk.internal.jimage + * java.base/jdk.internal.misc + * java.base/jdk.internal.reflect + * @modules java.base + * + * @build sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run main/timeout=7200 sun.hotspot.tools.ctw.CtwRunner modules:java.base 50% 100% + */ diff --git a/test/hotspot/jtreg/applications/ctw/modules/java_desktop.java b/test/hotspot/jtreg/applications/ctw/modules/java_desktop.java index 6c38d106f9e..1bac2f614fd 100644 --- a/test/hotspot/jtreg/applications/ctw/modules/java_desktop.java +++ b/test/hotspot/jtreg/applications/ctw/modules/java_desktop.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ /* * @test - * @summary run CTW for all classes from java.desktop module + * @summary run CTW for some classes from java.desktop module * * @library /test/lib / /testlibrary/ctw/src * @modules java.base/jdk.internal.jimage @@ -34,5 +34,5 @@ * @build sun.hotspot.WhiteBox * @run driver ClassFileInstaller sun.hotspot.WhiteBox * sun.hotspot.WhiteBox$WhiteBoxPermission - * @run main/timeout=7200 sun.hotspot.tools.ctw.CtwRunner modules:java.desktop + * @run main/timeout=7200 sun.hotspot.tools.ctw.CtwRunner modules:java.desktop 0% 50% */ diff --git a/test/hotspot/jtreg/applications/ctw/modules/java_desktop_2.java b/test/hotspot/jtreg/applications/ctw/modules/java_desktop_2.java new file mode 100644 index 00000000000..7c8d98bfcaa --- /dev/null +++ b/test/hotspot/jtreg/applications/ctw/modules/java_desktop_2.java @@ -0,0 +1,38 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @summary run CTW for some classes from java.desktop module + * + * @library /test/lib / /testlibrary/ctw/src + * @modules java.base/jdk.internal.jimage + * java.base/jdk.internal.misc + * java.base/jdk.internal.reflect + * @modules java.desktop + * + * @build sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run main/timeout=7200 sun.hotspot.tools.ctw.CtwRunner modules:java.desktop 50% 100% + */ diff --git a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/CtwRunner.java b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/CtwRunner.java index cdc8efaedfb..4b4a02a56ad 100644 --- a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/CtwRunner.java +++ b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/CtwRunner.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -52,11 +52,17 @@ public class CtwRunner { private static final Predicate IS_CLASS_LINE = Pattern.compile( "^\\[\\d+\\]\\s*\\S+\\s*$").asPredicate(); + private static final String USAGE = "Usage: CtwRunner [start[%] stop[%]]"; + public static void main(String[] args) throws Exception { - if (args.length != 1) { - throw new Error("Usage: "); + CtwRunner runner; + switch (args.length) { + case 1: runner = new CtwRunner(args[0]); break; + case 3: runner = new CtwRunner(args[0], args[1], args[2]); break; + default: throw new Error(USAGE); } - new CtwRunner(args[0]).run(); + + runner.run(); } private final List errors; @@ -64,7 +70,10 @@ public class CtwRunner { private final Path targetPath; private final String targetName; - private CtwRunner(String target) { + private final int start, stop; + private final boolean isStartStopPercentage; + + private CtwRunner(String target, String start, String stop) { if (target.startsWith("modules")) { targetPath = Paths .get(Utils.TEST_JDK) @@ -82,8 +91,29 @@ public class CtwRunner { } this.target = target; errors = new ArrayList<>(); + + if (start.endsWith("%") && stop.endsWith("%")) { + int startPercentage = Integer.parseInt(start.substring(0, start.length() - 1));; + int stopPercentage = Integer.parseInt(stop.substring(0, stop.length() - 1)); + if (startPercentage < 0 || startPercentage > 100 || + stopPercentage < 0 || stopPercentage > 100) { + throw new Error(USAGE); + } + this.start = startPercentage; + this.stop = stopPercentage; + this.isStartStopPercentage = true; + } else if (!start.endsWith("%") && !stop.endsWith("%")) { + this.start = Integer.parseInt(start); + this.stop = Integer.parseInt(stop); + this.isStartStopPercentage = false; + } else { + throw new Error(USAGE); + } } + private CtwRunner(String target) { + this(target, "0%", "100%"); + } private void run() { startCtwforAllClasses(); @@ -105,15 +135,44 @@ public class CtwRunner { } } + private long start(long totalClassCount) { + if (isStartStopPercentage) { + return totalClassCount * start / 100; + } else if (start > totalClassCount) { + System.err.println("WARNING: start [" + start + "] > totalClassCount [" + totalClassCount + "]"); + return totalClassCount; + } else { + return start; + } + } + + private long stop(long totalClassCount) { + if (isStartStopPercentage) { + return totalClassCount * stop / 100; + } else if (stop > totalClassCount) { + System.err.println("WARNING: stop [" + start + "] > totalClassCount [" + totalClassCount + "]"); + return totalClassCount; + } else { + return stop; + } + } private void startCtwforAllClasses() { - long classStart = 0L; - long classCount = classCount(); + long totalClassCount = classCount(); + + long classStart = start(totalClassCount); + long classStop = stop(totalClassCount); + + long classCount = classStop - classStart; Asserts.assertGreaterThan(classCount, 0L, target + "(at " + targetPath + ") does not have any classes"); + + System.out.printf("Compiling %d classes (of %d total classes) starting at %d and ending at %d\n", + classCount, totalClassCount, classStart, classStop); + boolean done = false; while (!done) { - String[] cmd = cmd(classStart); + String[] cmd = cmd(classStart, classStop); try { ProcessBuilder pb = ProcessTools.createJavaProcessBuilder( /* addTestVmAndJavaOptions = */ true, @@ -138,11 +197,11 @@ public class CtwRunner { Pair lastClass = getLastClass(out); if (exitCode == 0) { long lastIndex = lastClass == null ? -1 : lastClass.second; - if (lastIndex != classCount) { + if (lastIndex != classStop) { errors.add(new Error(phase + ": Unexpected zero exit code" + "before finishing all compilations." + " lastClass[" + lastIndex - + "] != classCount[" + classCount + "]")); + + "] != classStop[" + classStop + "]")); } else { System.out.println("Executed CTW for all " + classCount + " classes in " + target + "(at " + targetPath + ")"); @@ -197,7 +256,7 @@ public class CtwRunner { return null; } - private String[] cmd(long classStart) { + private String[] cmd(long classStart, long classStop) { String phase = phaseName(classStart); return new String[] { "-Xbatch", @@ -206,6 +265,7 @@ public class CtwRunner { "-XX:+UnlockDiagnosticVMOptions", // define phase start "-DCompileTheWorldStartAt=" + classStart, + "-DCompileTheWorldStopAt=" + classStop, // CTW library uses WhiteBox API "-XX:+WhiteBoxAPI", "-Xbootclasspath/a:.", // export jdk.internal packages used by CTW library