Path: blob/master/test/hotspot/jtreg/gc/shenandoah/TestAllocHumongousFragment.java
40942 views
/*1* Copyright (c) 2016, 2018, Red Hat, Inc. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*22*/2324/*25* @test TestAllocHumongousFragment26* @summary Make sure Shenandoah can recover from humongous allocation fragmentation27* @key randomness28* @requires vm.gc.Shenandoah29* @library /test/lib30*31* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204832* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=passive33* -XX:-ShenandoahDegeneratedGC -XX:+ShenandoahVerify34* TestAllocHumongousFragment35*36* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204837* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=passive38* -XX:+ShenandoahDegeneratedGC -XX:+ShenandoahVerify39* TestAllocHumongousFragment40*41* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204842* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=passive43* -XX:-ShenandoahDegeneratedGC44* TestAllocHumongousFragment45*46* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204847* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=passive48* -XX:+ShenandoahDegeneratedGC49* TestAllocHumongousFragment50*/5152/*53* @test TestAllocHumongousFragment54* @summary Make sure Shenandoah can recover from humongous allocation fragmentation55* @key randomness56* @requires vm.gc.Shenandoah57* @library /test/lib58*59* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204860* -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=aggressive61* -XX:+ShenandoahOOMDuringEvacALot -XX:+ShenandoahVerify62* TestAllocHumongousFragment63*64* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204865* -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=aggressive66* -XX:+ShenandoahAllocFailureALot -XX:+ShenandoahVerify67* TestAllocHumongousFragment68*69* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204870* -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=aggressive71* -XX:+ShenandoahOOMDuringEvacALot72* TestAllocHumongousFragment73*74* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204875* -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=aggressive76* -XX:+ShenandoahAllocFailureALot77* TestAllocHumongousFragment78*/7980/*81* @test TestAllocHumongousFragment82* @summary Make sure Shenandoah can recover from humongous allocation fragmentation83* @key randomness84* @requires vm.gc.Shenandoah85* @library /test/lib86*87* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204888* -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=adaptive89* -XX:+ShenandoahVerify90* TestAllocHumongousFragment91*92* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=204893* -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=adaptive94* TestAllocHumongousFragment95*/9697/*98* @test TestAllocHumongousFragment99* @summary Make sure Shenandoah can recover from humongous allocation fragmentation100* @key randomness101* @requires vm.gc.Shenandoah102* @library /test/lib103*104* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=2048105* -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=static106* TestAllocHumongousFragment107*/108109/*110* @test TestAllocHumongousFragment111* @summary Make sure Shenandoah can recover from humongous allocation fragmentation112* @key randomness113* @requires vm.gc.Shenandoah114* @library /test/lib115*116* @run main/othervm -Xmx1g -Xms1g -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:ShenandoahTargetNumRegions=2048117* -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=compact118* TestAllocHumongousFragment119*/120121/*122* @test TestAllocHumongousFragment123* @summary Make sure Shenandoah can recover from humongous allocation fragmentation124* @key randomness125* @requires vm.gc.Shenandoah126* @library /test/lib127*128* @run main/othervm -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -Xmx1g -Xms1g -XX:ShenandoahTargetNumRegions=2048129* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu -XX:ShenandoahGCHeuristics=aggressive130* -XX:+ShenandoahOOMDuringEvacALot -XX:+ShenandoahVerify131* TestAllocHumongousFragment132*133* @run main/othervm -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -Xmx1g -Xms1g -XX:ShenandoahTargetNumRegions=2048134* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu -XX:ShenandoahGCHeuristics=aggressive135* -XX:+ShenandoahAllocFailureALot -XX:+ShenandoahVerify136* TestAllocHumongousFragment137*138* @run main/othervm -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -Xmx1g -Xms1g -XX:ShenandoahTargetNumRegions=2048139* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu -XX:ShenandoahGCHeuristics=aggressive140* -XX:+ShenandoahOOMDuringEvacALot141* TestAllocHumongousFragment142*143* @run main/othervm -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -Xmx1g -Xms1g -XX:ShenandoahTargetNumRegions=2048144* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu -XX:ShenandoahGCHeuristics=aggressive145* -XX:+ShenandoahAllocFailureALot146* TestAllocHumongousFragment147*/148149/*150* @test TestAllocHumongousFragment151* @summary Make sure Shenandoah can recover from humongous allocation fragmentation152* @key randomness153* @requires vm.gc.Shenandoah154* @library /test/lib155*156* @run main/othervm -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -Xmx1g -Xms1g -XX:ShenandoahTargetNumRegions=2048157* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu158* -XX:+ShenandoahVerify159* TestAllocHumongousFragment160*161* @run main/othervm -Xlog:gc -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -Xmx1g -Xms1g -XX:ShenandoahTargetNumRegions=2048162* -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu163* TestAllocHumongousFragment164*/165166import java.util.*;167import jdk.test.lib.Utils;168169public class TestAllocHumongousFragment {170171static final long TARGET_MB = Long.getLong("target", 30_000); // 30 Gb allocations172static final long LIVE_MB = Long.getLong("occupancy", 700); // 700 Mb alive173174static volatile Object sink;175176static List<int[]> objects;177178public static void main(String[] args) throws Exception {179final int min = 128 * 1024;180final int max = 16 * 1024 * 1024;181final long count = TARGET_MB * 1024 * 1024 / (16 + 4 * (min + (max - min) / 2));182183objects = new ArrayList<>();184long current = 0;185186Random rng = Utils.getRandomInstance();187for (long c = 0; c < count; c++) {188while (current > LIVE_MB * 1024 * 1024) {189int idx = rng.nextInt(objects.size());190int[] remove = objects.remove(idx);191current -= remove.length * 4 + 16;192}193194int[] newObj = new int[min + rng.nextInt(max - min)];195current += newObj.length * 4 + 16;196objects.add(newObj);197sink = new Object();198199System.out.println("Allocated: " + (current / 1024 / 1024) + " Mb");200}201}202203}204205206