Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/compiler/jvmci/errors/TestInvalidDebugInfo.java
41152 views
1
/*
2
* Copyright (c) 2015, 2019, 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
* @requires vm.jvmci
27
* @modules jdk.internal.vm.ci/jdk.vm.ci.hotspot
28
* jdk.internal.vm.ci/jdk.vm.ci.code
29
* jdk.internal.vm.ci/jdk.vm.ci.code.site
30
* jdk.internal.vm.ci/jdk.vm.ci.meta
31
* jdk.internal.vm.ci/jdk.vm.ci.runtime
32
* jdk.internal.vm.ci/jdk.vm.ci.common
33
* @compile CodeInstallerTest.java
34
* @run junit/othervm -da:jdk.vm.ci... -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI
35
* -XX:-UseJVMCICompiler compiler.jvmci.errors.TestInvalidDebugInfo
36
*/
37
38
package compiler.jvmci.errors;
39
40
import jdk.vm.ci.code.Architecture;
41
import jdk.vm.ci.code.BytecodeFrame;
42
import jdk.vm.ci.code.DebugInfo;
43
import jdk.vm.ci.code.Location;
44
import jdk.vm.ci.code.Register;
45
import jdk.vm.ci.code.StackSlot;
46
import jdk.vm.ci.code.VirtualObject;
47
import jdk.vm.ci.code.site.DataPatch;
48
import jdk.vm.ci.code.site.Infopoint;
49
import jdk.vm.ci.code.site.InfopointReason;
50
import jdk.vm.ci.code.site.Site;
51
import jdk.vm.ci.common.JVMCIError;
52
import jdk.vm.ci.hotspot.HotSpotCompiledCode.Comment;
53
import jdk.vm.ci.hotspot.HotSpotReferenceMap;
54
import jdk.vm.ci.meta.Assumptions.Assumption;
55
import jdk.vm.ci.meta.JavaConstant;
56
import jdk.vm.ci.meta.JavaKind;
57
import jdk.vm.ci.meta.JavaValue;
58
import jdk.vm.ci.meta.PlatformKind;
59
import jdk.vm.ci.meta.ResolvedJavaType;
60
import jdk.vm.ci.meta.Value;
61
import jdk.vm.ci.meta.ValueKind;
62
import org.junit.Test;
63
64
/**
65
* Tests for errors in debug info.
66
*/
67
public class TestInvalidDebugInfo extends CodeInstallerTest {
68
69
private static class UnknownJavaValue implements JavaValue {
70
}
71
72
private static class TestValueKind extends ValueKind<TestValueKind> {
73
74
TestValueKind(Architecture arch, JavaKind kind) {
75
this(arch.getPlatformKind(kind));
76
}
77
78
TestValueKind(PlatformKind kind) {
79
super(kind);
80
}
81
82
@Override
83
public TestValueKind changeType(PlatformKind kind) {
84
return new TestValueKind(kind);
85
}
86
}
87
88
private void test(JavaValue[] values, JavaKind[] slotKinds, int locals, int stack, int locks) {
89
test(null, values, slotKinds, locals, stack, locks);
90
}
91
92
private void test(VirtualObject[] vobj, JavaValue[] values, JavaKind[] slotKinds, int locals, int stack, int locks) {
93
test(vobj, values, slotKinds, locals, stack, locks, StackSlot.get(null, 0, true));
94
}
95
96
private void test(VirtualObject[] vobj, JavaValue[] values, JavaKind[] slotKinds, int locals, int stack, int locks, StackSlot deoptRescueSlot) {
97
BytecodeFrame frame = new BytecodeFrame(null, dummyMethod, 0, false, false, values, slotKinds, locals, stack, locks);
98
DebugInfo info = new DebugInfo(frame, vobj);
99
info.setReferenceMap(new HotSpotReferenceMap(new Location[0], new Location[0], new int[0], 8));
100
installEmptyCode(new Site[]{new Infopoint(0, info, InfopointReason.SAFEPOINT)}, new Assumption[0], new Comment[0], 16, new DataPatch[0], deoptRescueSlot);
101
}
102
103
@Test(expected = NullPointerException.class)
104
public void testNullValues() {
105
test(null, new JavaKind[0], 0, 0, 0);
106
}
107
108
@Test(expected = NullPointerException.class)
109
public void testNullSlotKinds() {
110
test(new JavaValue[0], null, 0, 0, 0);
111
}
112
113
@Test(expected = JVMCIError.class)
114
public void testMissingDeoptRescueSlot() {
115
test(null, new JavaValue[0], new JavaKind[0], 0, 0, 0, null);
116
}
117
118
@Test(expected = JVMCIError.class)
119
public void testUnexpectedScopeValuesLength() {
120
test(new JavaValue[]{JavaConstant.FALSE}, new JavaKind[0], 0, 0, 0);
121
}
122
123
@Test(expected = JVMCIError.class)
124
public void testUnexpectedScopeSlotKindsLength() {
125
test(new JavaValue[0], new JavaKind[]{JavaKind.Boolean}, 0, 0, 0);
126
}
127
128
@Test(expected = NullPointerException.class)
129
public void testNullValue() {
130
test(new JavaValue[]{null}, new JavaKind[]{JavaKind.Int}, 1, 0, 0);
131
}
132
133
@Test(expected = NullPointerException.class)
134
public void testNullSlotKind() {
135
test(new JavaValue[]{JavaConstant.INT_0}, new JavaKind[]{null}, 1, 0, 0);
136
}
137
138
@Test(expected = NullPointerException.class)
139
public void testNullMonitor() {
140
test(new JavaValue[]{null}, new JavaKind[0], 0, 0, 1);
141
}
142
143
@Test(expected = JVMCIError.class)
144
public void testWrongMonitorType() {
145
test(new JavaValue[]{JavaConstant.INT_0}, new JavaKind[0], 0, 0, 1);
146
}
147
148
@Test(expected = JVMCIError.class)
149
public void testUnexpectedIllegalValue() {
150
test(new JavaValue[]{Value.ILLEGAL}, new JavaKind[]{JavaKind.Int}, 1, 0, 0);
151
}
152
153
@Test(expected = JVMCIError.class)
154
public void testUnexpectedTypeInCPURegister() {
155
Register reg = getRegister(arch.getPlatformKind(JavaKind.Int), 0);
156
test(new JavaValue[]{reg.asValue()}, new JavaKind[]{JavaKind.Illegal}, 1, 0, 0);
157
}
158
159
@Test(expected = JVMCIError.class)
160
public void testUnexpectedTypeInFloatRegister() {
161
Register reg = getRegister(arch.getPlatformKind(JavaKind.Float), 0);
162
test(new JavaValue[]{reg.asValue()}, new JavaKind[]{JavaKind.Illegal}, 1, 0, 0);
163
}
164
165
@Test(expected = JVMCIError.class)
166
public void testUnexpectedTypeOnStack() {
167
ValueKind<?> kind = new TestValueKind(codeCache.getTarget().arch, JavaKind.Int);
168
StackSlot value = StackSlot.get(kind, 8, false);
169
test(new JavaValue[]{value}, new JavaKind[]{JavaKind.Illegal}, 1, 0, 0);
170
}
171
172
@Test(expected = JVMCIError.class)
173
public void testWrongConstantType() {
174
test(new JavaValue[]{JavaConstant.INT_0}, new JavaKind[]{JavaKind.Object}, 1, 0, 0);
175
}
176
177
@Test(expected = JVMCIError.class)
178
public void testUnsupportedConstantType() {
179
test(new JavaValue[]{JavaConstant.forShort((short) 0)}, new JavaKind[]{JavaKind.Short}, 1, 0, 0);
180
}
181
182
@Test(expected = JVMCIError.class)
183
public void testUnexpectedNull() {
184
test(new JavaValue[]{JavaConstant.NULL_POINTER}, new JavaKind[]{JavaKind.Int}, 1, 0, 0);
185
}
186
187
@Test(expected = JVMCIError.class)
188
public void testUnexpectedObject() {
189
JavaValue wrapped = constantReflection.forObject(this);
190
test(new JavaValue[]{wrapped}, new JavaKind[]{JavaKind.Int}, 1, 0, 0);
191
}
192
193
@Test(expected = JVMCIError.class)
194
public void testUnknownJavaValue() {
195
test(new JavaValue[]{new UnknownJavaValue()}, new JavaKind[]{JavaKind.Int}, 1, 0, 0);
196
}
197
198
@Test(expected = JVMCIError.class)
199
public void testMissingIllegalAfterDouble() {
200
test(new JavaValue[]{JavaConstant.DOUBLE_0, JavaConstant.INT_0}, new JavaKind[]{JavaKind.Double, JavaKind.Int}, 2, 0, 0);
201
}
202
203
@Test(expected = JVMCIError.class)
204
public void testInvalidVirtualObjectId() {
205
ResolvedJavaType obj = metaAccess.lookupJavaType(Object.class);
206
VirtualObject o = VirtualObject.get(obj, 5);
207
o.setValues(new JavaValue[0], new JavaKind[0]);
208
209
test(new VirtualObject[]{o}, new JavaValue[0], new JavaKind[0], 0, 0, 0);
210
}
211
212
@Test(expected = JVMCIError.class)
213
public void testDuplicateVirtualObject() {
214
ResolvedJavaType obj = metaAccess.lookupJavaType(Object.class);
215
VirtualObject o1 = VirtualObject.get(obj, 0);
216
o1.setValues(new JavaValue[0], new JavaKind[0]);
217
218
VirtualObject o2 = VirtualObject.get(obj, 0);
219
o2.setValues(new JavaValue[0], new JavaKind[0]);
220
221
test(new VirtualObject[]{o1, o2}, new JavaValue[0], new JavaKind[0], 0, 0, 0);
222
}
223
224
@Test(expected = JVMCIError.class)
225
public void testUnexpectedVirtualObject() {
226
ResolvedJavaType obj = metaAccess.lookupJavaType(Object.class);
227
VirtualObject o = VirtualObject.get(obj, 0);
228
o.setValues(new JavaValue[0], new JavaKind[0]);
229
230
test(new VirtualObject[]{o}, new JavaValue[]{o}, new JavaKind[]{JavaKind.Int}, 1, 0, 0);
231
}
232
233
@Test(expected = JVMCIError.class)
234
public void testUndefinedVirtualObject() {
235
ResolvedJavaType obj = metaAccess.lookupJavaType(Object.class);
236
VirtualObject o0 = VirtualObject.get(obj, 0);
237
o0.setValues(new JavaValue[0], new JavaKind[0]);
238
239
VirtualObject o1 = VirtualObject.get(obj, 1);
240
o1.setValues(new JavaValue[0], new JavaKind[0]);
241
242
test(new VirtualObject[]{o0}, new JavaValue[]{o1}, new JavaKind[]{JavaKind.Object}, 1, 0, 0);
243
}
244
}
245
246