2021-09-28 06:23:47 +00:00
|
|
|
/*
|
2023-04-18 21:23:42 +00:00
|
|
|
* Copyright (c) 2021, 2023, Oracle and/or its affiliates. All rights reserved.
|
2021-09-28 06:23:47 +00: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 Loading CDS archived heap objects into SerialGC
|
|
|
|
* @bug 8234679
|
|
|
|
* @requires vm.cds
|
|
|
|
* @requires vm.gc.Serial
|
|
|
|
* @requires vm.gc.G1
|
|
|
|
*
|
|
|
|
* @comment don't run this test if any -XX::+Use???GC options are specified, since they will
|
2022-05-24 11:25:13 +00:00
|
|
|
* interfere with the test.
|
2021-09-28 06:23:47 +00:00
|
|
|
* @requires vm.gc == null
|
|
|
|
*
|
|
|
|
* @library /test/lib /test/hotspot/jtreg/runtime/cds/appcds
|
|
|
|
* @compile test-classes/Hello.java
|
|
|
|
* @run driver TestSerialGCWithCDS
|
|
|
|
*/
|
|
|
|
|
2022-12-01 19:59:14 +00:00
|
|
|
// Below is exactly the same as above, except:
|
|
|
|
// - requires vm.bits == "64"
|
|
|
|
// - extra argument "false"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @test Loading CDS archived heap objects into SerialGC
|
|
|
|
* @bug 8234679
|
|
|
|
* @requires vm.cds
|
|
|
|
* @requires vm.gc.Serial
|
|
|
|
* @requires vm.gc.G1
|
|
|
|
* @requires vm.bits == "64"
|
|
|
|
*
|
|
|
|
* @comment don't run this test if any -XX::+Use???GC options are specified, since they will
|
|
|
|
* interfere with the test.
|
|
|
|
* @requires vm.gc == null
|
|
|
|
*
|
|
|
|
* @library /test/lib /test/hotspot/jtreg/runtime/cds/appcds
|
|
|
|
* @compile test-classes/Hello.java
|
|
|
|
* @run driver TestSerialGCWithCDS false
|
|
|
|
*/
|
|
|
|
|
2021-09-28 06:23:47 +00:00
|
|
|
import jdk.test.lib.Platform;
|
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
|
|
|
|
|
|
|
public class TestSerialGCWithCDS {
|
|
|
|
public final static String HELLO = "Hello World";
|
|
|
|
static String helloJar;
|
2022-12-01 19:59:14 +00:00
|
|
|
static boolean useCompressedOops = true;
|
2021-09-28 06:23:47 +00:00
|
|
|
|
|
|
|
public static void main(String... args) throws Exception {
|
|
|
|
helloJar = JarBuilder.build("hello", "Hello");
|
|
|
|
|
2022-12-01 19:59:14 +00:00
|
|
|
if (args.length > 0 && args[0].equals("false")) {
|
|
|
|
useCompressedOops = false;
|
|
|
|
}
|
|
|
|
|
2021-09-28 06:23:47 +00:00
|
|
|
// Check if we can use SerialGC during dump time, or run time, or both.
|
|
|
|
test(false, true);
|
|
|
|
test(true, false);
|
|
|
|
test(true, true);
|
|
|
|
|
|
|
|
// We usually have 2 heap regions. To increase test coverage, we can have 3 heap regions
|
|
|
|
// by using "-Xmx256m -XX:ObjectAlignmentInBytes=64"
|
2022-12-01 19:59:14 +00:00
|
|
|
if (Platform.is64bit()) {
|
|
|
|
test(false, true, /*useSmallRegions=*/true);
|
|
|
|
}
|
2021-09-28 06:23:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
final static String G1 = "-XX:+UseG1GC";
|
|
|
|
final static String Serial = "-XX:+UseSerialGC";
|
|
|
|
|
|
|
|
static void test(boolean dumpWithSerial, boolean execWithSerial) throws Exception {
|
|
|
|
test(dumpWithSerial, execWithSerial, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test(boolean dumpWithSerial, boolean execWithSerial, boolean useSmallRegions) throws Exception {
|
2022-12-01 19:59:14 +00:00
|
|
|
String DUMMY = "-showversion"; // A harmless option that doesn't doesn't do anything except for printing out the version
|
2021-09-28 06:23:47 +00:00
|
|
|
String dumpGC = dumpWithSerial ? Serial : G1;
|
|
|
|
String execGC = execWithSerial ? Serial : G1;
|
2022-12-01 19:59:14 +00:00
|
|
|
String small1 = useSmallRegions ? "-Xmx256m" : DUMMY;
|
|
|
|
String small2 = useSmallRegions ? "-XX:ObjectAlignmentInBytes=64" : DUMMY;
|
|
|
|
String coops;
|
|
|
|
if (Platform.is64bit()) {
|
|
|
|
coops = useCompressedOops ? "-XX:+UseCompressedOops" : "-XX:-UseCompressedOops";
|
|
|
|
} else {
|
|
|
|
coops = DUMMY;
|
|
|
|
}
|
2021-09-28 06:23:47 +00:00
|
|
|
OutputAnalyzer out;
|
|
|
|
|
|
|
|
System.out.println("0. Dump with " + dumpGC);
|
|
|
|
out = TestCommon.dump(helloJar,
|
|
|
|
new String[] {"Hello"},
|
|
|
|
dumpGC,
|
|
|
|
small1,
|
|
|
|
small2,
|
2022-12-01 19:59:14 +00:00
|
|
|
coops,
|
2021-09-28 06:23:47 +00:00
|
|
|
"-Xlog:cds");
|
|
|
|
out.shouldContain("Dumping shared data to file:");
|
|
|
|
out.shouldHaveExitValue(0);
|
|
|
|
|
|
|
|
System.out.println("1. Exec with " + execGC);
|
|
|
|
out = TestCommon.exec(helloJar,
|
|
|
|
execGC,
|
|
|
|
small1,
|
|
|
|
small2,
|
2022-12-01 19:59:14 +00:00
|
|
|
coops,
|
2021-09-28 06:23:47 +00:00
|
|
|
"-Xlog:cds",
|
|
|
|
"Hello");
|
2022-12-01 19:59:14 +00:00
|
|
|
checkExecOutput(dumpWithSerial, execWithSerial, out);
|
2021-09-28 06:23:47 +00:00
|
|
|
|
2022-10-19 04:57:56 +00:00
|
|
|
System.out.println("2. Exec with " + execGC + " and test ArchiveRelocationMode");
|
|
|
|
out = TestCommon.exec(helloJar,
|
|
|
|
execGC,
|
|
|
|
small1,
|
|
|
|
small2,
|
2022-12-01 19:59:14 +00:00
|
|
|
coops,
|
2022-10-19 04:57:56 +00:00
|
|
|
"-Xlog:cds,cds+heap",
|
|
|
|
"-XX:ArchiveRelocationMode=1", // always relocate shared metadata
|
|
|
|
"Hello");
|
2022-12-01 19:59:14 +00:00
|
|
|
checkExecOutput(dumpWithSerial, execWithSerial, out);
|
2022-10-19 04:57:56 +00:00
|
|
|
|
2021-09-28 06:23:47 +00:00
|
|
|
int n = 2;
|
|
|
|
if (dumpWithSerial == false && execWithSerial == true) {
|
|
|
|
// We dumped with G1, so we have an archived heap. At exec time, try to load them into
|
|
|
|
// a small SerialGC heap that may be too small.
|
|
|
|
String[] sizes = {
|
|
|
|
"4m", // usually this will success load the archived heap
|
2021-10-07 12:42:16 +00:00
|
|
|
"2m", // usually this will fail to load the archived heap, but app can launch
|
|
|
|
// or fail with "GC triggered before VM initialization completed"
|
2021-09-28 06:23:47 +00:00
|
|
|
"1m" // usually this will cause VM launch to fail with "Too small maximum heap"
|
|
|
|
};
|
|
|
|
for (String sz : sizes) {
|
|
|
|
String xmx = "-Xmx" + sz;
|
|
|
|
System.out.println("=======\n" + n + ". Exec with " + execGC + " " + xmx);
|
|
|
|
out = TestCommon.exec(helloJar,
|
|
|
|
execGC,
|
|
|
|
small1,
|
|
|
|
small2,
|
|
|
|
xmx,
|
2022-12-01 19:59:14 +00:00
|
|
|
coops,
|
2021-09-28 06:23:47 +00:00
|
|
|
"-Xlog:cds",
|
|
|
|
"Hello");
|
|
|
|
if (out.getExitValue() == 0) {
|
2022-12-01 19:59:14 +00:00
|
|
|
checkExecOutput(dumpWithSerial, execWithSerial, out);
|
2021-09-28 06:23:47 +00:00
|
|
|
} else {
|
2021-10-07 12:42:16 +00:00
|
|
|
String output = out.getStdout() + out.getStderr();
|
|
|
|
String exp1 = "Too small maximum heap";
|
|
|
|
String exp2 = "GC triggered before VM initialization completed";
|
|
|
|
if (!output.contains(exp1) && !output.contains(exp2)) {
|
|
|
|
throw new RuntimeException("Either '" + exp1 + "' or '" + exp2 + "' must be in stdout/stderr \n");
|
|
|
|
}
|
2021-09-28 06:23:47 +00:00
|
|
|
}
|
|
|
|
n++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-12-01 19:59:14 +00:00
|
|
|
|
|
|
|
static void checkExecOutput(boolean dumpWithSerial, boolean execWithSerial, OutputAnalyzer out) {
|
|
|
|
String errMsg = "Cannot use CDS heap data. UseG1GC is required for -XX:-UseCompressedOops";
|
|
|
|
if (Platform.is64bit() &&
|
|
|
|
!Platform.isWindows() && // archive heap not supported on Windows.
|
|
|
|
!dumpWithSerial && // Dumped with G1, so we have an archived heap
|
|
|
|
execWithSerial && // Running with serial
|
|
|
|
!useCompressedOops) { // ArchiveHeapLoader::can_load() always returns false when COOP is disabled
|
|
|
|
out.shouldContain(errMsg);
|
|
|
|
}
|
|
|
|
if (!execWithSerial) {
|
|
|
|
// We should never see this message with G1
|
|
|
|
out.shouldNotContain(errMsg);
|
|
|
|
}
|
|
|
|
}
|
2021-09-28 06:23:47 +00:00
|
|
|
}
|