From f6a2109bab591aecd2be2534b347cf27e49d7ecd Mon Sep 17 00:00:00 2001 From: Stefan Johansson Date: Wed, 24 Jun 2015 08:37:12 +0200 Subject: [PATCH] 8081607: Change default GC for server configurations to G1 For more info see JEP 248. Reviewed-by: pliden, tschatzl --- hotspot/src/share/vm/runtime/arguments.cpp | 4 ++++ .../test/gc/arguments/TestSelectDefaultGC.java | 17 ++++++++--------- 2 files changed, 12 insertions(+), 9 deletions(-) diff --git a/hotspot/src/share/vm/runtime/arguments.cpp b/hotspot/src/share/vm/runtime/arguments.cpp index ddf37b359db..5d89e91b6a4 100644 --- a/hotspot/src/share/vm/runtime/arguments.cpp +++ b/hotspot/src/share/vm/runtime/arguments.cpp @@ -1535,7 +1535,11 @@ void Arguments::select_gc_ergonomically() { if (should_auto_select_low_pause_collector()) { FLAG_SET_ERGO(bool, UseConcMarkSweepGC, true); } else { +#if defined(JAVASE_EMBEDDED) FLAG_SET_ERGO(bool, UseParallelGC, true); +#else + FLAG_SET_ERGO(bool, UseG1GC, true); +#endif } } else { FLAG_SET_ERGO(bool, UseSerialGC, true); diff --git a/hotspot/test/gc/arguments/TestSelectDefaultGC.java b/hotspot/test/gc/arguments/TestSelectDefaultGC.java index 4311e1f6514..c3c043ce7e3 100644 --- a/hotspot/test/gc/arguments/TestSelectDefaultGC.java +++ b/hotspot/test/gc/arguments/TestSelectDefaultGC.java @@ -36,11 +36,6 @@ import jdk.test.lib.*; import java.util.regex.*; public class TestSelectDefaultGC { - public static boolean versionStringContains(OutputAnalyzer output, String pattern) { - Matcher matcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(output.getStderr()); - return matcher.find(); - } - public static void assertVMOption(OutputAnalyzer output, String option, boolean value) { output.shouldMatch(" " + option + " .*=.* " + value + " "); } @@ -51,14 +46,18 @@ public class TestSelectDefaultGC { OutputAnalyzer output = new OutputAnalyzer(pb.start()); output.shouldHaveExitValue(0); - boolean isServerVM = versionStringContains(output, "Server VM"); + boolean isServerVM = Platform.isServer(); + boolean isEmbeddedVM = Platform.isEmbedded(); // Verify GC selection - assertVMOption(output, "UseParallelGC", isServerVM); - assertVMOption(output, "UseParallelOldGC", isServerVM); + // G1 is default for non-embedded server VMs + assertVMOption(output, "UseG1GC", isServerVM && !isEmbeddedVM); + // Parallel is default for embedded server VMs + assertVMOption(output, "UseParallelGC", isServerVM && isEmbeddedVM); + assertVMOption(output, "UseParallelOldGC", isServerVM && isEmbeddedVM); + // Serial is default for non-server VMs assertVMOption(output, "UseSerialGC", !isServerVM); assertVMOption(output, "UseConcMarkSweepGC", false); - assertVMOption(output, "UseG1GC", false); assertVMOption(output, "UseParNewGC", false); } }