Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/vmTestbase/nsk/jdi/BreakpointRequest/location/location001a.java
41161 views
1
/*
2
* Copyright (c) 2001, 2018, 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
package nsk.jdi.BreakpointRequest.location;
25
26
import nsk.share.*;
27
import nsk.share.jpda.*;
28
import nsk.share.jdi.*;
29
30
/**
31
* This class is used as debuggee application for the location001 JDI test.
32
*/
33
34
public class location001a {
35
36
//----------------------------------------------------- templete section
37
38
static final int PASSED = 0;
39
static final int FAILED = 2;
40
static final int PASS_BASE = 95;
41
42
static ArgumentHandler argHandler;
43
static Log log;
44
45
//-------------------------------------------------- log procedures
46
47
private static void log1(String message) {
48
log.display("**> debuggee: " + message);
49
}
50
51
private static void logErr(String message) {
52
log.complain("**> debuggee: " + message);
53
}
54
55
//====================================================== test program
56
57
static Threadlocation001a thread1 = null;
58
59
static TestClass objTC = new TestClass();
60
61
//------------------------------------------------------ common section
62
63
static int exitCode = PASSED;
64
65
static int instruction = 1;
66
static int end = 0;
67
// static int quit = 0;
68
// static int continue = 2;
69
static int maxInstr = 1; // 2;
70
71
static int lineForComm = 2;
72
73
private static void methodForCommunication() {
74
int i1 = instruction;
75
int i2 = i1;
76
int i3 = i2;
77
}
78
//---------------------------------------------------- main method
79
80
public static void main (String argv[]) {
81
82
argHandler = new ArgumentHandler(argv);
83
log = argHandler.createDebugeeLog();
84
85
log1("debuggee started!");
86
87
label0:
88
for (int i = 0; ; i++) {
89
90
if (instruction > maxInstr) {
91
logErr("ERROR: unexpected instruction: " + instruction);
92
exitCode = FAILED;
93
break ;
94
}
95
96
switch (i) {
97
98
//------------------------------------------------------ section tested
99
100
case 0:
101
thread1 = new Threadlocation001a("thread1");
102
break;
103
104
//------------------------------------------------- standard end section
105
106
default:
107
instruction = end;
108
break;
109
}
110
log1("methodForCommunication();");
111
methodForCommunication();
112
if (instruction == end)
113
break;
114
}
115
116
log1("debuggee exits");
117
System.exit(exitCode + PASS_BASE);
118
}
119
120
121
static Object waitnotifyObj = new Object();
122
123
static int threadStart(Thread t) {
124
synchronized (waitnotifyObj) {
125
t.start();
126
try {
127
waitnotifyObj.wait();
128
} catch ( Exception e) {
129
exitCode = FAILED;
130
logErr(" Exception : " + e );
131
return FAILED;
132
}
133
}
134
return PASSED;
135
}
136
137
static Object lockingObj[] = new Object[2];
138
static volatile int number = 0;
139
140
static class Threadlocation001a extends Thread {
141
142
String tName = null;
143
int tNumber;
144
145
public Threadlocation001a(String threadName) {
146
super(threadName);
147
tName = threadName;
148
tNumber = number;
149
number++;
150
lockingObj[tNumber] = threadName;
151
}
152
153
public void run() {
154
log1(" 'run': enter :: threadName == " + tName);
155
if (lockingObj[tNumber] == null)
156
log1("lockingObj[tNumber] == null");
157
synchronized(lockingObj[tNumber]) {
158
synchronized (waitnotifyObj) {
159
waitnotifyObj.notify();
160
}
161
objTC.method();
162
}
163
log1(" 'run': exit :: threadName == " + tName);
164
return;
165
}
166
}
167
168
}
169
170
class TestClass {
171
172
static int breakpointLine = 3;
173
static String awFieldName = "var1";
174
static String mwFieldName = "var2";
175
176
static int var1 = 0;
177
static int var2 = 0;
178
static int var3 = 0;
179
180
static void method () {
181
var1 = 1;
182
var3 = var1;
183
var2 = var3;
184
}
185
}
186
187