From 4a49bb628452bf6470feb145ed927407b3016105 Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Wed, 19 Oct 2016 10:10:51 +0300 Subject: [PATCH 1/2] 8155570: serviceability/tmtools/jstat/GcTest02.java fails with parallel GC Reviewed-by: jwilhelm --- hotspot/test/serviceability/tmtools/jstat/GcTest02.java | 1 - .../tmtools/jstat/utils/GcProvokerImpl.java | 8 +++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/hotspot/test/serviceability/tmtools/jstat/GcTest02.java b/hotspot/test/serviceability/tmtools/jstat/GcTest02.java index 0c022358edc..bebabc6ef51 100644 --- a/hotspot/test/serviceability/tmtools/jstat/GcTest02.java +++ b/hotspot/test/serviceability/tmtools/jstat/GcTest02.java @@ -31,7 +31,6 @@ import utils.*; * @modules java.base/jdk.internal.misc * @library /test/lib * @library ../share - * @ignore 8155570 * @run main/othervm -XX:+UsePerfData -Xmx128M -XX:MaxMetaspaceSize=128M GcTest02 */ diff --git a/hotspot/test/serviceability/tmtools/jstat/utils/GcProvokerImpl.java b/hotspot/test/serviceability/tmtools/jstat/utils/GcProvokerImpl.java index f04cdf6a375..565d86cf377 100644 --- a/hotspot/test/serviceability/tmtools/jstat/utils/GcProvokerImpl.java +++ b/hotspot/test/serviceability/tmtools/jstat/utils/GcProvokerImpl.java @@ -50,7 +50,7 @@ public class GcProvokerImpl implements GcProvoker { used += memoryChunk; } catch (OutOfMemoryError e) { list = null; - throw new RuntimeException("Unexpected OOME while eating " + targetUsage + " of heap memory."); + throw new RuntimeException("Unexpected OOME '" + e.getMessage() + "' while eating " + targetUsage + " of heap memory."); } } return list; @@ -73,8 +73,10 @@ public class GcProvokerImpl implements GcProvoker { @Override public void eatMetaspaceAndHeap(float targetMemoryUsagePercent) { - eatenMemory = eatHeapMemory(targetMemoryUsagePercent); + // Metaspace should be filled before Java Heap to prevent unexpected OOME + // in the Java Heap while filling Metaspace eatenMetaspace = eatMetaspace(targetMemoryUsagePercent); + eatenMemory = eatHeapMemory(targetMemoryUsagePercent); } private static List eatMetaspace(float targetUsage) { @@ -97,7 +99,7 @@ public class GcProvokerImpl implements GcProvoker { list.add(gp.create(0)); } catch (OutOfMemoryError oome) { list = null; - throw new RuntimeException("Unexpected OOME while eating " + targetUsage + " of Metaspace."); + throw new RuntimeException("Unexpected OOME '" + oome.getMessage() + "' while eating " + targetUsage + " of Metaspace."); } MemoryUsage memoryUsage = metaspacePool.getUsage(); currentUsage = (((float) memoryUsage.getUsed()) / memoryUsage.getMax()); From 3057feeecb7dfdb836f610b64cab98cee15b4f37 Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Wed, 19 Oct 2016 10:06:55 +0300 Subject: [PATCH 2/2] 8166724: gc/g1/TestHumongousShrinkHeap.java fails with OOME Reviewed-by: dfazunen, jwilhelm --- .../test/gc/g1/TestHumongousShrinkHeap.java | 26 ++++++++++++------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/hotspot/test/gc/g1/TestHumongousShrinkHeap.java b/hotspot/test/gc/g1/TestHumongousShrinkHeap.java index 53bcbe077b8..47ea9450988 100644 --- a/hotspot/test/gc/g1/TestHumongousShrinkHeap.java +++ b/hotspot/test/gc/g1/TestHumongousShrinkHeap.java @@ -51,23 +51,29 @@ public class TestHumongousShrinkHeap { private static final int REGION_SIZE = 1024 * 1024; // 1M private static final int LISTS_COUNT = 10; private static final int HUMON_SIZE = Math.round(.9f * REGION_SIZE); - private static final long AVAILABLE_MEMORY - = Runtime.getRuntime().freeMemory(); - private static final int HUMON_COUNT - = (int) ((AVAILABLE_MEMORY / HUMON_SIZE) - / LISTS_COUNT); + private static final long TOTAL_MEMORY = Runtime.getRuntime().totalMemory(); + private static final long MAX_MEMORY = Runtime.getRuntime().maxMemory(); + + private static final int HUMON_COUNT = (int) ((TOTAL_MEMORY / HUMON_SIZE) / LISTS_COUNT); public static void main(String[] args) { if (HUMON_COUNT == 0) { System.out.println("Skipped. Heap is too small"); return; } - System.out.format("Running with %s max heap size. " - + "Will allocate humongous object of %s size %d times.%n", - MemoryUsagePrinter.humanReadableByteCount(AVAILABLE_MEMORY, false), - MemoryUsagePrinter.humanReadableByteCount(HUMON_SIZE, false), - HUMON_COUNT + + if (TOTAL_MEMORY + REGION_SIZE * HUMON_COUNT > MAX_MEMORY) { + System.out.println("Skipped. Initial heap size is to close to max heap size."); + return; + } + + System.out.format("Running with %s initial heap size of %s maximum heap size. " + + "Will allocate humongous object of %s size %d times.%n", + MemoryUsagePrinter.humanReadableByteCount(TOTAL_MEMORY, false), + MemoryUsagePrinter.humanReadableByteCount(MAX_MEMORY, false), + MemoryUsagePrinter.humanReadableByteCount(HUMON_SIZE, false), + HUMON_COUNT ); new TestHumongousShrinkHeap().test(); }