2013-11-07 15:17:10 +01:00
|
|
|
/*
|
2016-08-19 10:06:30 -04:00
|
|
|
* Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved.
|
2013-11-07 15:17:10 +01:00
|
|
|
* 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
|
2018-02-08 08:38:42 -08:00
|
|
|
* @key regression gc
|
2013-11-07 15:17:10 +01:00
|
|
|
* @bug 8027756
|
2016-08-29 23:04:48 +04:00
|
|
|
* @requires vm.gc.G1
|
2016-08-19 10:06:30 -04:00
|
|
|
* @library /test/lib
|
2016-04-09 23:03:39 +01:00
|
|
|
* @modules java.base/jdk.internal.misc
|
2015-03-26 16:36:56 +01:00
|
|
|
* java.management
|
2016-08-19 10:06:30 -04:00
|
|
|
* @build sun.hotspot.WhiteBox
|
2018-01-17 21:44:44 -08:00
|
|
|
* @run driver ClassFileInstaller sun.hotspot.WhiteBox
|
2014-08-11 17:12:41 +04:00
|
|
|
* sun.hotspot.WhiteBox$WhiteBoxPermission
|
2013-11-07 15:17:10 +01:00
|
|
|
* @summary Humongous objects may have references from the code cache
|
|
|
|
* @run main TestHumongousCodeCacheRoots
|
|
|
|
*/
|
|
|
|
|
2016-08-19 10:06:30 -04:00
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
|
|
|
import jdk.test.lib.process.ProcessTools;
|
2013-11-07 15:17:10 +01:00
|
|
|
import sun.hotspot.WhiteBox;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Arrays;
|
|
|
|
|
|
|
|
class TestHumongousCodeCacheRootsHelper {
|
|
|
|
|
|
|
|
static final int n = 1000000;
|
|
|
|
static final int[] AA = new int[n];
|
|
|
|
static final int[] BB = new int[n];
|
|
|
|
|
|
|
|
public static void main(String args[]) throws Exception {
|
|
|
|
// do some work so that the compiler compiles this method, inlining the
|
|
|
|
// reference to the integer array (which is a humonguous object) into
|
|
|
|
// the code cache.
|
|
|
|
for(int i = 0; i < n; i++) {
|
|
|
|
AA[i] = 0;
|
|
|
|
BB[i] = 0;
|
|
|
|
}
|
|
|
|
// trigger a GC that checks that the verification code allows humongous
|
|
|
|
// objects with code cache roots; objects should be all live here.
|
|
|
|
System.gc();
|
|
|
|
|
|
|
|
// deoptimize everyhing: this should make all compiled code zombies.
|
|
|
|
WhiteBox wb = WhiteBox.getWhiteBox();
|
|
|
|
wb.deoptimizeAll();
|
|
|
|
|
|
|
|
// trigger a GC that checks that the verification code allows humongous
|
|
|
|
// objects with code cache roots; objects should be all live here.
|
|
|
|
System.gc();
|
|
|
|
|
|
|
|
// wait a little for the code cache sweeper to try to clean up zombie nmethods
|
|
|
|
// and unregister the code roots.
|
|
|
|
try { Thread.sleep(5000); } catch (InterruptedException ex) { }
|
|
|
|
|
|
|
|
// do some work on the arrays to make sure that they need to be live after the GCs
|
|
|
|
for(int i = 0; i < n; i++) {
|
|
|
|
AA[i] = 1;
|
|
|
|
BB[i] = 10;
|
|
|
|
}
|
|
|
|
|
|
|
|
System.out.println();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public class TestHumongousCodeCacheRoots {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes a class in a new VM process with the given parameters.
|
|
|
|
* @param vmargs Arguments to the VM to run
|
|
|
|
* @param classname Name of the class to run
|
|
|
|
* @param arguments Arguments to the class
|
|
|
|
* @param useTestDotJavaDotOpts Use test.java.opts as part of the VM argument string
|
|
|
|
* @return The OutputAnalyzer with the results for the invocation.
|
|
|
|
*/
|
|
|
|
public static OutputAnalyzer runWhiteBoxTest(String[] vmargs, String classname, String[] arguments, boolean useTestDotJavaDotOpts) throws Exception {
|
|
|
|
ArrayList<String> finalargs = new ArrayList<String>();
|
|
|
|
|
|
|
|
String[] whiteboxOpts = new String[] {
|
|
|
|
"-Xbootclasspath/a:.",
|
|
|
|
"-XX:+UnlockDiagnosticVMOptions", "-XX:+WhiteBoxAPI",
|
|
|
|
"-cp", System.getProperty("java.class.path"),
|
|
|
|
};
|
|
|
|
|
|
|
|
if (useTestDotJavaDotOpts) {
|
|
|
|
// System.getProperty("test.java.opts") is '' if no options is set,
|
|
|
|
// we need to skip such a result
|
|
|
|
String[] externalVMOpts = new String[0];
|
|
|
|
if (System.getProperty("test.java.opts") != null && System.getProperty("test.java.opts").length() != 0) {
|
|
|
|
externalVMOpts = System.getProperty("test.java.opts").split(" ");
|
|
|
|
}
|
|
|
|
finalargs.addAll(Arrays.asList(externalVMOpts));
|
|
|
|
}
|
|
|
|
|
|
|
|
finalargs.addAll(Arrays.asList(vmargs));
|
|
|
|
finalargs.addAll(Arrays.asList(whiteboxOpts));
|
|
|
|
finalargs.add(classname);
|
|
|
|
finalargs.addAll(Arrays.asList(arguments));
|
|
|
|
|
|
|
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(finalargs.toArray(new String[0]));
|
|
|
|
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
2018-08-01 09:23:24 -07:00
|
|
|
output.shouldHaveExitValue(0);
|
2013-11-07 15:17:10 +01:00
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
|
|
final String[] baseArguments = new String[] {
|
|
|
|
"-XX:+UseG1GC", "-XX:G1HeapRegionSize=1M", "-Xmx100M", // make sure we get a humongous region
|
|
|
|
"-XX:+UnlockDiagnosticVMOptions",
|
|
|
|
"-XX:InitiatingHeapOccupancyPercent=1", // strong code root marking
|
|
|
|
"-XX:+G1VerifyHeapRegionCodeRoots", "-XX:+VerifyAfterGC", // make sure that verification is run
|
|
|
|
};
|
2018-08-01 09:23:24 -07:00
|
|
|
|
|
|
|
runWhiteBoxTest(baseArguments, TestHumongousCodeCacheRootsHelper.class.getName(),
|
|
|
|
new String[] {}, false);
|
2013-11-07 15:17:10 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|