test/hotspot/jtreg/compiler/whitebox/OSRFailureLevel4Test.java
author iignatyev
Wed, 13 Nov 2019 11:34:31 -0800
changeset 59064 f1a5d48d0471
parent 55206 2fe2063fe567
permissions -rw-r--r--
8226795: compiler/tiered/Level2RecompilationTest.java fails when XX:TieredStopAtLevel=1/2/3 is set Reviewed-by: redestad
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
55206
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     1
/*
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     2
 * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     4
 *
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     7
 * published by the Free Software Foundation.
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     8
 *
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    13
 * accompanied this code).
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    14
 *
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    18
 *
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    21
 * questions.
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    22
 */
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    23
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    24
/*
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    25
 * @test OSRFailureLevel4Test
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    26
 * @summary check that not compilable OSR level 4 results in falling back to level 1
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    27
 * @library /test/lib /
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    28
 * @modules java.base/jdk.internal.misc
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    29
 *          java.management
59064
f1a5d48d0471 8226795: compiler/tiered/Level2RecompilationTest.java fails when XX:TieredStopAtLevel=1/2/3 is set
iignatyev
parents: 55206
diff changeset
    30
 *
f1a5d48d0471 8226795: compiler/tiered/Level2RecompilationTest.java fails when XX:TieredStopAtLevel=1/2/3 is set
iignatyev
parents: 55206
diff changeset
    31
 * @comment the test can't be run w/ TieredStopAtLevel < 4
f1a5d48d0471 8226795: compiler/tiered/Level2RecompilationTest.java fails when XX:TieredStopAtLevel=1/2/3 is set
iignatyev
parents: 55206
diff changeset
    32
 * @requires vm.flavor == "server" & (vm.opt.TieredStopAtLevel == null | vm.opt.TieredStopAtLevel == 4)
f1a5d48d0471 8226795: compiler/tiered/Level2RecompilationTest.java fails when XX:TieredStopAtLevel=1/2/3 is set
iignatyev
parents: 55206
diff changeset
    33
 *
55206
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    34
 * @build sun.hotspot.WhiteBox
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    35
 * @run driver ClassFileInstaller sun.hotspot.WhiteBox
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    36
 *                                sun.hotspot.WhiteBox$WhiteBoxPermission
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    37
 * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    38
 *                   -XX:+WhiteBoxAPI -XX:+TieredCompilation compiler.whitebox.OSRFailureLevel4Test
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    39
 */
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    40
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    41
package compiler.whitebox;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    42
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    43
import sun.hotspot.WhiteBox;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    44
import java.lang.reflect.Executable;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    45
import java.lang.reflect.Method;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    46
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    47
public class OSRFailureLevel4Test extends Thread {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    48
    private static final WhiteBox WHITE_BOX = WhiteBox.getWhiteBox();
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    49
    private static final long BACKEDGE_THRESHOLD = 150000;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    50
    private Method method;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    51
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    52
    public static void main(String[] args) throws Exception {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    53
        OSRFailureLevel4Test test = new OSRFailureLevel4Test();
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    54
        test.test();
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    55
    }
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    56
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    57
    /**
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    58
     * Triggers two different OSR compilations for the same method and
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    59
     * checks if WhiteBox.deoptimizeMethod() deoptimizes both.
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    60
     *
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    61
     * @throws Exception
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    62
     */
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    63
    public void test() throws Exception {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    64
        method = OSRFailureLevel4Test.class.getDeclaredMethod("run");
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    65
        WHITE_BOX.makeMethodNotCompilable(method, 4, true);
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    66
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    67
        Thread t = new OSRFailureLevel4Test();
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    68
        t.setDaemon(true);
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    69
        t.start();
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    70
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    71
        int currentLevel = 0;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    72
        int loops = 0;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    73
        while (true) {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    74
            int level = WHITE_BOX.getMethodCompilationLevel(method, true);
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    75
            if (level == 1) {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    76
                System.err.println("success");
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    77
                running = false;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    78
                return;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    79
            }
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    80
            if (level == currentLevel) {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    81
                Thread.sleep(1000);
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    82
                loops++;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    83
                if (loops > 100) {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    84
                    running = false;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    85
                    throw new AssertionError("Never reached level 1");
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    86
                }
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    87
                continue;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    88
            }
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    89
            currentLevel = level;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    90
            System.err.println("Current level = " + currentLevel);
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    91
        }
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    92
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    93
    }
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    94
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    95
    static volatile int counter = 0;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    96
    static boolean running = true;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    97
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    98
    public void run() {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
    99
        while (running) {
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
   100
            counter++;
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
   101
        }
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
   102
    }
2fe2063fe567 8225019: Update JVMCI
kvn
parents:
diff changeset
   103
}