test/hotspot/jtreg/serviceability/jvmti/GetOwnedMonitorInfo/GetOwnedMonitorInfoWithEATest.java
author chegar
Thu, 17 Oct 2019 20:53:35 +0100
branchdatagramsocketimpl-branch
changeset 58678 9cf78a70fa4f
child 58679 9c3209ff7550
permissions -rw-r--r--
datagramsocketimpl-branch: update to default
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
58678
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     1
/*
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     2
 * Copyright (c) 2019 SAP SE. All rights reserved.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     4
 *
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     7
 * published by the Free Software Foundation.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     8
 *
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    13
 * accompanied this code).
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    14
 *
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    18
 *
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    21
 * questions.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    22
 */
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    23
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    24
/**
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    25
 * @test
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    26
 * @bug 8230677
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    27
 * @summary Test JVMTI's GetOwnedMonitorInfo with scalar replaced objects and eliminated locks on stack (optimizations based on escape analysis).
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    28
 * @comment Without RFE 8227745 escape analysis needs to be switched off to pass the test. For the implementation of RFE 8227745 it serves as a regression test.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    29
 * @requires (vm.compMode != "Xcomp" & vm.compiler2.enabled)
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    30
 * @library /test/lib
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    31
 * @compile GetOwnedMonitorInfoWithEATest.java
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    32
 * @run main/othervm/native
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    33
 *                  -agentlib:GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    34
 *                  -XX:+UnlockDiagnosticVMOptions
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    35
 *                  -Xms128m -Xmx128m
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    36
 *                  -XX:CompileCommand=dontinline,*::dontinline_*
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    37
 *                  -XX:+PrintCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    38
 *                  -XX:+PrintInlining
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    39
 *                  -XX:-TieredCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    40
 *                  -Xbatch
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    41
 *                  -XX:CICompilerCount=1
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    42
 *                  -XX:+DoEscapeAnalysis -XX:+EliminateAllocations -XX:+EliminateLocks -XX:+EliminateNestedLocks -XX:+UseBiasedLocking
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    43
 *                  GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    44
 * @run main/othervm/native
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    45
 *                  -agentlib:GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    46
 *                  -XX:+UnlockDiagnosticVMOptions
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    47
 *                  -Xms128m -Xmx128m
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    48
 *                  -XX:CompileCommand=dontinline,*::dontinline_*
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    49
 *                  -XX:+PrintCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    50
 *                  -XX:+PrintInlining
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    51
 *                  -XX:-TieredCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    52
 *                  -Xbatch
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    53
 *                  -XX:CICompilerCount=1
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    54
 *                  -XX:+DoEscapeAnalysis -XX:+EliminateAllocations -XX:-EliminateLocks -XX:+EliminateNestedLocks -XX:+UseBiasedLocking -XX:-UseOptoBiasInlining
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    55
 *                  GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    56
 * @run main/othervm/native
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    57
 *                  -agentlib:GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    58
 *                  -XX:+UnlockDiagnosticVMOptions
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    59
 *                  -Xms128m -Xmx128m
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    60
 *                  -XX:CompileCommand=dontinline,*::dontinline_*
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    61
 *                  -XX:+PrintCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    62
 *                  -XX:+PrintInlining
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    63
 *                  -XX:-TieredCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    64
 *                  -Xbatch
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    65
 *                  -XX:CICompilerCount=1
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    66
 *                  -XX:+DoEscapeAnalysis -XX:-EliminateAllocations -XX:+EliminateLocks -XX:+EliminateNestedLocks -XX:+UseBiasedLocking
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    67
 *                  GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    68
 * @run main/othervm/native
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    69
 *                  -agentlib:GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    70
 *                  -XX:+UnlockDiagnosticVMOptions
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    71
 *                  -Xms128m -Xmx128m
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    72
 *                  -XX:CompileCommand=dontinline,*::dontinline_*
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    73
 *                  -XX:+PrintCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    74
 *                  -XX:+PrintInlining
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    75
 *                  -XX:-TieredCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    76
 *                  -Xbatch
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    77
 *                  -XX:CICompilerCount=1
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    78
 *                  -XX:-DoEscapeAnalysis -XX:-EliminateAllocations -XX:+EliminateLocks -XX:+EliminateNestedLocks -XX:+UseBiasedLocking
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    79
 *                  GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    80
 * @run main/othervm/native
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    81
 *                  -agentlib:GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    82
 *                  -XX:+UnlockDiagnosticVMOptions
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    83
 *                  -Xms128m -Xmx128m
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    84
 *                  -XX:CompileCommand=dontinline,*::dontinline_*
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    85
 *                  -XX:+PrintCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    86
 *                  -XX:+PrintInlining
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    87
 *                  -XX:-TieredCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    88
 *                  -Xbatch
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    89
 *                  -XX:CICompilerCount=1
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    90
 *                  -XX:+DoEscapeAnalysis -XX:+EliminateAllocations -XX:+EliminateLocks -XX:+EliminateNestedLocks -XX:-UseBiasedLocking
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    91
 *                  GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    92
 * @run main/othervm/native
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    93
 *                  -agentlib:GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    94
 *                  -XX:+UnlockDiagnosticVMOptions
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    95
 *                  -Xms128m -Xmx128m
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    96
 *                  -XX:CompileCommand=dontinline,*::dontinline_*
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    97
 *                  -XX:+PrintCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    98
 *                  -XX:+PrintInlining
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
    99
 *                  -XX:-TieredCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   100
 *                  -Xbatch
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   101
 *                  -XX:CICompilerCount=1
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   102
 *                  -XX:+DoEscapeAnalysis -XX:-EliminateAllocations -XX:+EliminateLocks -XX:+EliminateNestedLocks -XX:-UseBiasedLocking
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   103
 *                  GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   104
 * @run main/othervm/native
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   105
 *                  -agentlib:GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   106
 *                  -XX:+UnlockDiagnosticVMOptions
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   107
 *                  -Xms128m -Xmx128m
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   108
 *                  -XX:CompileCommand=dontinline,*::dontinline_*
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   109
 *                  -XX:+PrintCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   110
 *                  -XX:+PrintInlining
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   111
 *                  -XX:-TieredCompilation
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   112
 *                  -Xbatch
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   113
 *                  -XX:CICompilerCount=1
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   114
 *                  -XX:-DoEscapeAnalysis -XX:-EliminateAllocations -XX:+EliminateLocks -XX:+EliminateNestedLocks -XX:-UseBiasedLocking
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   115
 *                  GetOwnedMonitorInfoWithEATest
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   116
 */
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   117
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   118
import jdk.test.lib.Asserts;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   119
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   120
public class GetOwnedMonitorInfoWithEATest {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   121
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   122
    public static final int COMPILE_THRESHOLD = 20000;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   123
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   124
    /**
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   125
     * Native wrapper arround JVMTI's GetOwnedMonitorInfo().
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   126
     * @param t The thread for which the owned monitors information should be retrieved.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   127
     * @param ownedMonitors Array filled in by the call with the objects associated
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   128
     *        with the monitors owned by the given thread.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   129
     * @param depths Per owned monitor the depth of the frame were it was locked.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   130
     *        Filled in by the call
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   131
     * @return Number of monitors owned by the given thread.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   132
     */
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   133
    public static native int getOwnedMonitorInfo(Thread t, Object[] ownedMonitors);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   134
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   135
    public static void main(String[] args) throws Exception {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   136
        new GetOwnedMonitorInfoWithEATest().runTest();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   137
    }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   138
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   139
    public void runTest() throws Exception {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   140
        new TestCase_1().run();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   141
        new TestCase_2().run();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   142
    }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   143
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   144
    public static abstract class TestCaseBase implements Runnable {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   145
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   146
        public long checkSum;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   147
        public boolean doLoop;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   148
        public volatile long loopCount;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   149
        public volatile boolean targetIsInLoop;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   150
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   151
        public void run() {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   152
            try {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   153
                msgHL("Executing test case " + getClass().getName());
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   154
                warmUp();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   155
                runTest();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   156
            } catch (Exception e) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   157
                Asserts.fail("Unexpected Exception", e);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   158
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   159
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   160
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   161
        public void warmUp() {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   162
            int callCount = COMPILE_THRESHOLD + 1000;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   163
            doLoop = true;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   164
            while (callCount-- > 0) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   165
                dontinline_testMethod();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   166
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   167
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   168
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   169
        public abstract void runTest() throws Exception;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   170
        public abstract void dontinline_testMethod();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   171
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   172
        public long dontinline_endlessLoop() {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   173
            long cs = checkSum;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   174
            while (doLoop && loopCount-- > 0) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   175
                targetIsInLoop = true;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   176
                checkSum += checkSum % ++cs;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   177
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   178
            loopCount = 3;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   179
            targetIsInLoop = false;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   180
            return checkSum;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   181
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   182
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   183
        public void waitUntilTargetThreadHasEnteredEndlessLoop() throws Exception {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   184
            while(!targetIsInLoop) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   185
                msg("Target has not yet entered the loop. Sleep 200ms.");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   186
                try { Thread.sleep(200); } catch (InterruptedException e) { /*ignore */ }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   187
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   188
            msg("Target has entered the loop.");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   189
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   190
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   191
        public void terminateEndlessLoop() throws Exception {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   192
            msg("Terminate endless loop");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   193
            do {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   194
                doLoop = false;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   195
            } while(targetIsInLoop);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   196
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   197
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   198
        public void msg(String m) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   199
            System.out.println();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   200
            System.out.println("### " + m);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   201
            System.out.println();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   202
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   203
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   204
        public void msgHL(String m) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   205
            System.out.println();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   206
            System.out.println("#####################################################");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   207
            System.out.println("### " + m);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   208
            System.out.println("###");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   209
            System.out.println();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   210
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   211
    }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   212
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   213
    /**
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   214
     * Starts target thread T and then queries monitor information for T using JVMTI's GetOwnedMonitorInfo().
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   215
     * With escape analysis enabled the jit compiled method {@link #dontinline_testMethod()} has
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   216
     * scalar replaced objects with eliminated (nested) locking in scope when the monitor
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   217
     * information is retrieved. Effectively the objects escape through the JVMTI call. This works
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   218
     * only with RFE 8227745. Without it escape analysis needs to be disabled.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   219
     */
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   220
    public static class TestCase_1 extends TestCaseBase {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   221
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   222
        public void runTest() throws Exception {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   223
            loopCount = 1L << 62; // endless loop
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   224
            Thread t1 = new Thread(() -> dontinline_testMethod(), "Target Thread");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   225
            t1.start();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   226
            try {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   227
                waitUntilTargetThreadHasEnteredEndlessLoop();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   228
                int expectedMonitorCount = 1;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   229
                int resultSize = expectedMonitorCount + 3;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   230
                Object[] ownedMonitors = new Object[resultSize];
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   231
                msg("Get monitor info");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   232
                int monitorCount = getOwnedMonitorInfo(t1, ownedMonitors);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   233
                terminateEndlessLoop();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   234
                t1.join();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   235
                Asserts.assertGreaterThanOrEqual(monitorCount, 0, "getOwnedMonitorsFor() call failed");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   236
                msg("Monitor info:");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   237
                for (int i = 0; i < monitorCount; i++) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   238
                    System.out.println(i + ": cls=" + (ownedMonitors[i] != null ? ownedMonitors[i].getClass() : null));
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   239
                }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   240
                Asserts.assertEQ(monitorCount, expectedMonitorCount, "unexpected monitor count returned by getOwnedMonitorsFor()");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   241
                Asserts.assertNotNull(ownedMonitors[0]);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   242
                Asserts.assertSame(ownedMonitors[0].getClass(), LockCls.class);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   243
            } finally {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   244
                terminateEndlessLoop();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   245
                t1.join();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   246
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   247
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   248
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   249
        public void dontinline_testMethod() {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   250
            LockCls l1 = new LockCls();        // to be scalar replaced
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   251
            synchronized (l1) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   252
                inlinedTestMethodWithNestedLocking(l1);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   253
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   254
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   255
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   256
        public void inlinedTestMethodWithNestedLocking(LockCls l1) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   257
            synchronized (l1) {              // nested
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   258
                dontinline_endlessLoop();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   259
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   260
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   261
    }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   262
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   263
    /**
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   264
     * Similar to {@link TestCase_1}. Additionally the target thread T has got eliminated locking
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   265
     * for a synchronized method of a different type {@linkplain LockCls2}.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   266
     */
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   267
    public static class TestCase_2 extends TestCaseBase {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   268
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   269
        public void runTest() throws Exception {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   270
            loopCount = 1L << 62; // endless loop
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   271
            Thread t1 = new Thread(() -> dontinline_testMethod(), "Target Thread");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   272
            t1.start();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   273
            try {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   274
                waitUntilTargetThreadHasEnteredEndlessLoop();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   275
                int expectedMonitorCount = 2;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   276
                int resultSize = expectedMonitorCount + 3;
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   277
                Object[] ownedMonitors = new Object[resultSize];
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   278
                msg("Get monitor info");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   279
                int monitorCount = getOwnedMonitorInfo(t1, ownedMonitors);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   280
                terminateEndlessLoop();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   281
                t1.join();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   282
                Asserts.assertGreaterThanOrEqual(monitorCount, 0, "getOwnedMonitorsFor() call failed");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   283
                msg("Monitor info:");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   284
                for (int i = 0; i < monitorCount; i++) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   285
                    System.out.println(i + ": cls=" + (ownedMonitors[i] != null ? ownedMonitors[i].getClass() : null));
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   286
                }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   287
                Asserts.assertEQ(monitorCount, expectedMonitorCount, "unexpected monitor count returned by getOwnedMonitorsFor()");
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   288
                Asserts.assertNotNull(ownedMonitors[0]);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   289
                Asserts.assertSame(ownedMonitors[0].getClass(), LockCls2.class);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   290
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   291
                Asserts.assertNotNull(ownedMonitors[1]);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   292
                Asserts.assertSame(ownedMonitors[1].getClass(), LockCls.class);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   293
            } finally {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   294
                terminateEndlessLoop();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   295
                t1.join();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   296
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   297
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   298
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   299
        public void dontinline_testMethod() {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   300
            LockCls l1 = new LockCls();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   301
            synchronized (l1) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   302
                inlinedTestMethodWithNestedLocking(l1);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   303
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   304
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   305
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   306
        public void inlinedTestMethodWithNestedLocking(LockCls l1) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   307
            synchronized (l1) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   308
                dontinline_testMethod2();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   309
            }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   310
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   311
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   312
        public void dontinline_testMethod2() {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   313
            // Call synchronized method. Receiver of the call will be scalar replaced,
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   314
            // and locking will be eliminated. Here we use a different type.
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   315
            new LockCls2().inline_synchronized_testMethod(this);
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   316
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   317
    }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   318
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   319
    public static class LockCls {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   320
    }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   321
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   322
    public static class LockCls2 {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   323
        public synchronized void inline_synchronized_testMethod(TestCaseBase testCase) {
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   324
            testCase.dontinline_endlessLoop();
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   325
        }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   326
    }
9cf78a70fa4f datagramsocketimpl-branch: update to default
chegar
parents:
diff changeset
   327
}