Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java
41153 views
1
/*
2
* Copyright (c) 2016, 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 8138708
27
* @bug 8136421
28
* @requires vm.jvmci
29
* @library /test/lib /
30
* @library ../common/patches
31
* @modules java.base/jdk.internal.access
32
* java.base/jdk.internal.reflect
33
* java.base/jdk.internal.org.objectweb.asm
34
* java.base/jdk.internal.org.objectweb.asm.tree
35
* jdk.internal.vm.ci/jdk.vm.ci.hotspot
36
* jdk.internal.vm.ci/jdk.vm.ci.runtime
37
* jdk.internal.vm.ci/jdk.vm.ci.meta
38
*
39
* @build jdk.internal.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper sun.hotspot.WhiteBox
40
* @run driver jdk.test.lib.helpers.ClassFileInstaller sun.hotspot.WhiteBox
41
* @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions
42
* -XX:+WhiteBoxAPI -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI
43
* -XX:-UseJVMCICompiler
44
* compiler.jvmci.compilerToVM.ResolvePossiblyCachedConstantInPoolTest
45
*/
46
47
package compiler.jvmci.compilerToVM;
48
49
import compiler.jvmci.compilerToVM.ConstantPoolTestCase.ConstantTypes;
50
import compiler.jvmci.compilerToVM.ConstantPoolTestCase.TestedCPEntry;
51
import compiler.jvmci.compilerToVM.ConstantPoolTestCase.Validator;
52
import compiler.jvmci.compilerToVM.ConstantPoolTestsHelper.DummyClasses;
53
import jdk.test.lib.Asserts;
54
import jdk.vm.ci.hotspot.CompilerToVMHelper;
55
import jdk.vm.ci.meta.ConstantPool;
56
57
import java.lang.invoke.MethodHandle;
58
import java.lang.invoke.MethodType;
59
import java.util.HashMap;
60
import java.util.Map;
61
62
import static compiler.jvmci.compilerToVM.ConstantPoolTestCase.ConstantTypes.CONSTANT_METHODHANDLE;
63
import static compiler.jvmci.compilerToVM.ConstantPoolTestCase.ConstantTypes.CONSTANT_METHODTYPE;
64
import static compiler.jvmci.compilerToVM.ConstantPoolTestCase.ConstantTypes.CONSTANT_STRING;
65
66
/**
67
* Test for {@code jdk.vm.ci.hotspot.CompilerToVM.resolvePossiblyCachedConstantInPool} method
68
*/
69
public class ResolvePossiblyCachedConstantInPoolTest {
70
71
public static void main(String[] args) throws Exception {
72
Map<ConstantTypes, Validator> typeTests = new HashMap<>();
73
typeTests.put(CONSTANT_STRING, ResolvePossiblyCachedConstantInPoolTest::validateString);
74
typeTests.put(CONSTANT_METHODHANDLE, ResolvePossiblyCachedConstantInPoolTest::validateMethodHandle);
75
typeTests.put(CONSTANT_METHODTYPE, ResolvePossiblyCachedConstantInPoolTest::validateMethodType);
76
ConstantPoolTestCase testCase = new ConstantPoolTestCase(typeTests);
77
testCase.test();
78
// The next "Class.forName" and repeating "testCase.test()"
79
// are here for the following reason.
80
// The first test run is without dummy class initialization,
81
// which means no constant pool cache exists.
82
// The second run is with initialized class (with constant pool cache available).
83
// Some CompilerToVM methods require different input
84
// depending on whether CP cache exists or not.
85
for (DummyClasses dummy : DummyClasses.values()) {
86
Class.forName(dummy.klass.getName());
87
}
88
testCase.test();
89
}
90
91
private static void validateString(ConstantPool constantPoolCTVM,
92
ConstantTypes cpType,
93
DummyClasses dummyClass,
94
int cpi) {
95
TestedCPEntry entry = cpType.getTestedCPEntry(dummyClass, cpi);
96
if (entry == null) {
97
return;
98
}
99
int index = cpi;
100
String cached = "";
101
int cpci = dummyClass.getCPCacheIndex(cpi);
102
if (cpci != ConstantPoolTestsHelper.NO_CP_CACHE_PRESENT) {
103
index = cpci;
104
cached = "cached ";
105
}
106
Object constantInPool = CompilerToVMHelper.resolvePossiblyCachedConstantInPool(constantPoolCTVM, index);
107
String stringToVerify = (String) constantInPool;
108
String stringToRefer = entry.name;
109
if (stringToRefer.equals("") && cpci != ConstantPoolTestsHelper.NO_CP_CACHE_PRESENT) {
110
stringToRefer = null; // tested method returns null for cached empty strings
111
}
112
String msg = String.format("Wrong string accessed by %sconstant pool index %d", cached, index);
113
Asserts.assertEQ(stringToRefer, stringToVerify, msg);
114
}
115
116
private static final String NOT_NULL_MSG
117
= "Object returned by resolvePossiblyCachedConstantInPool method should not be null";
118
119
120
private static void validateMethodHandle(ConstantPool constantPoolCTVM,
121
ConstantTypes cpType,
122
DummyClasses dummyClass,
123
int index) {
124
Object constantInPool = CompilerToVMHelper.resolvePossiblyCachedConstantInPool(constantPoolCTVM, index);
125
String msg = String.format("%s for index %d", NOT_NULL_MSG, index);
126
Asserts.assertNotNull(constantInPool, msg);
127
if (!(constantInPool instanceof MethodHandle)) {
128
msg = String.format("Wrong constant pool entry accessed by index"
129
+ " %d: %s, but should be subclass of %s",
130
index,
131
constantInPool.getClass(),
132
MethodHandle.class.getName());
133
throw new AssertionError(msg);
134
}
135
}
136
137
private static void validateMethodType(ConstantPool constantPoolCTVM,
138
ConstantTypes cpType,
139
DummyClasses dummyClass,
140
int index) {
141
Object constantInPool = CompilerToVMHelper.resolvePossiblyCachedConstantInPool(constantPoolCTVM, index);
142
String msg = String.format("%s for index %d", NOT_NULL_MSG, index);
143
Asserts.assertNotNull(constantInPool, msg);
144
Class mtToVerify = constantInPool.getClass();
145
Class mtToRefer = MethodType.class;
146
msg = String.format("Wrong method type class accessed by"
147
+ " constant pool index %d",
148
index);
149
Asserts.assertEQ(mtToRefer, mtToVerify, msg);
150
}
151
}
152
153