hotspot/test/gc/g1/TestEagerReclaimHumongousRegionsWithRefs.java
author tschatzl
Wed, 07 Jan 2015 15:15:37 +0100
changeset 28379 e6784fc8fff2
child 29678 dd2f3932c21e
permissions -rw-r--r--
8048179: Early reclaim of large objects that are referenced by a few objects Summary: Push the remembered sets of large objects with few referenced into the dirty card queue at the beginning of the evacuation so that they may end up with zero remembered set entries at the end of the collection, and are potentially reclaimed. Also improve timing measurements of the early reclaim mechanism, and shorten flag names. Reviewed-by: brutisso, jmasa, dfazunen
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28379
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     1
/*
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     2
 * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     4
 *
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     7
 * published by the Free Software Foundation.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     8
 *
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    13
 * accompanied this code).
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    14
 *
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    18
 *
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    21
 * questions.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    22
 */
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    23
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    24
/*
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    25
 * @test TestEagerReclaimHumongousRegionsWithRefs
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    26
 * @bug 8048179
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    27
 * @summary Test to make sure that eager reclaim of humongous objects that have previously
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    28
 * been referenced by other old gen regions work. We simply try to fill
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    29
 * up the heap with humongous objects and create a remembered set entry from an object by
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    30
 * referencing that we know is in the old gen. After changing this reference, the object
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    31
 * should still be eagerly reclaimable to avoid Full GC.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    32
 * @key gc
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    33
 * @library /testlibrary
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    34
 */
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    35
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    36
import java.util.regex.Pattern;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    37
import java.util.regex.Matcher;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    38
import java.util.LinkedList;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    39
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    40
import com.oracle.java.testlibrary.OutputAnalyzer;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    41
import com.oracle.java.testlibrary.ProcessTools;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    42
import static com.oracle.java.testlibrary.Asserts.*;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    43
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    44
class RefHolder {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    45
  Object ref;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    46
}
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    47
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    48
class ReclaimRegionFast {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    49
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    50
    public static final int M = 1024*1024;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    51
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    52
    public static LinkedList<Object> garbageList = new LinkedList<Object>();
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    53
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    54
    public static void genGarbage() {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    55
        for (int i = 0; i < 32*1024; i++) {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    56
            garbageList.add(new int[100]);
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    57
        }
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    58
        garbageList.clear();
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    59
    }
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    60
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    61
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    62
    // A large object referenced by a static.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    63
    static int[] filler = new int[10 * M];
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    64
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    65
    // Old gen object referencing the large object, generating remembered
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    66
    // set entries.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    67
    static RefHolder fromOld = new RefHolder();
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    68
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    69
    public static void main(String[] args) {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    70
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    71
        int[] large = new int[M];
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    72
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    73
        Object ref_from_stack = large;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    74
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    75
        for (int i = 0; i < 100; i++) {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    76
            // A large object that will be reclaimed eagerly.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    77
            large = new int[6*M];
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    78
            fromOld.ref = large;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    79
            genGarbage();
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    80
        }
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    81
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    82
        // Keep the reference to the first object alive.
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    83
        System.out.println(ref_from_stack);
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    84
    }
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    85
}
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    86
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    87
public class TestEagerReclaimHumongousRegionsWithRefs {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    88
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    89
    public static void main(String[] args) throws Exception {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    90
        ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    91
            "-XX:+UseG1GC",
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    92
            "-Xms128M",
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    93
            "-Xmx128M",
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    94
            "-Xmn16M",
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    95
            "-XX:+PrintGC",
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    96
            ReclaimRegionFast.class.getName());
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    97
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    98
        Pattern p = Pattern.compile("Full GC");
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
    99
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   100
        OutputAnalyzer output = new OutputAnalyzer(pb.start());
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   101
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   102
        int found = 0;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   103
        Matcher m = p.matcher(output.getStdout());
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   104
        while (m.find()) {
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   105
            found++;
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   106
        }
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   107
        System.out.println("Issued " + found + " Full GCs");
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   108
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   109
        assertLessThan(found, 10, "Found that " + found + " Full GCs were issued. This is larger than the bound. Eager reclaim of objects once referenced from old gen seems to not work at all");
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   110
        output.shouldHaveExitValue(0);
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   111
    }
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   112
}
e6784fc8fff2 8048179: Early reclaim of large objects that are referenced by a few objects
tschatzl
parents:
diff changeset
   113