Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/compiler/rtm/locking/TestRTMLockingCalculationDelay.java
41154 views
1
/*
2
* Copyright (c) 2014, 2021, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
6
* under the terms of the GNU General Public License version 2 only, as
7
* published by the Free Software Foundation.
8
*
9
* This code is distributed in the hope that it will be useful, but WITHOUT
10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12
* version 2 for more details (a copy is included in the LICENSE file that
13
* accompanied this code).
14
*
15
* You should have received a copy of the GNU General Public License version
16
* 2 along with this work; if not, write to the Free Software Foundation,
17
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18
*
19
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20
* or visit www.oracle.com if you need additional information or have any
21
* questions.
22
*/
23
24
/**
25
* @test
26
* @bug 8031320
27
* @summary Verify that RTMLockingCalculationDelay affect when
28
* abort ratio calculation is started.
29
* @library /test/lib /
30
* @modules java.base/jdk.internal.misc
31
* java.management
32
* @requires vm.rtm.cpu & vm.rtm.compiler
33
* @build sun.hotspot.WhiteBox
34
* @run driver jdk.test.lib.helpers.ClassFileInstaller sun.hotspot.WhiteBox
35
* @run main/othervm/native -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions
36
* -XX:+WhiteBoxAPI
37
* compiler.rtm.locking.TestRTMLockingCalculationDelay
38
*/
39
40
package compiler.rtm.locking;
41
42
import compiler.testlibrary.rtm.AbortProvoker;
43
import compiler.testlibrary.rtm.AbortType;
44
import compiler.testlibrary.rtm.RTMTestBase;
45
import jdk.test.lib.Asserts;
46
import jdk.test.lib.process.OutputAnalyzer;
47
import jdk.test.lib.cli.CommandLineOptionTest;
48
49
/**
50
* Test verifies that abort ratio calculation could be delayed using
51
* RTMLockingCalculationDelay option.
52
*/
53
public class TestRTMLockingCalculationDelay {
54
private static final boolean INFLATE_MONITOR = true;
55
56
protected void runTestCases() throws Throwable {
57
// verify that calculation will be started immediately
58
verifyLockingCalculationDelay(0, 0, true);
59
60
// verify that calculation will not be started during
61
// first 10 minutes, while test will be started immediately
62
verifyLockingCalculationDelay(600000, 0, false);
63
64
// verify that calculation will be started after a second
65
verifyLockingCalculationDelay(1000, 1000, true);
66
}
67
68
private void verifyLockingCalculationDelay(long delay, long testDelay,
69
boolean deoptExpected) throws Throwable {
70
AbortProvoker provoker = AbortType.XABORT.provoker();
71
String logFileName = String.format("rtm_delay_%d_%d.xml", delay,
72
testDelay);
73
74
OutputAnalyzer outputAnalyzer = RTMTestBase.executeRTMTest(
75
logFileName,
76
provoker,
77
"-XX:+UseRTMDeopt",
78
CommandLineOptionTest.prepareNumericFlag(
79
"RTMLockingCalculationDelay", delay),
80
"-XX:RTMAbortRatio=0",
81
"-XX:RTMAbortThreshold=0",
82
AbortProvoker.class.getName(),
83
AbortType.XABORT.toString(),
84
Boolean.toString(
85
TestRTMLockingCalculationDelay.INFLATE_MONITOR),
86
Long.toString(AbortProvoker.DEFAULT_ITERATIONS),
87
Long.toString(testDelay)
88
);
89
90
outputAnalyzer.shouldHaveExitValue(0);
91
92
int deopts = RTMTestBase.firedRTMStateChangeTraps(logFileName);
93
94
if (deoptExpected) {
95
Asserts.assertGT(deopts, 0, "At least one deoptimization due to "
96
+ "rtm_state_chage is expected");
97
} else {
98
Asserts.assertEQ(deopts, 0, "No deoptimizations due to "
99
+ "rtm_state_chage are expected");
100
}
101
}
102
103
public static void main(String args[]) throws Throwable {
104
new TestRTMLockingCalculationDelay().runTestCases();
105
}
106
}
107
108