annotate src/share/vm/prims/jvm.cpp @ 3992:d1bdeef3e3e2

7098282: G1: assert(interval >= 0) failed: Sanity check, referencePolicy.cpp: 76 Summary: There is a race between one thread successfully forwarding and copying the klass mirror for the SoftReference class (including the static master clock) and another thread attempting to use the master clock while attempting to discover a soft reference object. Maintain a shadow copy of the soft reference master clock and use the shadow during reference discovery and reference processing. Reviewed-by: tonyp, brutisso, ysr
author johnc
date Wed, 12 Oct 2011 10:25:51 -0700
parents f08d439fab8c
children 436b4a3231bf
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
2162
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2 * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1324
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1324
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1324
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #include "classfile/classLoader.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #include "classfile/javaAssertions.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "classfile/javaClasses.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "classfile/symbolTable.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "classfile/systemDictionary.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 #include "classfile/vmSymbols.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "gc_interface/collectedHeap.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
33 #include "memory/oopFactory.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
34 #include "memory/universe.inline.hpp"
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
35 #include "oops/fieldStreams.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
36 #include "oops/instanceKlass.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
37 #include "oops/objArrayKlass.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
38 #include "prims/jvm.h"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
39 #include "prims/jvm_misc.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
40 #include "prims/jvmtiExport.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
41 #include "prims/jvmtiThreadState.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
42 #include "prims/nativeLookup.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
43 #include "prims/privilegedStack.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
44 #include "runtime/arguments.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
45 #include "runtime/dtraceJSDT.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
46 #include "runtime/handles.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
47 #include "runtime/init.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
48 #include "runtime/interfaceSupport.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
49 #include "runtime/java.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
50 #include "runtime/javaCalls.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
51 #include "runtime/jfieldIDWorkaround.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
52 #include "runtime/os.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
53 #include "runtime/perfData.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
54 #include "runtime/reflection.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
55 #include "runtime/vframe.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
56 #include "runtime/vm_operations.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
57 #include "services/attachListener.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
58 #include "services/management.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
59 #include "services/threadService.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
60 #include "utilities/copy.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
61 #include "utilities/defaultStream.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
62 #include "utilities/dtrace.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
63 #include "utilities/events.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
64 #include "utilities/histogram.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
65 #include "utilities/top.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
66 #include "utilities/utf8.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
67 #ifdef TARGET_OS_FAMILY_linux
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
68 # include "jvm_linux.h"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
69 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
70 #ifdef TARGET_OS_FAMILY_solaris
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
71 # include "jvm_solaris.h"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
72 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
73 #ifdef TARGET_OS_FAMILY_windows
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
74 # include "jvm_windows.h"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
75 #endif
3960
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 3938
diff changeset
76 #ifdef TARGET_OS_FAMILY_bsd
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 3938
diff changeset
77 # include "jvm_bsd.h"
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 3938
diff changeset
78 #endif
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
79
0
a61af66fc99e Initial load
duke
parents:
diff changeset
80 #include <errno.h>
a61af66fc99e Initial load
duke
parents:
diff changeset
81
1324
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
82 HS_DTRACE_PROBE_DECL1(hotspot, thread__sleep__begin, long long);
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
83 HS_DTRACE_PROBE_DECL1(hotspot, thread__sleep__end, int);
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
84 HS_DTRACE_PROBE_DECL0(hotspot, thread__yield);
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
85
0
a61af66fc99e Initial load
duke
parents:
diff changeset
86 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
87 NOTE about use of any ctor or function call that can trigger a safepoint/GC:
a61af66fc99e Initial load
duke
parents:
diff changeset
88 such ctors and calls MUST NOT come between an oop declaration/init and its
a61af66fc99e Initial load
duke
parents:
diff changeset
89 usage because if objects are move this may cause various memory stomps, bus
a61af66fc99e Initial load
duke
parents:
diff changeset
90 errors and segfaults. Here is a cookbook for causing so called "naked oop
a61af66fc99e Initial load
duke
parents:
diff changeset
91 failures":
a61af66fc99e Initial load
duke
parents:
diff changeset
92
a61af66fc99e Initial load
duke
parents:
diff changeset
93 JVM_ENTRY(jobjectArray, JVM_GetClassDeclaredFields<etc> {
a61af66fc99e Initial load
duke
parents:
diff changeset
94 JVMWrapper("JVM_GetClassDeclaredFields");
a61af66fc99e Initial load
duke
parents:
diff changeset
95
a61af66fc99e Initial load
duke
parents:
diff changeset
96 // Object address to be held directly in mirror & not visible to GC
a61af66fc99e Initial load
duke
parents:
diff changeset
97 oop mirror = JNIHandles::resolve_non_null(ofClass);
a61af66fc99e Initial load
duke
parents:
diff changeset
98
a61af66fc99e Initial load
duke
parents:
diff changeset
99 // If this ctor can hit a safepoint, moving objects around, then
a61af66fc99e Initial load
duke
parents:
diff changeset
100 ComplexConstructor foo;
a61af66fc99e Initial load
duke
parents:
diff changeset
101
a61af66fc99e Initial load
duke
parents:
diff changeset
102 // Boom! mirror may point to JUNK instead of the intended object
a61af66fc99e Initial load
duke
parents:
diff changeset
103 (some dereference of mirror)
a61af66fc99e Initial load
duke
parents:
diff changeset
104
a61af66fc99e Initial load
duke
parents:
diff changeset
105 // Here's another call that may block for GC, making mirror stale
a61af66fc99e Initial load
duke
parents:
diff changeset
106 MutexLocker ml(some_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
107
a61af66fc99e Initial load
duke
parents:
diff changeset
108 // And here's an initializer that can result in a stale oop
a61af66fc99e Initial load
duke
parents:
diff changeset
109 // all in one step.
a61af66fc99e Initial load
duke
parents:
diff changeset
110 oop o = call_that_can_throw_exception(TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
111
a61af66fc99e Initial load
duke
parents:
diff changeset
112
a61af66fc99e Initial load
duke
parents:
diff changeset
113 The solution is to keep the oop declaration BELOW the ctor or function
a61af66fc99e Initial load
duke
parents:
diff changeset
114 call that might cause a GC, do another resolve to reassign the oop, or
a61af66fc99e Initial load
duke
parents:
diff changeset
115 consider use of a Handle instead of an oop so there is immunity from object
a61af66fc99e Initial load
duke
parents:
diff changeset
116 motion. But note that the "QUICK" entries below do not have a handlemark
a61af66fc99e Initial load
duke
parents:
diff changeset
117 and thus can only support use of handles passed in.
a61af66fc99e Initial load
duke
parents:
diff changeset
118 */
a61af66fc99e Initial load
duke
parents:
diff changeset
119
a61af66fc99e Initial load
duke
parents:
diff changeset
120 static void trace_class_resolution_impl(klassOop to_class, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
121 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
122 int line_number = -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
123 const char * source_file = NULL;
657
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
124 const char * trace = "explicit";
0
a61af66fc99e Initial load
duke
parents:
diff changeset
125 klassOop caller = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
126 JavaThread* jthread = JavaThread::current();
a61af66fc99e Initial load
duke
parents:
diff changeset
127 if (jthread->has_last_Java_frame()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
128 vframeStream vfst(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
129
a61af66fc99e Initial load
duke
parents:
diff changeset
130 // scan up the stack skipping ClassLoader, AccessController and PrivilegedAction frames
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
131 TempNewSymbol access_controller = SymbolTable::new_symbol("java/security/AccessController", CHECK);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
132 klassOop access_controller_klass = SystemDictionary::resolve_or_fail(access_controller, false, CHECK);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
133 TempNewSymbol privileged_action = SymbolTable::new_symbol("java/security/PrivilegedAction", CHECK);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
134 klassOop privileged_action_klass = SystemDictionary::resolve_or_fail(privileged_action, false, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
135
a61af66fc99e Initial load
duke
parents:
diff changeset
136 methodOop last_caller = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
137
a61af66fc99e Initial load
duke
parents:
diff changeset
138 while (!vfst.at_end()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
139 methodOop m = vfst.method();
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
140 if (!vfst.method()->method_holder()->klass_part()->is_subclass_of(SystemDictionary::ClassLoader_klass())&&
0
a61af66fc99e Initial load
duke
parents:
diff changeset
141 !vfst.method()->method_holder()->klass_part()->is_subclass_of(access_controller_klass) &&
a61af66fc99e Initial load
duke
parents:
diff changeset
142 !vfst.method()->method_holder()->klass_part()->is_subclass_of(privileged_action_klass)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
143 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
144 }
a61af66fc99e Initial load
duke
parents:
diff changeset
145 last_caller = m;
a61af66fc99e Initial load
duke
parents:
diff changeset
146 vfst.next();
a61af66fc99e Initial load
duke
parents:
diff changeset
147 }
a61af66fc99e Initial load
duke
parents:
diff changeset
148 // if this is called from Class.forName0 and that is called from Class.forName,
a61af66fc99e Initial load
duke
parents:
diff changeset
149 // then print the caller of Class.forName. If this is Class.loadClass, then print
a61af66fc99e Initial load
duke
parents:
diff changeset
150 // that caller, otherwise keep quiet since this should be picked up elsewhere.
a61af66fc99e Initial load
duke
parents:
diff changeset
151 bool found_it = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
152 if (!vfst.at_end() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
153 instanceKlass::cast(vfst.method()->method_holder())->name() == vmSymbols::java_lang_Class() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
154 vfst.method()->name() == vmSymbols::forName0_name()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
155 vfst.next();
a61af66fc99e Initial load
duke
parents:
diff changeset
156 if (!vfst.at_end() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
157 instanceKlass::cast(vfst.method()->method_holder())->name() == vmSymbols::java_lang_Class() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
158 vfst.method()->name() == vmSymbols::forName_name()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
159 vfst.next();
a61af66fc99e Initial load
duke
parents:
diff changeset
160 found_it = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
161 }
a61af66fc99e Initial load
duke
parents:
diff changeset
162 } else if (last_caller != NULL &&
a61af66fc99e Initial load
duke
parents:
diff changeset
163 instanceKlass::cast(last_caller->method_holder())->name() ==
a61af66fc99e Initial load
duke
parents:
diff changeset
164 vmSymbols::java_lang_ClassLoader() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
165 (last_caller->name() == vmSymbols::loadClassInternal_name() ||
a61af66fc99e Initial load
duke
parents:
diff changeset
166 last_caller->name() == vmSymbols::loadClass_name())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
167 found_it = true;
657
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
168 } else if (!vfst.at_end()) {
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
169 if (vfst.method()->is_native()) {
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
170 // JNI call
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
171 found_it = true;
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
172 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
173 }
a61af66fc99e Initial load
duke
parents:
diff changeset
174 if (found_it && !vfst.at_end()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
175 // found the caller
a61af66fc99e Initial load
duke
parents:
diff changeset
176 caller = vfst.method()->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
177 line_number = vfst.method()->line_number_from_bci(vfst.bci());
657
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
178 if (line_number == -1) {
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
179 // show method name if it's a native method
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
180 trace = vfst.method()->name_and_sig_as_C_string();
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
181 }
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
182 Symbol* s = instanceKlass::cast(caller)->source_file_name();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
183 if (s != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
184 source_file = s->as_C_string();
a61af66fc99e Initial load
duke
parents:
diff changeset
185 }
a61af66fc99e Initial load
duke
parents:
diff changeset
186 }
a61af66fc99e Initial load
duke
parents:
diff changeset
187 }
a61af66fc99e Initial load
duke
parents:
diff changeset
188 if (caller != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
189 if (to_class != caller) {
a61af66fc99e Initial load
duke
parents:
diff changeset
190 const char * from = Klass::cast(caller)->external_name();
a61af66fc99e Initial load
duke
parents:
diff changeset
191 const char * to = Klass::cast(to_class)->external_name();
a61af66fc99e Initial load
duke
parents:
diff changeset
192 // print in a single call to reduce interleaving between threads
a61af66fc99e Initial load
duke
parents:
diff changeset
193 if (source_file != NULL) {
657
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
194 tty->print("RESOLVE %s %s %s:%d (%s)\n", from, to, source_file, line_number, trace);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
195 } else {
657
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
196 tty->print("RESOLVE %s %s (%s)\n", from, to, trace);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
197 }
a61af66fc99e Initial load
duke
parents:
diff changeset
198 }
a61af66fc99e Initial load
duke
parents:
diff changeset
199 }
a61af66fc99e Initial load
duke
parents:
diff changeset
200 }
a61af66fc99e Initial load
duke
parents:
diff changeset
201
657
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
202 void trace_class_resolution(klassOop to_class) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
203 EXCEPTION_MARK;
a61af66fc99e Initial load
duke
parents:
diff changeset
204 trace_class_resolution_impl(to_class, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
205 if (HAS_PENDING_EXCEPTION) {
a61af66fc99e Initial load
duke
parents:
diff changeset
206 CLEAR_PENDING_EXCEPTION;
a61af66fc99e Initial load
duke
parents:
diff changeset
207 }
a61af66fc99e Initial load
duke
parents:
diff changeset
208 }
a61af66fc99e Initial load
duke
parents:
diff changeset
209
a61af66fc99e Initial load
duke
parents:
diff changeset
210 // Wrapper to trace JVM functions
a61af66fc99e Initial load
duke
parents:
diff changeset
211
a61af66fc99e Initial load
duke
parents:
diff changeset
212 #ifdef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
213 class JVMTraceWrapper : public StackObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
214 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
215 JVMTraceWrapper(const char* format, ...) {
a61af66fc99e Initial load
duke
parents:
diff changeset
216 if (TraceJVMCalls) {
a61af66fc99e Initial load
duke
parents:
diff changeset
217 va_list ap;
a61af66fc99e Initial load
duke
parents:
diff changeset
218 va_start(ap, format);
a61af66fc99e Initial load
duke
parents:
diff changeset
219 tty->print("JVM ");
a61af66fc99e Initial load
duke
parents:
diff changeset
220 tty->vprint_cr(format, ap);
a61af66fc99e Initial load
duke
parents:
diff changeset
221 va_end(ap);
a61af66fc99e Initial load
duke
parents:
diff changeset
222 }
a61af66fc99e Initial load
duke
parents:
diff changeset
223 }
a61af66fc99e Initial load
duke
parents:
diff changeset
224 };
a61af66fc99e Initial load
duke
parents:
diff changeset
225
a61af66fc99e Initial load
duke
parents:
diff changeset
226 Histogram* JVMHistogram;
a61af66fc99e Initial load
duke
parents:
diff changeset
227 volatile jint JVMHistogram_lock = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
228
a61af66fc99e Initial load
duke
parents:
diff changeset
229 class JVMHistogramElement : public HistogramElement {
a61af66fc99e Initial load
duke
parents:
diff changeset
230 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
231 JVMHistogramElement(const char* name);
a61af66fc99e Initial load
duke
parents:
diff changeset
232 };
a61af66fc99e Initial load
duke
parents:
diff changeset
233
a61af66fc99e Initial load
duke
parents:
diff changeset
234 JVMHistogramElement::JVMHistogramElement(const char* elementName) {
a61af66fc99e Initial load
duke
parents:
diff changeset
235 _name = elementName;
a61af66fc99e Initial load
duke
parents:
diff changeset
236 uintx count = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
237
a61af66fc99e Initial load
duke
parents:
diff changeset
238 while (Atomic::cmpxchg(1, &JVMHistogram_lock, 0) != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
239 while (OrderAccess::load_acquire(&JVMHistogram_lock) != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
240 count +=1;
a61af66fc99e Initial load
duke
parents:
diff changeset
241 if ( (WarnOnStalledSpinLock > 0)
a61af66fc99e Initial load
duke
parents:
diff changeset
242 && (count % WarnOnStalledSpinLock == 0)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
243 warning("JVMHistogram_lock seems to be stalled");
a61af66fc99e Initial load
duke
parents:
diff changeset
244 }
a61af66fc99e Initial load
duke
parents:
diff changeset
245 }
a61af66fc99e Initial load
duke
parents:
diff changeset
246 }
a61af66fc99e Initial load
duke
parents:
diff changeset
247
a61af66fc99e Initial load
duke
parents:
diff changeset
248 if(JVMHistogram == NULL)
a61af66fc99e Initial load
duke
parents:
diff changeset
249 JVMHistogram = new Histogram("JVM Call Counts",100);
a61af66fc99e Initial load
duke
parents:
diff changeset
250
a61af66fc99e Initial load
duke
parents:
diff changeset
251 JVMHistogram->add_element(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
252 Atomic::dec(&JVMHistogram_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
253 }
a61af66fc99e Initial load
duke
parents:
diff changeset
254
a61af66fc99e Initial load
duke
parents:
diff changeset
255 #define JVMCountWrapper(arg) \
a61af66fc99e Initial load
duke
parents:
diff changeset
256 static JVMHistogramElement* e = new JVMHistogramElement(arg); \
a61af66fc99e Initial load
duke
parents:
diff changeset
257 if (e != NULL) e->increment_count(); // Due to bug in VC++, we need a NULL check here eventhough it should never happen!
a61af66fc99e Initial load
duke
parents:
diff changeset
258
a61af66fc99e Initial load
duke
parents:
diff changeset
259 #define JVMWrapper(arg1) JVMCountWrapper(arg1); JVMTraceWrapper(arg1)
a61af66fc99e Initial load
duke
parents:
diff changeset
260 #define JVMWrapper2(arg1, arg2) JVMCountWrapper(arg1); JVMTraceWrapper(arg1, arg2)
a61af66fc99e Initial load
duke
parents:
diff changeset
261 #define JVMWrapper3(arg1, arg2, arg3) JVMCountWrapper(arg1); JVMTraceWrapper(arg1, arg2, arg3)
a61af66fc99e Initial load
duke
parents:
diff changeset
262 #define JVMWrapper4(arg1, arg2, arg3, arg4) JVMCountWrapper(arg1); JVMTraceWrapper(arg1, arg2, arg3, arg4)
a61af66fc99e Initial load
duke
parents:
diff changeset
263 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
264 #define JVMWrapper(arg1)
a61af66fc99e Initial load
duke
parents:
diff changeset
265 #define JVMWrapper2(arg1, arg2)
a61af66fc99e Initial load
duke
parents:
diff changeset
266 #define JVMWrapper3(arg1, arg2, arg3)
a61af66fc99e Initial load
duke
parents:
diff changeset
267 #define JVMWrapper4(arg1, arg2, arg3, arg4)
a61af66fc99e Initial load
duke
parents:
diff changeset
268 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
269
a61af66fc99e Initial load
duke
parents:
diff changeset
270
a61af66fc99e Initial load
duke
parents:
diff changeset
271 // Interface version /////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
272
a61af66fc99e Initial load
duke
parents:
diff changeset
273
a61af66fc99e Initial load
duke
parents:
diff changeset
274 JVM_LEAF(jint, JVM_GetInterfaceVersion())
a61af66fc99e Initial load
duke
parents:
diff changeset
275 return JVM_INTERFACE_VERSION;
a61af66fc99e Initial load
duke
parents:
diff changeset
276 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
277
a61af66fc99e Initial load
duke
parents:
diff changeset
278
a61af66fc99e Initial load
duke
parents:
diff changeset
279 // java.lang.System //////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
280
a61af66fc99e Initial load
duke
parents:
diff changeset
281
a61af66fc99e Initial load
duke
parents:
diff changeset
282 JVM_LEAF(jlong, JVM_CurrentTimeMillis(JNIEnv *env, jclass ignored))
a61af66fc99e Initial load
duke
parents:
diff changeset
283 JVMWrapper("JVM_CurrentTimeMillis");
a61af66fc99e Initial load
duke
parents:
diff changeset
284 return os::javaTimeMillis();
a61af66fc99e Initial load
duke
parents:
diff changeset
285 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
286
a61af66fc99e Initial load
duke
parents:
diff changeset
287 JVM_LEAF(jlong, JVM_NanoTime(JNIEnv *env, jclass ignored))
a61af66fc99e Initial load
duke
parents:
diff changeset
288 JVMWrapper("JVM_NanoTime");
a61af66fc99e Initial load
duke
parents:
diff changeset
289 return os::javaTimeNanos();
a61af66fc99e Initial load
duke
parents:
diff changeset
290 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
291
a61af66fc99e Initial load
duke
parents:
diff changeset
292
a61af66fc99e Initial load
duke
parents:
diff changeset
293 JVM_ENTRY(void, JVM_ArrayCopy(JNIEnv *env, jclass ignored, jobject src, jint src_pos,
a61af66fc99e Initial load
duke
parents:
diff changeset
294 jobject dst, jint dst_pos, jint length))
a61af66fc99e Initial load
duke
parents:
diff changeset
295 JVMWrapper("JVM_ArrayCopy");
a61af66fc99e Initial load
duke
parents:
diff changeset
296 // Check if we have null pointers
a61af66fc99e Initial load
duke
parents:
diff changeset
297 if (src == NULL || dst == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
298 THROW(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
299 }
a61af66fc99e Initial load
duke
parents:
diff changeset
300 arrayOop s = arrayOop(JNIHandles::resolve_non_null(src));
a61af66fc99e Initial load
duke
parents:
diff changeset
301 arrayOop d = arrayOop(JNIHandles::resolve_non_null(dst));
a61af66fc99e Initial load
duke
parents:
diff changeset
302 assert(s->is_oop(), "JVM_ArrayCopy: src not an oop");
a61af66fc99e Initial load
duke
parents:
diff changeset
303 assert(d->is_oop(), "JVM_ArrayCopy: dst not an oop");
a61af66fc99e Initial load
duke
parents:
diff changeset
304 // Do copy
a61af66fc99e Initial load
duke
parents:
diff changeset
305 Klass::cast(s->klass())->copy_array(s, src_pos, d, dst_pos, length, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
306 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
307
a61af66fc99e Initial load
duke
parents:
diff changeset
308
a61af66fc99e Initial load
duke
parents:
diff changeset
309 static void set_property(Handle props, const char* key, const char* value, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
310 JavaValue r(T_OBJECT);
a61af66fc99e Initial load
duke
parents:
diff changeset
311 // public synchronized Object put(Object key, Object value);
a61af66fc99e Initial load
duke
parents:
diff changeset
312 HandleMark hm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
313 Handle key_str = java_lang_String::create_from_platform_dependent_str(key, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
314 Handle value_str = java_lang_String::create_from_platform_dependent_str((value != NULL ? value : ""), CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
315 JavaCalls::call_virtual(&r,
a61af66fc99e Initial load
duke
parents:
diff changeset
316 props,
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
317 KlassHandle(THREAD, SystemDictionary::Properties_klass()),
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
318 vmSymbols::put_name(),
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
319 vmSymbols::object_object_object_signature(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
320 key_str,
a61af66fc99e Initial load
duke
parents:
diff changeset
321 value_str,
a61af66fc99e Initial load
duke
parents:
diff changeset
322 THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
323 }
a61af66fc99e Initial load
duke
parents:
diff changeset
324
a61af66fc99e Initial load
duke
parents:
diff changeset
325
a61af66fc99e Initial load
duke
parents:
diff changeset
326 #define PUTPROP(props, name, value) set_property((props), (name), (value), CHECK_(properties));
a61af66fc99e Initial load
duke
parents:
diff changeset
327
a61af66fc99e Initial load
duke
parents:
diff changeset
328
a61af66fc99e Initial load
duke
parents:
diff changeset
329 JVM_ENTRY(jobject, JVM_InitProperties(JNIEnv *env, jobject properties))
a61af66fc99e Initial load
duke
parents:
diff changeset
330 JVMWrapper("JVM_InitProperties");
a61af66fc99e Initial load
duke
parents:
diff changeset
331 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
332
a61af66fc99e Initial load
duke
parents:
diff changeset
333 Handle props(THREAD, JNIHandles::resolve_non_null(properties));
a61af66fc99e Initial load
duke
parents:
diff changeset
334
a61af66fc99e Initial load
duke
parents:
diff changeset
335 // System property list includes both user set via -D option and
a61af66fc99e Initial load
duke
parents:
diff changeset
336 // jvm system specific properties.
a61af66fc99e Initial load
duke
parents:
diff changeset
337 for (SystemProperty* p = Arguments::system_properties(); p != NULL; p = p->next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
338 PUTPROP(props, p->key(), p->value());
a61af66fc99e Initial load
duke
parents:
diff changeset
339 }
a61af66fc99e Initial load
duke
parents:
diff changeset
340
a61af66fc99e Initial load
duke
parents:
diff changeset
341 // Convert the -XX:MaxDirectMemorySize= command line flag
a61af66fc99e Initial load
duke
parents:
diff changeset
342 // to the sun.nio.MaxDirectMemorySize property.
a61af66fc99e Initial load
duke
parents:
diff changeset
343 // Do this after setting user properties to prevent people
a61af66fc99e Initial load
duke
parents:
diff changeset
344 // from setting the value with a -D option, as requested.
a61af66fc99e Initial load
duke
parents:
diff changeset
345 {
a61af66fc99e Initial load
duke
parents:
diff changeset
346 char as_chars[256];
a61af66fc99e Initial load
duke
parents:
diff changeset
347 jio_snprintf(as_chars, sizeof(as_chars), INTX_FORMAT, MaxDirectMemorySize);
a61af66fc99e Initial load
duke
parents:
diff changeset
348 PUTPROP(props, "sun.nio.MaxDirectMemorySize", as_chars);
a61af66fc99e Initial load
duke
parents:
diff changeset
349 }
a61af66fc99e Initial load
duke
parents:
diff changeset
350
a61af66fc99e Initial load
duke
parents:
diff changeset
351 // JVM monitoring and management support
a61af66fc99e Initial load
duke
parents:
diff changeset
352 // Add the sun.management.compiler property for the compiler's name
a61af66fc99e Initial load
duke
parents:
diff changeset
353 {
a61af66fc99e Initial load
duke
parents:
diff changeset
354 #undef CSIZE
a61af66fc99e Initial load
duke
parents:
diff changeset
355 #if defined(_LP64) || defined(_WIN64)
a61af66fc99e Initial load
duke
parents:
diff changeset
356 #define CSIZE "64-Bit "
a61af66fc99e Initial load
duke
parents:
diff changeset
357 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
358 #define CSIZE
a61af66fc99e Initial load
duke
parents:
diff changeset
359 #endif // 64bit
a61af66fc99e Initial load
duke
parents:
diff changeset
360
a61af66fc99e Initial load
duke
parents:
diff changeset
361 #ifdef TIERED
a61af66fc99e Initial load
duke
parents:
diff changeset
362 const char* compiler_name = "HotSpot " CSIZE "Tiered Compilers";
a61af66fc99e Initial load
duke
parents:
diff changeset
363 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
364 #if defined(COMPILER1)
a61af66fc99e Initial load
duke
parents:
diff changeset
365 const char* compiler_name = "HotSpot " CSIZE "Client Compiler";
a61af66fc99e Initial load
duke
parents:
diff changeset
366 #elif defined(COMPILER2)
a61af66fc99e Initial load
duke
parents:
diff changeset
367 const char* compiler_name = "HotSpot " CSIZE "Server Compiler";
a61af66fc99e Initial load
duke
parents:
diff changeset
368 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
369 const char* compiler_name = "";
a61af66fc99e Initial load
duke
parents:
diff changeset
370 #endif // compilers
a61af66fc99e Initial load
duke
parents:
diff changeset
371 #endif // TIERED
a61af66fc99e Initial load
duke
parents:
diff changeset
372
a61af66fc99e Initial load
duke
parents:
diff changeset
373 if (*compiler_name != '\0' &&
a61af66fc99e Initial load
duke
parents:
diff changeset
374 (Arguments::mode() != Arguments::_int)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
375 PUTPROP(props, "sun.management.compiler", compiler_name);
a61af66fc99e Initial load
duke
parents:
diff changeset
376 }
a61af66fc99e Initial load
duke
parents:
diff changeset
377 }
a61af66fc99e Initial load
duke
parents:
diff changeset
378
a61af66fc99e Initial load
duke
parents:
diff changeset
379 return properties;
a61af66fc99e Initial load
duke
parents:
diff changeset
380 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
381
a61af66fc99e Initial load
duke
parents:
diff changeset
382
a61af66fc99e Initial load
duke
parents:
diff changeset
383 // java.lang.Runtime /////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
384
a61af66fc99e Initial load
duke
parents:
diff changeset
385 extern volatile jint vm_created;
a61af66fc99e Initial load
duke
parents:
diff changeset
386
a61af66fc99e Initial load
duke
parents:
diff changeset
387 JVM_ENTRY_NO_ENV(void, JVM_Exit(jint code))
a61af66fc99e Initial load
duke
parents:
diff changeset
388 if (vm_created != 0 && (code == 0)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
389 // The VM is about to exit. We call back into Java to check whether finalizers should be run
a61af66fc99e Initial load
duke
parents:
diff changeset
390 Universe::run_finalizers_on_exit();
a61af66fc99e Initial load
duke
parents:
diff changeset
391 }
a61af66fc99e Initial load
duke
parents:
diff changeset
392 before_exit(thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
393 vm_exit(code);
a61af66fc99e Initial load
duke
parents:
diff changeset
394 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
395
a61af66fc99e Initial load
duke
parents:
diff changeset
396
a61af66fc99e Initial load
duke
parents:
diff changeset
397 JVM_ENTRY_NO_ENV(void, JVM_Halt(jint code))
a61af66fc99e Initial load
duke
parents:
diff changeset
398 before_exit(thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
399 vm_exit(code);
a61af66fc99e Initial load
duke
parents:
diff changeset
400 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
401
a61af66fc99e Initial load
duke
parents:
diff changeset
402
a61af66fc99e Initial load
duke
parents:
diff changeset
403 JVM_LEAF(void, JVM_OnExit(void (*func)(void)))
a61af66fc99e Initial load
duke
parents:
diff changeset
404 register_on_exit_function(func);
a61af66fc99e Initial load
duke
parents:
diff changeset
405 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
406
a61af66fc99e Initial load
duke
parents:
diff changeset
407
a61af66fc99e Initial load
duke
parents:
diff changeset
408 JVM_ENTRY_NO_ENV(void, JVM_GC(void))
a61af66fc99e Initial load
duke
parents:
diff changeset
409 JVMWrapper("JVM_GC");
a61af66fc99e Initial load
duke
parents:
diff changeset
410 if (!DisableExplicitGC) {
a61af66fc99e Initial load
duke
parents:
diff changeset
411 Universe::heap()->collect(GCCause::_java_lang_system_gc);
a61af66fc99e Initial load
duke
parents:
diff changeset
412 }
a61af66fc99e Initial load
duke
parents:
diff changeset
413 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
414
a61af66fc99e Initial load
duke
parents:
diff changeset
415
a61af66fc99e Initial load
duke
parents:
diff changeset
416 JVM_LEAF(jlong, JVM_MaxObjectInspectionAge(void))
a61af66fc99e Initial load
duke
parents:
diff changeset
417 JVMWrapper("JVM_MaxObjectInspectionAge");
a61af66fc99e Initial load
duke
parents:
diff changeset
418 return Universe::heap()->millis_since_last_gc();
a61af66fc99e Initial load
duke
parents:
diff changeset
419 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
420
a61af66fc99e Initial load
duke
parents:
diff changeset
421
a61af66fc99e Initial load
duke
parents:
diff changeset
422 JVM_LEAF(void, JVM_TraceInstructions(jboolean on))
a61af66fc99e Initial load
duke
parents:
diff changeset
423 if (PrintJVMWarnings) warning("JVM_TraceInstructions not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
424 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
425
a61af66fc99e Initial load
duke
parents:
diff changeset
426
a61af66fc99e Initial load
duke
parents:
diff changeset
427 JVM_LEAF(void, JVM_TraceMethodCalls(jboolean on))
a61af66fc99e Initial load
duke
parents:
diff changeset
428 if (PrintJVMWarnings) warning("JVM_TraceMethodCalls not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
429 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
430
a61af66fc99e Initial load
duke
parents:
diff changeset
431 static inline jlong convert_size_t_to_jlong(size_t val) {
a61af66fc99e Initial load
duke
parents:
diff changeset
432 // In the 64-bit vm, a size_t can overflow a jlong (which is signed).
a61af66fc99e Initial load
duke
parents:
diff changeset
433 NOT_LP64 (return (jlong)val;)
a61af66fc99e Initial load
duke
parents:
diff changeset
434 LP64_ONLY(return (jlong)MIN2(val, (size_t)max_jlong);)
a61af66fc99e Initial load
duke
parents:
diff changeset
435 }
a61af66fc99e Initial load
duke
parents:
diff changeset
436
a61af66fc99e Initial load
duke
parents:
diff changeset
437 JVM_ENTRY_NO_ENV(jlong, JVM_TotalMemory(void))
a61af66fc99e Initial load
duke
parents:
diff changeset
438 JVMWrapper("JVM_TotalMemory");
a61af66fc99e Initial load
duke
parents:
diff changeset
439 size_t n = Universe::heap()->capacity();
a61af66fc99e Initial load
duke
parents:
diff changeset
440 return convert_size_t_to_jlong(n);
a61af66fc99e Initial load
duke
parents:
diff changeset
441 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
442
a61af66fc99e Initial load
duke
parents:
diff changeset
443
a61af66fc99e Initial load
duke
parents:
diff changeset
444 JVM_ENTRY_NO_ENV(jlong, JVM_FreeMemory(void))
a61af66fc99e Initial load
duke
parents:
diff changeset
445 JVMWrapper("JVM_FreeMemory");
a61af66fc99e Initial load
duke
parents:
diff changeset
446 CollectedHeap* ch = Universe::heap();
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 116
diff changeset
447 size_t n;
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 116
diff changeset
448 {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 116
diff changeset
449 MutexLocker x(Heap_lock);
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 116
diff changeset
450 n = ch->capacity() - ch->used();
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 116
diff changeset
451 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
452 return convert_size_t_to_jlong(n);
a61af66fc99e Initial load
duke
parents:
diff changeset
453 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
454
a61af66fc99e Initial load
duke
parents:
diff changeset
455
a61af66fc99e Initial load
duke
parents:
diff changeset
456 JVM_ENTRY_NO_ENV(jlong, JVM_MaxMemory(void))
a61af66fc99e Initial load
duke
parents:
diff changeset
457 JVMWrapper("JVM_MaxMemory");
a61af66fc99e Initial load
duke
parents:
diff changeset
458 size_t n = Universe::heap()->max_capacity();
a61af66fc99e Initial load
duke
parents:
diff changeset
459 return convert_size_t_to_jlong(n);
a61af66fc99e Initial load
duke
parents:
diff changeset
460 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
461
a61af66fc99e Initial load
duke
parents:
diff changeset
462
a61af66fc99e Initial load
duke
parents:
diff changeset
463 JVM_ENTRY_NO_ENV(jint, JVM_ActiveProcessorCount(void))
a61af66fc99e Initial load
duke
parents:
diff changeset
464 JVMWrapper("JVM_ActiveProcessorCount");
a61af66fc99e Initial load
duke
parents:
diff changeset
465 return os::active_processor_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
466 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
467
a61af66fc99e Initial load
duke
parents:
diff changeset
468
a61af66fc99e Initial load
duke
parents:
diff changeset
469
a61af66fc99e Initial load
duke
parents:
diff changeset
470 // java.lang.Throwable //////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
471
a61af66fc99e Initial load
duke
parents:
diff changeset
472
a61af66fc99e Initial load
duke
parents:
diff changeset
473 JVM_ENTRY(void, JVM_FillInStackTrace(JNIEnv *env, jobject receiver))
a61af66fc99e Initial load
duke
parents:
diff changeset
474 JVMWrapper("JVM_FillInStackTrace");
a61af66fc99e Initial load
duke
parents:
diff changeset
475 Handle exception(thread, JNIHandles::resolve_non_null(receiver));
a61af66fc99e Initial load
duke
parents:
diff changeset
476 java_lang_Throwable::fill_in_stack_trace(exception);
a61af66fc99e Initial load
duke
parents:
diff changeset
477 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
478
a61af66fc99e Initial load
duke
parents:
diff changeset
479
a61af66fc99e Initial load
duke
parents:
diff changeset
480 JVM_ENTRY(void, JVM_PrintStackTrace(JNIEnv *env, jobject receiver, jobject printable))
a61af66fc99e Initial load
duke
parents:
diff changeset
481 JVMWrapper("JVM_PrintStackTrace");
a61af66fc99e Initial load
duke
parents:
diff changeset
482 // Note: This is no longer used in Merlin, but we still support it for compatibility.
a61af66fc99e Initial load
duke
parents:
diff changeset
483 oop exception = JNIHandles::resolve_non_null(receiver);
a61af66fc99e Initial load
duke
parents:
diff changeset
484 oop stream = JNIHandles::resolve_non_null(printable);
a61af66fc99e Initial load
duke
parents:
diff changeset
485 java_lang_Throwable::print_stack_trace(exception, stream);
a61af66fc99e Initial load
duke
parents:
diff changeset
486 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
487
a61af66fc99e Initial load
duke
parents:
diff changeset
488
a61af66fc99e Initial load
duke
parents:
diff changeset
489 JVM_ENTRY(jint, JVM_GetStackTraceDepth(JNIEnv *env, jobject throwable))
a61af66fc99e Initial load
duke
parents:
diff changeset
490 JVMWrapper("JVM_GetStackTraceDepth");
a61af66fc99e Initial load
duke
parents:
diff changeset
491 oop exception = JNIHandles::resolve(throwable);
a61af66fc99e Initial load
duke
parents:
diff changeset
492 return java_lang_Throwable::get_stack_trace_depth(exception, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
493 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
494
a61af66fc99e Initial load
duke
parents:
diff changeset
495
a61af66fc99e Initial load
duke
parents:
diff changeset
496 JVM_ENTRY(jobject, JVM_GetStackTraceElement(JNIEnv *env, jobject throwable, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
497 JVMWrapper("JVM_GetStackTraceElement");
a61af66fc99e Initial load
duke
parents:
diff changeset
498 JvmtiVMObjectAllocEventCollector oam; // This ctor (throughout this module) may trigger a safepoint/GC
a61af66fc99e Initial load
duke
parents:
diff changeset
499 oop exception = JNIHandles::resolve(throwable);
a61af66fc99e Initial load
duke
parents:
diff changeset
500 oop element = java_lang_Throwable::get_stack_trace_element(exception, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
501 return JNIHandles::make_local(env, element);
a61af66fc99e Initial load
duke
parents:
diff changeset
502 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
503
a61af66fc99e Initial load
duke
parents:
diff changeset
504
a61af66fc99e Initial load
duke
parents:
diff changeset
505 // java.lang.Object ///////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
506
a61af66fc99e Initial load
duke
parents:
diff changeset
507
a61af66fc99e Initial load
duke
parents:
diff changeset
508 JVM_ENTRY(jint, JVM_IHashCode(JNIEnv* env, jobject handle))
a61af66fc99e Initial load
duke
parents:
diff changeset
509 JVMWrapper("JVM_IHashCode");
a61af66fc99e Initial load
duke
parents:
diff changeset
510 // as implemented in the classic virtual machine; return 0 if object is NULL
a61af66fc99e Initial load
duke
parents:
diff changeset
511 return handle == NULL ? 0 : ObjectSynchronizer::FastHashCode (THREAD, JNIHandles::resolve_non_null(handle)) ;
a61af66fc99e Initial load
duke
parents:
diff changeset
512 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
513
a61af66fc99e Initial load
duke
parents:
diff changeset
514
a61af66fc99e Initial load
duke
parents:
diff changeset
515 JVM_ENTRY(void, JVM_MonitorWait(JNIEnv* env, jobject handle, jlong ms))
a61af66fc99e Initial load
duke
parents:
diff changeset
516 JVMWrapper("JVM_MonitorWait");
a61af66fc99e Initial load
duke
parents:
diff changeset
517 Handle obj(THREAD, JNIHandles::resolve_non_null(handle));
a61af66fc99e Initial load
duke
parents:
diff changeset
518 assert(obj->is_instance() || obj->is_array(), "JVM_MonitorWait must apply to an object");
a61af66fc99e Initial load
duke
parents:
diff changeset
519 JavaThreadInObjectWaitState jtiows(thread, ms != 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
520 if (JvmtiExport::should_post_monitor_wait()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
521 JvmtiExport::post_monitor_wait((JavaThread *)THREAD, (oop)obj(), ms);
a61af66fc99e Initial load
duke
parents:
diff changeset
522 }
a61af66fc99e Initial load
duke
parents:
diff changeset
523 ObjectSynchronizer::wait(obj, ms, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
524 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
525
a61af66fc99e Initial load
duke
parents:
diff changeset
526
a61af66fc99e Initial load
duke
parents:
diff changeset
527 JVM_ENTRY(void, JVM_MonitorNotify(JNIEnv* env, jobject handle))
a61af66fc99e Initial load
duke
parents:
diff changeset
528 JVMWrapper("JVM_MonitorNotify");
a61af66fc99e Initial load
duke
parents:
diff changeset
529 Handle obj(THREAD, JNIHandles::resolve_non_null(handle));
a61af66fc99e Initial load
duke
parents:
diff changeset
530 assert(obj->is_instance() || obj->is_array(), "JVM_MonitorNotify must apply to an object");
a61af66fc99e Initial load
duke
parents:
diff changeset
531 ObjectSynchronizer::notify(obj, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
532 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
533
a61af66fc99e Initial load
duke
parents:
diff changeset
534
a61af66fc99e Initial load
duke
parents:
diff changeset
535 JVM_ENTRY(void, JVM_MonitorNotifyAll(JNIEnv* env, jobject handle))
a61af66fc99e Initial load
duke
parents:
diff changeset
536 JVMWrapper("JVM_MonitorNotifyAll");
a61af66fc99e Initial load
duke
parents:
diff changeset
537 Handle obj(THREAD, JNIHandles::resolve_non_null(handle));
a61af66fc99e Initial load
duke
parents:
diff changeset
538 assert(obj->is_instance() || obj->is_array(), "JVM_MonitorNotifyAll must apply to an object");
a61af66fc99e Initial load
duke
parents:
diff changeset
539 ObjectSynchronizer::notifyall(obj, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
540 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
541
a61af66fc99e Initial load
duke
parents:
diff changeset
542
a61af66fc99e Initial load
duke
parents:
diff changeset
543 JVM_ENTRY(jobject, JVM_Clone(JNIEnv* env, jobject handle))
a61af66fc99e Initial load
duke
parents:
diff changeset
544 JVMWrapper("JVM_Clone");
a61af66fc99e Initial load
duke
parents:
diff changeset
545 Handle obj(THREAD, JNIHandles::resolve_non_null(handle));
a61af66fc99e Initial load
duke
parents:
diff changeset
546 const KlassHandle klass (THREAD, obj->klass());
a61af66fc99e Initial load
duke
parents:
diff changeset
547 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
548
a61af66fc99e Initial load
duke
parents:
diff changeset
549 #ifdef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
550 // Just checking that the cloneable flag is set correct
a61af66fc99e Initial load
duke
parents:
diff changeset
551 if (obj->is_javaArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
552 guarantee(klass->is_cloneable(), "all arrays are cloneable");
a61af66fc99e Initial load
duke
parents:
diff changeset
553 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
554 guarantee(obj->is_instance(), "should be instanceOop");
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
555 bool cloneable = klass->is_subtype_of(SystemDictionary::Cloneable_klass());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
556 guarantee(cloneable == klass->is_cloneable(), "incorrect cloneable flag");
a61af66fc99e Initial load
duke
parents:
diff changeset
557 }
a61af66fc99e Initial load
duke
parents:
diff changeset
558 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
559
a61af66fc99e Initial load
duke
parents:
diff changeset
560 // Check if class of obj supports the Cloneable interface.
a61af66fc99e Initial load
duke
parents:
diff changeset
561 // All arrays are considered to be cloneable (See JLS 20.1.5)
a61af66fc99e Initial load
duke
parents:
diff changeset
562 if (!klass->is_cloneable()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
563 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
564 THROW_MSG_0(vmSymbols::java_lang_CloneNotSupportedException(), klass->external_name());
a61af66fc99e Initial load
duke
parents:
diff changeset
565 }
a61af66fc99e Initial load
duke
parents:
diff changeset
566
a61af66fc99e Initial load
duke
parents:
diff changeset
567 // Make shallow object copy
a61af66fc99e Initial load
duke
parents:
diff changeset
568 const int size = obj->size();
a61af66fc99e Initial load
duke
parents:
diff changeset
569 oop new_obj = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
570 if (obj->is_javaArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
571 const int length = ((arrayOop)obj())->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
572 new_obj = CollectedHeap::array_allocate(klass, size, length, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
573 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
574 new_obj = CollectedHeap::obj_allocate(klass, size, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
575 }
a61af66fc99e Initial load
duke
parents:
diff changeset
576 // 4839641 (4840070): We must do an oop-atomic copy, because if another thread
a61af66fc99e Initial load
duke
parents:
diff changeset
577 // is modifying a reference field in the clonee, a non-oop-atomic copy might
a61af66fc99e Initial load
duke
parents:
diff changeset
578 // be suspended in the middle of copying the pointer and end up with parts
a61af66fc99e Initial load
duke
parents:
diff changeset
579 // of two different pointers in the field. Subsequent dereferences will crash.
a61af66fc99e Initial load
duke
parents:
diff changeset
580 // 4846409: an oop-copy of objects with long or double fields or arrays of same
a61af66fc99e Initial load
duke
parents:
diff changeset
581 // won't copy the longs/doubles atomically in 32-bit vm's, so we copy jlongs instead
a61af66fc99e Initial load
duke
parents:
diff changeset
582 // of oops. We know objects are aligned on a minimum of an jlong boundary.
a61af66fc99e Initial load
duke
parents:
diff changeset
583 // The same is true of StubRoutines::object_copy and the various oop_copy
a61af66fc99e Initial load
duke
parents:
diff changeset
584 // variants, and of the code generated by the inline_native_clone intrinsic.
a61af66fc99e Initial load
duke
parents:
diff changeset
585 assert(MinObjAlignmentInBytes >= BytesPerLong, "objects misaligned");
a61af66fc99e Initial load
duke
parents:
diff changeset
586 Copy::conjoint_jlongs_atomic((jlong*)obj(), (jlong*)new_obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
587 (size_t)align_object_size(size) / HeapWordsPerLong);
a61af66fc99e Initial load
duke
parents:
diff changeset
588 // Clear the header
a61af66fc99e Initial load
duke
parents:
diff changeset
589 new_obj->init_mark();
a61af66fc99e Initial load
duke
parents:
diff changeset
590
a61af66fc99e Initial load
duke
parents:
diff changeset
591 // Store check (mark entire object and let gc sort it out)
a61af66fc99e Initial load
duke
parents:
diff changeset
592 BarrierSet* bs = Universe::heap()->barrier_set();
a61af66fc99e Initial load
duke
parents:
diff changeset
593 assert(bs->has_write_region_opt(), "Barrier set does not have write_region");
a61af66fc99e Initial load
duke
parents:
diff changeset
594 bs->write_region(MemRegion((HeapWord*)new_obj, size));
a61af66fc99e Initial load
duke
parents:
diff changeset
595
a61af66fc99e Initial load
duke
parents:
diff changeset
596 // Caution: this involves a java upcall, so the clone should be
a61af66fc99e Initial load
duke
parents:
diff changeset
597 // "gc-robust" by this stage.
a61af66fc99e Initial load
duke
parents:
diff changeset
598 if (klass->has_finalizer()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
599 assert(obj->is_instance(), "should be instanceOop");
a61af66fc99e Initial load
duke
parents:
diff changeset
600 new_obj = instanceKlass::register_finalizer(instanceOop(new_obj), CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
601 }
a61af66fc99e Initial load
duke
parents:
diff changeset
602
a61af66fc99e Initial load
duke
parents:
diff changeset
603 return JNIHandles::make_local(env, oop(new_obj));
a61af66fc99e Initial load
duke
parents:
diff changeset
604 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
605
a61af66fc99e Initial load
duke
parents:
diff changeset
606 // java.lang.Compiler ////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
607
a61af66fc99e Initial load
duke
parents:
diff changeset
608 // The initial cuts of the HotSpot VM will not support JITs, and all existing
a61af66fc99e Initial load
duke
parents:
diff changeset
609 // JITs would need extensive changes to work with HotSpot. The JIT-related JVM
a61af66fc99e Initial load
duke
parents:
diff changeset
610 // functions are all silently ignored unless JVM warnings are printed.
a61af66fc99e Initial load
duke
parents:
diff changeset
611
a61af66fc99e Initial load
duke
parents:
diff changeset
612 JVM_LEAF(void, JVM_InitializeCompiler (JNIEnv *env, jclass compCls))
a61af66fc99e Initial load
duke
parents:
diff changeset
613 if (PrintJVMWarnings) warning("JVM_InitializeCompiler not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
614 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
615
a61af66fc99e Initial load
duke
parents:
diff changeset
616
a61af66fc99e Initial load
duke
parents:
diff changeset
617 JVM_LEAF(jboolean, JVM_IsSilentCompiler(JNIEnv *env, jclass compCls))
a61af66fc99e Initial load
duke
parents:
diff changeset
618 if (PrintJVMWarnings) warning("JVM_IsSilentCompiler not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
619 return JNI_FALSE;
a61af66fc99e Initial load
duke
parents:
diff changeset
620 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
621
a61af66fc99e Initial load
duke
parents:
diff changeset
622
a61af66fc99e Initial load
duke
parents:
diff changeset
623 JVM_LEAF(jboolean, JVM_CompileClass(JNIEnv *env, jclass compCls, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
624 if (PrintJVMWarnings) warning("JVM_CompileClass not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
625 return JNI_FALSE;
a61af66fc99e Initial load
duke
parents:
diff changeset
626 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
627
a61af66fc99e Initial load
duke
parents:
diff changeset
628
a61af66fc99e Initial load
duke
parents:
diff changeset
629 JVM_LEAF(jboolean, JVM_CompileClasses(JNIEnv *env, jclass cls, jstring jname))
a61af66fc99e Initial load
duke
parents:
diff changeset
630 if (PrintJVMWarnings) warning("JVM_CompileClasses not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
631 return JNI_FALSE;
a61af66fc99e Initial load
duke
parents:
diff changeset
632 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
633
a61af66fc99e Initial load
duke
parents:
diff changeset
634
a61af66fc99e Initial load
duke
parents:
diff changeset
635 JVM_LEAF(jobject, JVM_CompilerCommand(JNIEnv *env, jclass compCls, jobject arg))
a61af66fc99e Initial load
duke
parents:
diff changeset
636 if (PrintJVMWarnings) warning("JVM_CompilerCommand not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
637 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
638 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
639
a61af66fc99e Initial load
duke
parents:
diff changeset
640
a61af66fc99e Initial load
duke
parents:
diff changeset
641 JVM_LEAF(void, JVM_EnableCompiler(JNIEnv *env, jclass compCls))
a61af66fc99e Initial load
duke
parents:
diff changeset
642 if (PrintJVMWarnings) warning("JVM_EnableCompiler not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
643 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
644
a61af66fc99e Initial load
duke
parents:
diff changeset
645
a61af66fc99e Initial load
duke
parents:
diff changeset
646 JVM_LEAF(void, JVM_DisableCompiler(JNIEnv *env, jclass compCls))
a61af66fc99e Initial load
duke
parents:
diff changeset
647 if (PrintJVMWarnings) warning("JVM_DisableCompiler not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
648 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
649
a61af66fc99e Initial load
duke
parents:
diff changeset
650
a61af66fc99e Initial load
duke
parents:
diff changeset
651
a61af66fc99e Initial load
duke
parents:
diff changeset
652 // Error message support //////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
653
a61af66fc99e Initial load
duke
parents:
diff changeset
654 JVM_LEAF(jint, JVM_GetLastErrorString(char *buf, int len))
a61af66fc99e Initial load
duke
parents:
diff changeset
655 JVMWrapper("JVM_GetLastErrorString");
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
656 return (jint)os::lasterror(buf, len);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
657 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
658
a61af66fc99e Initial load
duke
parents:
diff changeset
659
a61af66fc99e Initial load
duke
parents:
diff changeset
660 // java.io.File ///////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
661
a61af66fc99e Initial load
duke
parents:
diff changeset
662 JVM_LEAF(char*, JVM_NativePath(char* path))
a61af66fc99e Initial load
duke
parents:
diff changeset
663 JVMWrapper2("JVM_NativePath (%s)", path);
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
664 return os::native_path(path);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
665 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
666
a61af66fc99e Initial load
duke
parents:
diff changeset
667
a61af66fc99e Initial load
duke
parents:
diff changeset
668 // Misc. class handling ///////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
669
a61af66fc99e Initial load
duke
parents:
diff changeset
670
a61af66fc99e Initial load
duke
parents:
diff changeset
671 JVM_ENTRY(jclass, JVM_GetCallerClass(JNIEnv* env, int depth))
a61af66fc99e Initial load
duke
parents:
diff changeset
672 JVMWrapper("JVM_GetCallerClass");
a61af66fc99e Initial load
duke
parents:
diff changeset
673 klassOop k = thread->security_get_caller_class(depth);
a61af66fc99e Initial load
duke
parents:
diff changeset
674 return (k == NULL) ? NULL : (jclass) JNIHandles::make_local(env, Klass::cast(k)->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
675 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
676
a61af66fc99e Initial load
duke
parents:
diff changeset
677
a61af66fc99e Initial load
duke
parents:
diff changeset
678 JVM_ENTRY(jclass, JVM_FindPrimitiveClass(JNIEnv* env, const char* utf))
a61af66fc99e Initial load
duke
parents:
diff changeset
679 JVMWrapper("JVM_FindPrimitiveClass");
a61af66fc99e Initial load
duke
parents:
diff changeset
680 oop mirror = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
681 BasicType t = name2type(utf);
a61af66fc99e Initial load
duke
parents:
diff changeset
682 if (t != T_ILLEGAL && t != T_OBJECT && t != T_ARRAY) {
a61af66fc99e Initial load
duke
parents:
diff changeset
683 mirror = Universe::java_mirror(t);
a61af66fc99e Initial load
duke
parents:
diff changeset
684 }
a61af66fc99e Initial load
duke
parents:
diff changeset
685 if (mirror == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
686 THROW_MSG_0(vmSymbols::java_lang_ClassNotFoundException(), (char*) utf);
a61af66fc99e Initial load
duke
parents:
diff changeset
687 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
688 return (jclass) JNIHandles::make_local(env, mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
689 }
a61af66fc99e Initial load
duke
parents:
diff changeset
690 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
691
a61af66fc99e Initial load
duke
parents:
diff changeset
692
a61af66fc99e Initial load
duke
parents:
diff changeset
693 JVM_ENTRY(void, JVM_ResolveClass(JNIEnv* env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
694 JVMWrapper("JVM_ResolveClass");
a61af66fc99e Initial load
duke
parents:
diff changeset
695 if (PrintJVMWarnings) warning("JVM_ResolveClass not implemented");
a61af66fc99e Initial load
duke
parents:
diff changeset
696 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
697
878
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
698
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
699 // Returns a class loaded by the bootstrap class loader; or null
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
700 // if not found. ClassNotFoundException is not thrown.
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
701 //
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
702 // Rationale behind JVM_FindClassFromBootLoader
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
703 // a> JVM_FindClassFromClassLoader was never exported in the export tables.
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
704 // b> because of (a) java.dll has a direct dependecy on the unexported
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
705 // private symbol "_JVM_FindClassFromClassLoader@20".
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
706 // c> the launcher cannot use the private symbol as it dynamically opens
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
707 // the entry point, so if something changes, the launcher will fail
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
708 // unexpectedly at runtime, it is safest for the launcher to dlopen a
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
709 // stable exported interface.
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
710 // d> re-exporting JVM_FindClassFromClassLoader as public, will cause its
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
711 // signature to change from _JVM_FindClassFromClassLoader@20 to
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
712 // JVM_FindClassFromClassLoader and will not be backward compatible
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
713 // with older JDKs.
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
714 // Thus a public/stable exported entry point is the right solution,
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
715 // public here means public in linker semantics, and is exported only
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
716 // to the JDK, and is not intended to be a public API.
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
717
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
718 JVM_ENTRY(jclass, JVM_FindClassFromBootLoader(JNIEnv* env,
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
719 const char* name))
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
720 JVMWrapper2("JVM_FindClassFromBootLoader %s", name);
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
721
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
722 // Java libraries should ensure that name is never null...
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
723 if (name == NULL || (int)strlen(name) > Symbol::max_length()) {
878
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
724 // It's impossible to create this class; the name cannot fit
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
725 // into the constant pool.
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
726 return NULL;
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
727 }
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
728
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
729 TempNewSymbol h_name = SymbolTable::new_symbol(name, CHECK_NULL);
878
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
730 klassOop k = SystemDictionary::resolve_or_null(h_name, CHECK_NULL);
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
731 if (k == NULL) {
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
732 return NULL;
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
733 }
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
734
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
735 if (TraceClassResolution) {
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
736 trace_class_resolution(k);
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
737 }
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
738 return (jclass) JNIHandles::make_local(env, Klass::cast(k)->java_mirror());
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
739 JVM_END
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
740
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
741 JVM_ENTRY(jclass, JVM_FindClassFromClassLoader(JNIEnv* env, const char* name,
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
742 jboolean init, jobject loader,
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
743 jboolean throwError))
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
744 JVMWrapper3("JVM_FindClassFromClassLoader %s throw %s", name,
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
745 throwError ? "error" : "exception");
388
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
746 // Java libraries should ensure that name is never null...
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
747 if (name == NULL || (int)strlen(name) > Symbol::max_length()) {
388
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
748 // It's impossible to create this class; the name cannot fit
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
749 // into the constant pool.
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
750 if (throwError) {
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
751 THROW_MSG_0(vmSymbols::java_lang_NoClassDefFoundError(), name);
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
752 } else {
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
753 THROW_MSG_0(vmSymbols::java_lang_ClassNotFoundException(), name);
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
754 }
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
755 }
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
756 TempNewSymbol h_name = SymbolTable::new_symbol(name, CHECK_NULL);
388
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
757 Handle h_loader(THREAD, JNIHandles::resolve(loader));
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
758 jclass result = find_class_from_class_loader(env, h_name, init, h_loader,
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
759 Handle(), throwError, THREAD);
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
760
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
761 if (TraceClassResolution && result != NULL) {
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
762 trace_class_resolution(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(result)));
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
763 }
f008d3631bd1 6755845: JVM_FindClassFromBoot triggers assertions
ksrini
parents: 356
diff changeset
764 return result;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
765 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
766
a61af66fc99e Initial load
duke
parents:
diff changeset
767
a61af66fc99e Initial load
duke
parents:
diff changeset
768 JVM_ENTRY(jclass, JVM_FindClassFromClass(JNIEnv *env, const char *name,
a61af66fc99e Initial load
duke
parents:
diff changeset
769 jboolean init, jclass from))
a61af66fc99e Initial load
duke
parents:
diff changeset
770 JVMWrapper2("JVM_FindClassFromClass %s", name);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
771 if (name == NULL || (int)strlen(name) > Symbol::max_length()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
772 // It's impossible to create this class; the name cannot fit
a61af66fc99e Initial load
duke
parents:
diff changeset
773 // into the constant pool.
a61af66fc99e Initial load
duke
parents:
diff changeset
774 THROW_MSG_0(vmSymbols::java_lang_NoClassDefFoundError(), name);
a61af66fc99e Initial load
duke
parents:
diff changeset
775 }
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
776 TempNewSymbol h_name = SymbolTable::new_symbol(name, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
777 oop from_class_oop = JNIHandles::resolve(from);
a61af66fc99e Initial load
duke
parents:
diff changeset
778 klassOop from_class = (from_class_oop == NULL)
a61af66fc99e Initial load
duke
parents:
diff changeset
779 ? (klassOop)NULL
a61af66fc99e Initial load
duke
parents:
diff changeset
780 : java_lang_Class::as_klassOop(from_class_oop);
a61af66fc99e Initial load
duke
parents:
diff changeset
781 oop class_loader = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
782 oop protection_domain = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
783 if (from_class != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
784 class_loader = Klass::cast(from_class)->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
785 protection_domain = Klass::cast(from_class)->protection_domain();
a61af66fc99e Initial load
duke
parents:
diff changeset
786 }
a61af66fc99e Initial load
duke
parents:
diff changeset
787 Handle h_loader(THREAD, class_loader);
a61af66fc99e Initial load
duke
parents:
diff changeset
788 Handle h_prot (THREAD, protection_domain);
a61af66fc99e Initial load
duke
parents:
diff changeset
789 jclass result = find_class_from_class_loader(env, h_name, init, h_loader,
a61af66fc99e Initial load
duke
parents:
diff changeset
790 h_prot, true, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
791
a61af66fc99e Initial load
duke
parents:
diff changeset
792 if (TraceClassResolution && result != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
793 // this function is generally only used for class loading during verification.
a61af66fc99e Initial load
duke
parents:
diff changeset
794 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
795 oop from_mirror = JNIHandles::resolve_non_null(from);
a61af66fc99e Initial load
duke
parents:
diff changeset
796 klassOop from_class = java_lang_Class::as_klassOop(from_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
797 const char * from_name = Klass::cast(from_class)->external_name();
a61af66fc99e Initial load
duke
parents:
diff changeset
798
a61af66fc99e Initial load
duke
parents:
diff changeset
799 oop mirror = JNIHandles::resolve_non_null(result);
a61af66fc99e Initial load
duke
parents:
diff changeset
800 klassOop to_class = java_lang_Class::as_klassOop(mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
801 const char * to = Klass::cast(to_class)->external_name();
a61af66fc99e Initial load
duke
parents:
diff changeset
802 tty->print("RESOLVE %s %s (verification)\n", from_name, to);
a61af66fc99e Initial load
duke
parents:
diff changeset
803 }
a61af66fc99e Initial load
duke
parents:
diff changeset
804
a61af66fc99e Initial load
duke
parents:
diff changeset
805 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
806 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
807
a61af66fc99e Initial load
duke
parents:
diff changeset
808 static void is_lock_held_by_thread(Handle loader, PerfCounter* counter, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
809 if (loader.is_null()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
810 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
811 }
a61af66fc99e Initial load
duke
parents:
diff changeset
812
a61af66fc99e Initial load
duke
parents:
diff changeset
813 // check whether the current caller thread holds the lock or not.
a61af66fc99e Initial load
duke
parents:
diff changeset
814 // If not, increment the corresponding counter
a61af66fc99e Initial load
duke
parents:
diff changeset
815 if (ObjectSynchronizer::query_lock_ownership((JavaThread*)THREAD, loader) !=
a61af66fc99e Initial load
duke
parents:
diff changeset
816 ObjectSynchronizer::owner_self) {
a61af66fc99e Initial load
duke
parents:
diff changeset
817 counter->inc();
a61af66fc99e Initial load
duke
parents:
diff changeset
818 }
a61af66fc99e Initial load
duke
parents:
diff changeset
819 }
a61af66fc99e Initial load
duke
parents:
diff changeset
820
a61af66fc99e Initial load
duke
parents:
diff changeset
821 // common code for JVM_DefineClass() and JVM_DefineClassWithSource()
973
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
822 // and JVM_DefineClassWithSourceCond()
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
823 static jclass jvm_define_class_common(JNIEnv *env, const char *name,
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
824 jobject loader, const jbyte *buf,
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
825 jsize len, jobject pd, const char *source,
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
826 jboolean verify, TRAPS) {
431
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 388
diff changeset
827 if (source == NULL) source = "__JVM_DefineClass__";
0
a61af66fc99e Initial load
duke
parents:
diff changeset
828
875
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
829 assert(THREAD->is_Java_thread(), "must be a JavaThread");
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
830 JavaThread* jt = (JavaThread*) THREAD;
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
831
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
832 PerfClassTraceTime vmtimer(ClassLoader::perf_define_appclass_time(),
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
833 ClassLoader::perf_define_appclass_selftime(),
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
834 ClassLoader::perf_define_appclasses(),
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
835 jt->get_thread_stat()->perf_recursion_counts_addr(),
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
836 jt->get_thread_stat()->perf_timers_addr(),
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
837 PerfClassTraceTime::DEFINE_CLASS);
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
838
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
839 if (UsePerfData) {
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
840 ClassLoader::perf_app_classfile_bytes_read()->inc(len);
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
841 }
6a93908f268f 6857194: Add hotspot perf counters to aid class loading performance measurement
mchung
parents: 726
diff changeset
842
0
a61af66fc99e Initial load
duke
parents:
diff changeset
843 // Since exceptions can be thrown, class initialization can take place
a61af66fc99e Initial load
duke
parents:
diff changeset
844 // if name is NULL no check for class name in .class stream has to be made.
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
845 TempNewSymbol class_name = NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
846 if (name != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
847 const int str_len = (int)strlen(name);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
848 if (str_len > Symbol::max_length()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
849 // It's impossible to create this class; the name cannot fit
a61af66fc99e Initial load
duke
parents:
diff changeset
850 // into the constant pool.
a61af66fc99e Initial load
duke
parents:
diff changeset
851 THROW_MSG_0(vmSymbols::java_lang_NoClassDefFoundError(), name);
a61af66fc99e Initial load
duke
parents:
diff changeset
852 }
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
853 class_name = SymbolTable::new_symbol(name, str_len, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
854 }
a61af66fc99e Initial load
duke
parents:
diff changeset
855
a61af66fc99e Initial load
duke
parents:
diff changeset
856 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
857 ClassFileStream st((u1*) buf, len, (char *)source);
a61af66fc99e Initial load
duke
parents:
diff changeset
858 Handle class_loader (THREAD, JNIHandles::resolve(loader));
a61af66fc99e Initial load
duke
parents:
diff changeset
859 if (UsePerfData) {
a61af66fc99e Initial load
duke
parents:
diff changeset
860 is_lock_held_by_thread(class_loader,
a61af66fc99e Initial load
duke
parents:
diff changeset
861 ClassLoader::sync_JVMDefineClassLockFreeCounter(),
a61af66fc99e Initial load
duke
parents:
diff changeset
862 THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
863 }
a61af66fc99e Initial load
duke
parents:
diff changeset
864 Handle protection_domain (THREAD, JNIHandles::resolve(pd));
a61af66fc99e Initial load
duke
parents:
diff changeset
865 klassOop k = SystemDictionary::resolve_from_stream(class_name, class_loader,
a61af66fc99e Initial load
duke
parents:
diff changeset
866 protection_domain, &st,
973
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
867 verify != 0,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
868 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
869
a61af66fc99e Initial load
duke
parents:
diff changeset
870 if (TraceClassResolution && k != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
871 trace_class_resolution(k);
a61af66fc99e Initial load
duke
parents:
diff changeset
872 }
a61af66fc99e Initial load
duke
parents:
diff changeset
873
a61af66fc99e Initial load
duke
parents:
diff changeset
874 return (jclass) JNIHandles::make_local(env, Klass::cast(k)->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
875 }
a61af66fc99e Initial load
duke
parents:
diff changeset
876
a61af66fc99e Initial load
duke
parents:
diff changeset
877
a61af66fc99e Initial load
duke
parents:
diff changeset
878 JVM_ENTRY(jclass, JVM_DefineClass(JNIEnv *env, const char *name, jobject loader, const jbyte *buf, jsize len, jobject pd))
a61af66fc99e Initial load
duke
parents:
diff changeset
879 JVMWrapper2("JVM_DefineClass %s", name);
a61af66fc99e Initial load
duke
parents:
diff changeset
880
973
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
881 return jvm_define_class_common(env, name, loader, buf, len, pd, NULL, true, THREAD);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
882 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
883
a61af66fc99e Initial load
duke
parents:
diff changeset
884
a61af66fc99e Initial load
duke
parents:
diff changeset
885 JVM_ENTRY(jclass, JVM_DefineClassWithSource(JNIEnv *env, const char *name, jobject loader, const jbyte *buf, jsize len, jobject pd, const char *source))
a61af66fc99e Initial load
duke
parents:
diff changeset
886 JVMWrapper2("JVM_DefineClassWithSource %s", name);
a61af66fc99e Initial load
duke
parents:
diff changeset
887
973
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
888 return jvm_define_class_common(env, name, loader, buf, len, pd, source, true, THREAD);
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
889 JVM_END
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
890
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
891 JVM_ENTRY(jclass, JVM_DefineClassWithSourceCond(JNIEnv *env, const char *name,
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
892 jobject loader, const jbyte *buf,
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
893 jsize len, jobject pd,
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
894 const char *source, jboolean verify))
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
895 JVMWrapper2("JVM_DefineClassWithSourceCond %s", name);
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
896
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
897 return jvm_define_class_common(env, name, loader, buf, len, pd, source, verify, THREAD);
ad6585fd4087 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 878
diff changeset
898 JVM_END
0
a61af66fc99e Initial load
duke
parents:
diff changeset
899
a61af66fc99e Initial load
duke
parents:
diff changeset
900 JVM_ENTRY(jclass, JVM_FindLoadedClass(JNIEnv *env, jobject loader, jstring name))
a61af66fc99e Initial load
duke
parents:
diff changeset
901 JVMWrapper("JVM_FindLoadedClass");
a61af66fc99e Initial load
duke
parents:
diff changeset
902 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
903
a61af66fc99e Initial load
duke
parents:
diff changeset
904 Handle h_name (THREAD, JNIHandles::resolve_non_null(name));
a61af66fc99e Initial load
duke
parents:
diff changeset
905 Handle string = java_lang_String::internalize_classname(h_name, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
906
a61af66fc99e Initial load
duke
parents:
diff changeset
907 const char* str = java_lang_String::as_utf8_string(string());
a61af66fc99e Initial load
duke
parents:
diff changeset
908 // Sanity check, don't expect null
a61af66fc99e Initial load
duke
parents:
diff changeset
909 if (str == NULL) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
910
a61af66fc99e Initial load
duke
parents:
diff changeset
911 const int str_len = (int)strlen(str);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
912 if (str_len > Symbol::max_length()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
913 // It's impossible to create this class; the name cannot fit
a61af66fc99e Initial load
duke
parents:
diff changeset
914 // into the constant pool.
a61af66fc99e Initial load
duke
parents:
diff changeset
915 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
916 }
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
917 TempNewSymbol klass_name = SymbolTable::new_symbol(str, str_len, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
918
a61af66fc99e Initial load
duke
parents:
diff changeset
919 // Security Note:
a61af66fc99e Initial load
duke
parents:
diff changeset
920 // The Java level wrapper will perform the necessary security check allowing
a61af66fc99e Initial load
duke
parents:
diff changeset
921 // us to pass the NULL as the initiating class loader.
a61af66fc99e Initial load
duke
parents:
diff changeset
922 Handle h_loader(THREAD, JNIHandles::resolve(loader));
a61af66fc99e Initial load
duke
parents:
diff changeset
923 if (UsePerfData) {
a61af66fc99e Initial load
duke
parents:
diff changeset
924 is_lock_held_by_thread(h_loader,
a61af66fc99e Initial load
duke
parents:
diff changeset
925 ClassLoader::sync_JVMFindLoadedClassLockFreeCounter(),
a61af66fc99e Initial load
duke
parents:
diff changeset
926 THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
927 }
a61af66fc99e Initial load
duke
parents:
diff changeset
928
a61af66fc99e Initial load
duke
parents:
diff changeset
929 klassOop k = SystemDictionary::find_instance_or_array_klass(klass_name,
a61af66fc99e Initial load
duke
parents:
diff changeset
930 h_loader,
a61af66fc99e Initial load
duke
parents:
diff changeset
931 Handle(),
a61af66fc99e Initial load
duke
parents:
diff changeset
932 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
933
a61af66fc99e Initial load
duke
parents:
diff changeset
934 return (k == NULL) ? NULL :
a61af66fc99e Initial load
duke
parents:
diff changeset
935 (jclass) JNIHandles::make_local(env, Klass::cast(k)->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
936 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
937
a61af66fc99e Initial load
duke
parents:
diff changeset
938
a61af66fc99e Initial load
duke
parents:
diff changeset
939 // Reflection support //////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
940
a61af66fc99e Initial load
duke
parents:
diff changeset
941 JVM_ENTRY(jstring, JVM_GetClassName(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
942 assert (cls != NULL, "illegal class");
a61af66fc99e Initial load
duke
parents:
diff changeset
943 JVMWrapper("JVM_GetClassName");
a61af66fc99e Initial load
duke
parents:
diff changeset
944 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
945 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
946 const char* name;
a61af66fc99e Initial load
duke
parents:
diff changeset
947 if (java_lang_Class::is_primitive(JNIHandles::resolve(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
948 name = type2name(java_lang_Class::primitive_type(JNIHandles::resolve(cls)));
a61af66fc99e Initial load
duke
parents:
diff changeset
949 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
950 // Consider caching interned string in Klass
a61af66fc99e Initial load
duke
parents:
diff changeset
951 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
952 assert(k->is_klass(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
953 name = Klass::cast(k)->external_name();
a61af66fc99e Initial load
duke
parents:
diff changeset
954 }
a61af66fc99e Initial load
duke
parents:
diff changeset
955 oop result = StringTable::intern((char*) name, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
956 return (jstring) JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
957 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
958
a61af66fc99e Initial load
duke
parents:
diff changeset
959
a61af66fc99e Initial load
duke
parents:
diff changeset
960 JVM_ENTRY(jobjectArray, JVM_GetClassInterfaces(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
961 JVMWrapper("JVM_GetClassInterfaces");
a61af66fc99e Initial load
duke
parents:
diff changeset
962 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
963 oop mirror = JNIHandles::resolve_non_null(cls);
a61af66fc99e Initial load
duke
parents:
diff changeset
964
a61af66fc99e Initial load
duke
parents:
diff changeset
965 // Special handling for primitive objects
a61af66fc99e Initial load
duke
parents:
diff changeset
966 if (java_lang_Class::is_primitive(mirror)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
967 // Primitive objects does not have any interfaces
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
968 objArrayOop r = oopFactory::new_objArray(SystemDictionary::Class_klass(), 0, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
969 return (jobjectArray) JNIHandles::make_local(env, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
970 }
a61af66fc99e Initial load
duke
parents:
diff changeset
971
a61af66fc99e Initial load
duke
parents:
diff changeset
972 KlassHandle klass(thread, java_lang_Class::as_klassOop(mirror));
a61af66fc99e Initial load
duke
parents:
diff changeset
973 // Figure size of result array
a61af66fc99e Initial load
duke
parents:
diff changeset
974 int size;
a61af66fc99e Initial load
duke
parents:
diff changeset
975 if (klass->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
976 size = instanceKlass::cast(klass())->local_interfaces()->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
977 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
978 assert(klass->oop_is_objArray() || klass->oop_is_typeArray(), "Illegal mirror klass");
a61af66fc99e Initial load
duke
parents:
diff changeset
979 size = 2;
a61af66fc99e Initial load
duke
parents:
diff changeset
980 }
a61af66fc99e Initial load
duke
parents:
diff changeset
981
a61af66fc99e Initial load
duke
parents:
diff changeset
982 // Allocate result array
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
983 objArrayOop r = oopFactory::new_objArray(SystemDictionary::Class_klass(), size, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
984 objArrayHandle result (THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
985 // Fill in result
a61af66fc99e Initial load
duke
parents:
diff changeset
986 if (klass->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
987 // Regular instance klass, fill in all local interfaces
a61af66fc99e Initial load
duke
parents:
diff changeset
988 for (int index = 0; index < size; index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
989 klassOop k = klassOop(instanceKlass::cast(klass())->local_interfaces()->obj_at(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
990 result->obj_at_put(index, Klass::cast(k)->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
991 }
a61af66fc99e Initial load
duke
parents:
diff changeset
992 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
993 // All arrays implement java.lang.Cloneable and java.io.Serializable
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
994 result->obj_at_put(0, Klass::cast(SystemDictionary::Cloneable_klass())->java_mirror());
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
995 result->obj_at_put(1, Klass::cast(SystemDictionary::Serializable_klass())->java_mirror());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
996 }
a61af66fc99e Initial load
duke
parents:
diff changeset
997 return (jobjectArray) JNIHandles::make_local(env, result());
a61af66fc99e Initial load
duke
parents:
diff changeset
998 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
999
a61af66fc99e Initial load
duke
parents:
diff changeset
1000
a61af66fc99e Initial load
duke
parents:
diff changeset
1001 JVM_ENTRY(jobject, JVM_GetClassLoader(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1002 JVMWrapper("JVM_GetClassLoader");
a61af66fc99e Initial load
duke
parents:
diff changeset
1003 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1004 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1005 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1006 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1007 oop loader = Klass::cast(k)->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
1008 return JNIHandles::make_local(env, loader);
a61af66fc99e Initial load
duke
parents:
diff changeset
1009 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1010
a61af66fc99e Initial load
duke
parents:
diff changeset
1011
a61af66fc99e Initial load
duke
parents:
diff changeset
1012 JVM_QUICK_ENTRY(jboolean, JVM_IsInterface(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1013 JVMWrapper("JVM_IsInterface");
a61af66fc99e Initial load
duke
parents:
diff changeset
1014 oop mirror = JNIHandles::resolve_non_null(cls);
a61af66fc99e Initial load
duke
parents:
diff changeset
1015 if (java_lang_Class::is_primitive(mirror)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1016 return JNI_FALSE;
a61af66fc99e Initial load
duke
parents:
diff changeset
1017 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1018 klassOop k = java_lang_Class::as_klassOop(mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1019 jboolean result = Klass::cast(k)->is_interface();
a61af66fc99e Initial load
duke
parents:
diff changeset
1020 assert(!result || Klass::cast(k)->oop_is_instance(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1021 "all interfaces are instance types");
a61af66fc99e Initial load
duke
parents:
diff changeset
1022 // The compiler intrinsic for isInterface tests the
a61af66fc99e Initial load
duke
parents:
diff changeset
1023 // Klass::_access_flags bits in the same way.
a61af66fc99e Initial load
duke
parents:
diff changeset
1024 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1025 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1026
a61af66fc99e Initial load
duke
parents:
diff changeset
1027
a61af66fc99e Initial load
duke
parents:
diff changeset
1028 JVM_ENTRY(jobjectArray, JVM_GetClassSigners(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1029 JVMWrapper("JVM_GetClassSigners");
a61af66fc99e Initial load
duke
parents:
diff changeset
1030 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1031 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1032 // There are no signers for primitive types
a61af66fc99e Initial load
duke
parents:
diff changeset
1033 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1034 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1035
a61af66fc99e Initial load
duke
parents:
diff changeset
1036 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1037 objArrayOop signers = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1038 if (Klass::cast(k)->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1039 signers = instanceKlass::cast(k)->signers();
a61af66fc99e Initial load
duke
parents:
diff changeset
1040 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1041
a61af66fc99e Initial load
duke
parents:
diff changeset
1042 // If there are no signers set in the class, or if the class
a61af66fc99e Initial load
duke
parents:
diff changeset
1043 // is an array, return NULL.
a61af66fc99e Initial load
duke
parents:
diff changeset
1044 if (signers == NULL) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1045
a61af66fc99e Initial load
duke
parents:
diff changeset
1046 // copy of the signers array
a61af66fc99e Initial load
duke
parents:
diff changeset
1047 klassOop element = objArrayKlass::cast(signers->klass())->element_klass();
a61af66fc99e Initial load
duke
parents:
diff changeset
1048 objArrayOop signers_copy = oopFactory::new_objArray(element, signers->length(), CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1049 for (int index = 0; index < signers->length(); index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1050 signers_copy->obj_at_put(index, signers->obj_at(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
1051 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1052
a61af66fc99e Initial load
duke
parents:
diff changeset
1053 // return the copy
a61af66fc99e Initial load
duke
parents:
diff changeset
1054 return (jobjectArray) JNIHandles::make_local(env, signers_copy);
a61af66fc99e Initial load
duke
parents:
diff changeset
1055 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1056
a61af66fc99e Initial load
duke
parents:
diff changeset
1057
a61af66fc99e Initial load
duke
parents:
diff changeset
1058 JVM_ENTRY(void, JVM_SetClassSigners(JNIEnv *env, jclass cls, jobjectArray signers))
a61af66fc99e Initial load
duke
parents:
diff changeset
1059 JVMWrapper("JVM_SetClassSigners");
a61af66fc99e Initial load
duke
parents:
diff changeset
1060 if (!java_lang_Class::is_primitive(JNIHandles::resolve_non_null(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1061 // This call is ignored for primitive types and arrays.
a61af66fc99e Initial load
duke
parents:
diff changeset
1062 // Signers are only set once, ClassLoader.java, and thus shouldn't
a61af66fc99e Initial load
duke
parents:
diff changeset
1063 // be called with an array. Only the bootstrap loader creates arrays.
a61af66fc99e Initial load
duke
parents:
diff changeset
1064 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1065 if (Klass::cast(k)->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1066 instanceKlass::cast(k)->set_signers(objArrayOop(JNIHandles::resolve(signers)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1067 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1068 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1069 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1070
a61af66fc99e Initial load
duke
parents:
diff changeset
1071
a61af66fc99e Initial load
duke
parents:
diff changeset
1072 JVM_ENTRY(jobject, JVM_GetProtectionDomain(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1073 JVMWrapper("JVM_GetProtectionDomain");
a61af66fc99e Initial load
duke
parents:
diff changeset
1074 if (JNIHandles::resolve(cls) == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1075 THROW_(vmSymbols::java_lang_NullPointerException(), NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1076 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1077
a61af66fc99e Initial load
duke
parents:
diff changeset
1078 if (java_lang_Class::is_primitive(JNIHandles::resolve(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1079 // Primitive types does not have a protection domain.
a61af66fc99e Initial load
duke
parents:
diff changeset
1080 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1081 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1082
a61af66fc99e Initial load
duke
parents:
diff changeset
1083 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1084 return (jobject) JNIHandles::make_local(env, Klass::cast(k)->protection_domain());
a61af66fc99e Initial load
duke
parents:
diff changeset
1085 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1086
a61af66fc99e Initial load
duke
parents:
diff changeset
1087
a61af66fc99e Initial load
duke
parents:
diff changeset
1088 // Obsolete since 1.2 (Class.setProtectionDomain removed), although
a61af66fc99e Initial load
duke
parents:
diff changeset
1089 // still defined in core libraries as of 1.5.
a61af66fc99e Initial load
duke
parents:
diff changeset
1090 JVM_ENTRY(void, JVM_SetProtectionDomain(JNIEnv *env, jclass cls, jobject protection_domain))
a61af66fc99e Initial load
duke
parents:
diff changeset
1091 JVMWrapper("JVM_SetProtectionDomain");
a61af66fc99e Initial load
duke
parents:
diff changeset
1092 if (JNIHandles::resolve(cls) == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1093 THROW(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
1094 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1095 if (!java_lang_Class::is_primitive(JNIHandles::resolve(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1096 // Call is ignored for primitive types
a61af66fc99e Initial load
duke
parents:
diff changeset
1097 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1098
a61af66fc99e Initial load
duke
parents:
diff changeset
1099 // cls won't be an array, as this called only from ClassLoader.defineClass
a61af66fc99e Initial load
duke
parents:
diff changeset
1100 if (Klass::cast(k)->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1101 oop pd = JNIHandles::resolve(protection_domain);
a61af66fc99e Initial load
duke
parents:
diff changeset
1102 assert(pd == NULL || pd->is_oop(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
1103 instanceKlass::cast(k)->set_protection_domain(pd);
a61af66fc99e Initial load
duke
parents:
diff changeset
1104 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1105 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1106 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1107
a61af66fc99e Initial load
duke
parents:
diff changeset
1108
a61af66fc99e Initial load
duke
parents:
diff changeset
1109 JVM_ENTRY(jobject, JVM_DoPrivileged(JNIEnv *env, jclass cls, jobject action, jobject context, jboolean wrapException))
a61af66fc99e Initial load
duke
parents:
diff changeset
1110 JVMWrapper("JVM_DoPrivileged");
a61af66fc99e Initial load
duke
parents:
diff changeset
1111
a61af66fc99e Initial load
duke
parents:
diff changeset
1112 if (action == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1113 THROW_MSG_0(vmSymbols::java_lang_NullPointerException(), "Null action");
a61af66fc99e Initial load
duke
parents:
diff changeset
1114 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1115
a61af66fc99e Initial load
duke
parents:
diff changeset
1116 // Stack allocated list of privileged stack elements
a61af66fc99e Initial load
duke
parents:
diff changeset
1117 PrivilegedElement pi;
a61af66fc99e Initial load
duke
parents:
diff changeset
1118
a61af66fc99e Initial load
duke
parents:
diff changeset
1119 // Check that action object understands "Object run()"
a61af66fc99e Initial load
duke
parents:
diff changeset
1120 Handle object (THREAD, JNIHandles::resolve(action));
a61af66fc99e Initial load
duke
parents:
diff changeset
1121
a61af66fc99e Initial load
duke
parents:
diff changeset
1122 // get run() method
a61af66fc99e Initial load
duke
parents:
diff changeset
1123 methodOop m_oop = Klass::cast(object->klass())->uncached_lookup_method(
a61af66fc99e Initial load
duke
parents:
diff changeset
1124 vmSymbols::run_method_name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1125 vmSymbols::void_object_signature());
a61af66fc99e Initial load
duke
parents:
diff changeset
1126 methodHandle m (THREAD, m_oop);
a61af66fc99e Initial load
duke
parents:
diff changeset
1127 if (m.is_null() || !m->is_method() || !methodOop(m())->is_public() || methodOop(m())->is_static()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1128 THROW_MSG_0(vmSymbols::java_lang_InternalError(), "No run method");
a61af66fc99e Initial load
duke
parents:
diff changeset
1129 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1130
a61af66fc99e Initial load
duke
parents:
diff changeset
1131 // Compute the frame initiating the do privileged operation and setup the privileged stack
a61af66fc99e Initial load
duke
parents:
diff changeset
1132 vframeStream vfst(thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
1133 vfst.security_get_caller_frame(1);
a61af66fc99e Initial load
duke
parents:
diff changeset
1134
a61af66fc99e Initial load
duke
parents:
diff changeset
1135 if (!vfst.at_end()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1136 pi.initialize(&vfst, JNIHandles::resolve(context), thread->privileged_stack_top(), CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1137 thread->set_privileged_stack_top(&pi);
a61af66fc99e Initial load
duke
parents:
diff changeset
1138 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1139
a61af66fc99e Initial load
duke
parents:
diff changeset
1140
a61af66fc99e Initial load
duke
parents:
diff changeset
1141 // invoke the Object run() in the action object. We cannot use call_interface here, since the static type
a61af66fc99e Initial load
duke
parents:
diff changeset
1142 // is not really known - it is either java.security.PrivilegedAction or java.security.PrivilegedExceptionAction
a61af66fc99e Initial load
duke
parents:
diff changeset
1143 Handle pending_exception;
a61af66fc99e Initial load
duke
parents:
diff changeset
1144 JavaValue result(T_OBJECT);
a61af66fc99e Initial load
duke
parents:
diff changeset
1145 JavaCallArguments args(object);
a61af66fc99e Initial load
duke
parents:
diff changeset
1146 JavaCalls::call(&result, m, &args, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
1147
a61af66fc99e Initial load
duke
parents:
diff changeset
1148 // done with action, remove ourselves from the list
a61af66fc99e Initial load
duke
parents:
diff changeset
1149 if (!vfst.at_end()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1150 assert(thread->privileged_stack_top() != NULL && thread->privileged_stack_top() == &pi, "wrong top element");
a61af66fc99e Initial load
duke
parents:
diff changeset
1151 thread->set_privileged_stack_top(thread->privileged_stack_top()->next());
a61af66fc99e Initial load
duke
parents:
diff changeset
1152 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1153
a61af66fc99e Initial load
duke
parents:
diff changeset
1154 if (HAS_PENDING_EXCEPTION) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1155 pending_exception = Handle(THREAD, PENDING_EXCEPTION);
a61af66fc99e Initial load
duke
parents:
diff changeset
1156 CLEAR_PENDING_EXCEPTION;
a61af66fc99e Initial load
duke
parents:
diff changeset
1157
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1158 if ( pending_exception->is_a(SystemDictionary::Exception_klass()) &&
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1159 !pending_exception->is_a(SystemDictionary::RuntimeException_klass())) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1160 // Throw a java.security.PrivilegedActionException(Exception e) exception
a61af66fc99e Initial load
duke
parents:
diff changeset
1161 JavaCallArguments args(pending_exception);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1162 THROW_ARG_0(vmSymbols::java_security_PrivilegedActionException(),
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1163 vmSymbols::exception_void_signature(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1164 &args);
a61af66fc99e Initial load
duke
parents:
diff changeset
1165 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1166 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1167
a61af66fc99e Initial load
duke
parents:
diff changeset
1168 if (pending_exception.not_null()) THROW_OOP_0(pending_exception());
a61af66fc99e Initial load
duke
parents:
diff changeset
1169 return JNIHandles::make_local(env, (oop) result.get_jobject());
a61af66fc99e Initial load
duke
parents:
diff changeset
1170 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1171
a61af66fc99e Initial load
duke
parents:
diff changeset
1172
a61af66fc99e Initial load
duke
parents:
diff changeset
1173 // Returns the inherited_access_control_context field of the running thread.
a61af66fc99e Initial load
duke
parents:
diff changeset
1174 JVM_ENTRY(jobject, JVM_GetInheritedAccessControlContext(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1175 JVMWrapper("JVM_GetInheritedAccessControlContext");
a61af66fc99e Initial load
duke
parents:
diff changeset
1176 oop result = java_lang_Thread::inherited_access_control_context(thread->threadObj());
a61af66fc99e Initial load
duke
parents:
diff changeset
1177 return JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
1178 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1179
a61af66fc99e Initial load
duke
parents:
diff changeset
1180 class RegisterArrayForGC {
a61af66fc99e Initial load
duke
parents:
diff changeset
1181 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
1182 JavaThread *_thread;
a61af66fc99e Initial load
duke
parents:
diff changeset
1183 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
1184 RegisterArrayForGC(JavaThread *thread, GrowableArray<oop>* array) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1185 _thread = thread;
a61af66fc99e Initial load
duke
parents:
diff changeset
1186 _thread->register_array_for_gc(array);
a61af66fc99e Initial load
duke
parents:
diff changeset
1187 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1188
a61af66fc99e Initial load
duke
parents:
diff changeset
1189 ~RegisterArrayForGC() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1190 _thread->register_array_for_gc(NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1191 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1192 };
a61af66fc99e Initial load
duke
parents:
diff changeset
1193
a61af66fc99e Initial load
duke
parents:
diff changeset
1194
a61af66fc99e Initial load
duke
parents:
diff changeset
1195 JVM_ENTRY(jobject, JVM_GetStackAccessControlContext(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1196 JVMWrapper("JVM_GetStackAccessControlContext");
a61af66fc99e Initial load
duke
parents:
diff changeset
1197 if (!UsePrivilegedStack) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1198
a61af66fc99e Initial load
duke
parents:
diff changeset
1199 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
1200 GrowableArray<oop>* local_array = new GrowableArray<oop>(12);
a61af66fc99e Initial load
duke
parents:
diff changeset
1201 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1202
a61af66fc99e Initial load
duke
parents:
diff changeset
1203 // count the protection domains on the execution stack. We collapse
a61af66fc99e Initial load
duke
parents:
diff changeset
1204 // duplicate consecutive protection domains into a single one, as
a61af66fc99e Initial load
duke
parents:
diff changeset
1205 // well as stopping when we hit a privileged frame.
a61af66fc99e Initial load
duke
parents:
diff changeset
1206
a61af66fc99e Initial load
duke
parents:
diff changeset
1207 // Use vframeStream to iterate through Java frames
a61af66fc99e Initial load
duke
parents:
diff changeset
1208 vframeStream vfst(thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
1209
a61af66fc99e Initial load
duke
parents:
diff changeset
1210 oop previous_protection_domain = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1211 Handle privileged_context(thread, NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1212 bool is_privileged = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
1213 oop protection_domain = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1214
a61af66fc99e Initial load
duke
parents:
diff changeset
1215 for(; !vfst.at_end(); vfst.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1216 // get method of frame
a61af66fc99e Initial load
duke
parents:
diff changeset
1217 methodOop method = vfst.method();
a61af66fc99e Initial load
duke
parents:
diff changeset
1218 intptr_t* frame_id = vfst.frame_id();
a61af66fc99e Initial load
duke
parents:
diff changeset
1219
a61af66fc99e Initial load
duke
parents:
diff changeset
1220 // check the privileged frames to see if we have a match
a61af66fc99e Initial load
duke
parents:
diff changeset
1221 if (thread->privileged_stack_top() && thread->privileged_stack_top()->frame_id() == frame_id) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1222 // this frame is privileged
a61af66fc99e Initial load
duke
parents:
diff changeset
1223 is_privileged = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
1224 privileged_context = Handle(thread, thread->privileged_stack_top()->privileged_context());
a61af66fc99e Initial load
duke
parents:
diff changeset
1225 protection_domain = thread->privileged_stack_top()->protection_domain();
a61af66fc99e Initial load
duke
parents:
diff changeset
1226 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
1227 protection_domain = instanceKlass::cast(method->method_holder())->protection_domain();
a61af66fc99e Initial load
duke
parents:
diff changeset
1228 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1229
a61af66fc99e Initial load
duke
parents:
diff changeset
1230 if ((previous_protection_domain != protection_domain) && (protection_domain != NULL)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1231 local_array->push(protection_domain);
a61af66fc99e Initial load
duke
parents:
diff changeset
1232 previous_protection_domain = protection_domain;
a61af66fc99e Initial load
duke
parents:
diff changeset
1233 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1234
a61af66fc99e Initial load
duke
parents:
diff changeset
1235 if (is_privileged) break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1236 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1237
a61af66fc99e Initial load
duke
parents:
diff changeset
1238
a61af66fc99e Initial load
duke
parents:
diff changeset
1239 // either all the domains on the stack were system domains, or
a61af66fc99e Initial load
duke
parents:
diff changeset
1240 // we had a privileged system domain
a61af66fc99e Initial load
duke
parents:
diff changeset
1241 if (local_array->is_empty()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1242 if (is_privileged && privileged_context.is_null()) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1243
a61af66fc99e Initial load
duke
parents:
diff changeset
1244 oop result = java_security_AccessControlContext::create(objArrayHandle(), is_privileged, privileged_context, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1245 return JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
1246 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1247
a61af66fc99e Initial load
duke
parents:
diff changeset
1248 // the resource area must be registered in case of a gc
a61af66fc99e Initial load
duke
parents:
diff changeset
1249 RegisterArrayForGC ragc(thread, local_array);
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1250 objArrayOop context = oopFactory::new_objArray(SystemDictionary::ProtectionDomain_klass(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1251 local_array->length(), CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1252 objArrayHandle h_context(thread, context);
a61af66fc99e Initial load
duke
parents:
diff changeset
1253 for (int index = 0; index < local_array->length(); index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1254 h_context->obj_at_put(index, local_array->at(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
1255 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1256
a61af66fc99e Initial load
duke
parents:
diff changeset
1257 oop result = java_security_AccessControlContext::create(h_context, is_privileged, privileged_context, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1258
a61af66fc99e Initial load
duke
parents:
diff changeset
1259 return JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
1260 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1261
a61af66fc99e Initial load
duke
parents:
diff changeset
1262
a61af66fc99e Initial load
duke
parents:
diff changeset
1263 JVM_QUICK_ENTRY(jboolean, JVM_IsArrayClass(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1264 JVMWrapper("JVM_IsArrayClass");
a61af66fc99e Initial load
duke
parents:
diff changeset
1265 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1266 return (k != NULL) && Klass::cast(k)->oop_is_javaArray() ? true : false;
a61af66fc99e Initial load
duke
parents:
diff changeset
1267 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1268
a61af66fc99e Initial load
duke
parents:
diff changeset
1269
a61af66fc99e Initial load
duke
parents:
diff changeset
1270 JVM_QUICK_ENTRY(jboolean, JVM_IsPrimitiveClass(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1271 JVMWrapper("JVM_IsPrimitiveClass");
a61af66fc99e Initial load
duke
parents:
diff changeset
1272 oop mirror = JNIHandles::resolve_non_null(cls);
a61af66fc99e Initial load
duke
parents:
diff changeset
1273 return (jboolean) java_lang_Class::is_primitive(mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1274 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1275
a61af66fc99e Initial load
duke
parents:
diff changeset
1276
a61af66fc99e Initial load
duke
parents:
diff changeset
1277 JVM_ENTRY(jclass, JVM_GetComponentType(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1278 JVMWrapper("JVM_GetComponentType");
a61af66fc99e Initial load
duke
parents:
diff changeset
1279 oop mirror = JNIHandles::resolve_non_null(cls);
a61af66fc99e Initial load
duke
parents:
diff changeset
1280 oop result = Reflection::array_component_type(mirror, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1281 return (jclass) JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
1282 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1283
a61af66fc99e Initial load
duke
parents:
diff changeset
1284
a61af66fc99e Initial load
duke
parents:
diff changeset
1285 JVM_ENTRY(jint, JVM_GetClassModifiers(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1286 JVMWrapper("JVM_GetClassModifiers");
a61af66fc99e Initial load
duke
parents:
diff changeset
1287 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1288 // Primitive type
a61af66fc99e Initial load
duke
parents:
diff changeset
1289 return JVM_ACC_ABSTRACT | JVM_ACC_FINAL | JVM_ACC_PUBLIC;
a61af66fc99e Initial load
duke
parents:
diff changeset
1290 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1291
a61af66fc99e Initial load
duke
parents:
diff changeset
1292 Klass* k = Klass::cast(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1293 debug_only(int computed_modifiers = k->compute_modifier_flags(CHECK_0));
a61af66fc99e Initial load
duke
parents:
diff changeset
1294 assert(k->modifier_flags() == computed_modifiers, "modifiers cache is OK");
a61af66fc99e Initial load
duke
parents:
diff changeset
1295 return k->modifier_flags();
a61af66fc99e Initial load
duke
parents:
diff changeset
1296 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1297
a61af66fc99e Initial load
duke
parents:
diff changeset
1298
a61af66fc99e Initial load
duke
parents:
diff changeset
1299 // Inner class reflection ///////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
1300
a61af66fc99e Initial load
duke
parents:
diff changeset
1301 JVM_ENTRY(jobjectArray, JVM_GetDeclaredClasses(JNIEnv *env, jclass ofClass))
a61af66fc99e Initial load
duke
parents:
diff changeset
1302 const int inner_class_info_index = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1303 const int outer_class_info_index = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
1304
a61af66fc99e Initial load
duke
parents:
diff changeset
1305 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1306 // ofClass is a reference to a java_lang_Class object. The mirror object
a61af66fc99e Initial load
duke
parents:
diff changeset
1307 // of an instanceKlass
a61af66fc99e Initial load
duke
parents:
diff changeset
1308
a61af66fc99e Initial load
duke
parents:
diff changeset
1309 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(ofClass)) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
1310 ! Klass::cast(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)))->oop_is_instance()) {
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1311 oop result = oopFactory::new_objArray(SystemDictionary::Class_klass(), 0, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1312 return (jobjectArray)JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
1313 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1314
a61af66fc99e Initial load
duke
parents:
diff changeset
1315 instanceKlassHandle k(thread, java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1316
a61af66fc99e Initial load
duke
parents:
diff changeset
1317 if (k->inner_classes()->length() == 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1318 // Neither an inner nor outer class
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1319 oop result = oopFactory::new_objArray(SystemDictionary::Class_klass(), 0, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1320 return (jobjectArray)JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
1321 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1322
a61af66fc99e Initial load
duke
parents:
diff changeset
1323 // find inner class info
a61af66fc99e Initial load
duke
parents:
diff changeset
1324 typeArrayHandle icls(thread, k->inner_classes());
a61af66fc99e Initial load
duke
parents:
diff changeset
1325 constantPoolHandle cp(thread, k->constants());
a61af66fc99e Initial load
duke
parents:
diff changeset
1326 int length = icls->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
1327
a61af66fc99e Initial load
duke
parents:
diff changeset
1328 // Allocate temp. result array
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1329 objArrayOop r = oopFactory::new_objArray(SystemDictionary::Class_klass(), length/4, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1330 objArrayHandle result (THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
1331 int members = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1332
a61af66fc99e Initial load
duke
parents:
diff changeset
1333 for(int i = 0; i < length; i += 4) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1334 int ioff = icls->ushort_at(i + inner_class_info_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1335 int ooff = icls->ushort_at(i + outer_class_info_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1336
a61af66fc99e Initial load
duke
parents:
diff changeset
1337 if (ioff != 0 && ooff != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1338 // Check to see if the name matches the class we're looking for
a61af66fc99e Initial load
duke
parents:
diff changeset
1339 // before attempting to find the class.
a61af66fc99e Initial load
duke
parents:
diff changeset
1340 if (cp->klass_name_at_matches(k, ooff)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1341 klassOop outer_klass = cp->klass_at(ooff, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1342 if (outer_klass == k()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1343 klassOop ik = cp->klass_at(ioff, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1344 instanceKlassHandle inner_klass (THREAD, ik);
a61af66fc99e Initial load
duke
parents:
diff changeset
1345
a61af66fc99e Initial load
duke
parents:
diff changeset
1346 // Throws an exception if outer klass has not declared k as
a61af66fc99e Initial load
duke
parents:
diff changeset
1347 // an inner klass
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1348 Reflection::check_for_inner_class(k, inner_klass, true, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1349
a61af66fc99e Initial load
duke
parents:
diff changeset
1350 result->obj_at_put(members, inner_klass->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
1351 members++;
a61af66fc99e Initial load
duke
parents:
diff changeset
1352 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1353 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1354 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1355 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1356
a61af66fc99e Initial load
duke
parents:
diff changeset
1357 if (members != length) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1358 // Return array of right length
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1359 objArrayOop res = oopFactory::new_objArray(SystemDictionary::Class_klass(), members, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1360 for(int i = 0; i < members; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1361 res->obj_at_put(i, result->obj_at(i));
a61af66fc99e Initial load
duke
parents:
diff changeset
1362 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1363 return (jobjectArray)JNIHandles::make_local(env, res);
a61af66fc99e Initial load
duke
parents:
diff changeset
1364 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1365
a61af66fc99e Initial load
duke
parents:
diff changeset
1366 return (jobjectArray)JNIHandles::make_local(env, result());
a61af66fc99e Initial load
duke
parents:
diff changeset
1367 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1368
a61af66fc99e Initial load
duke
parents:
diff changeset
1369
a61af66fc99e Initial load
duke
parents:
diff changeset
1370 JVM_ENTRY(jclass, JVM_GetDeclaringClass(JNIEnv *env, jclass ofClass))
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1371 {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1372 // ofClass is a reference to a java_lang_Class object.
a61af66fc99e Initial load
duke
parents:
diff changeset
1373 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(ofClass)) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
1374 ! Klass::cast(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)))->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1375 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1376 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1377
1126
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1378 bool inner_is_member = false;
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1379 klassOop outer_klass
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1380 = instanceKlass::cast(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass))
1126
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1381 )->compute_enclosing_class(&inner_is_member, CHECK_NULL);
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1382 if (outer_klass == NULL) return NULL; // already a top-level class
1126
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1383 if (!inner_is_member) return NULL; // an anonymous class (inside a method)
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1384 return (jclass) JNIHandles::make_local(env, Klass::cast(outer_klass)->java_mirror());
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1385 }
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1386 JVM_END
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1387
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1388 // should be in instanceKlass.cpp, but is here for historical reasons
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1389 klassOop instanceKlass::compute_enclosing_class_impl(instanceKlassHandle k,
1126
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1390 bool* inner_is_member,
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1391 TRAPS) {
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1392 Thread* thread = THREAD;
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1393 const int inner_class_info_index = inner_class_inner_class_info_offset;
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1394 const int outer_class_info_index = inner_class_outer_class_info_offset;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1395
a61af66fc99e Initial load
duke
parents:
diff changeset
1396 if (k->inner_classes()->length() == 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1397 // No inner class info => no declaring class
a61af66fc99e Initial load
duke
parents:
diff changeset
1398 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1399 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1400
a61af66fc99e Initial load
duke
parents:
diff changeset
1401 typeArrayHandle i_icls(thread, k->inner_classes());
a61af66fc99e Initial load
duke
parents:
diff changeset
1402 constantPoolHandle i_cp(thread, k->constants());
a61af66fc99e Initial load
duke
parents:
diff changeset
1403 int i_length = i_icls->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
1404
a61af66fc99e Initial load
duke
parents:
diff changeset
1405 bool found = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
1406 klassOop ok;
a61af66fc99e Initial load
duke
parents:
diff changeset
1407 instanceKlassHandle outer_klass;
1126
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1408 *inner_is_member = false;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1409
a61af66fc99e Initial load
duke
parents:
diff changeset
1410 // Find inner_klass attribute
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1411 for (int i = 0; i < i_length && !found; i += inner_class_next_offset) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1412 int ioff = i_icls->ushort_at(i + inner_class_info_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1413 int ooff = i_icls->ushort_at(i + outer_class_info_index);
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1414 int noff = i_icls->ushort_at(i + inner_class_inner_name_offset);
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1415 if (ioff != 0) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1416 // Check to see if the name matches the class we're looking for
a61af66fc99e Initial load
duke
parents:
diff changeset
1417 // before attempting to find the class.
a61af66fc99e Initial load
duke
parents:
diff changeset
1418 if (i_cp->klass_name_at_matches(k, ioff)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1419 klassOop inner_klass = i_cp->klass_at(ioff, CHECK_NULL);
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1420 found = (k() == inner_klass);
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1421 if (found && ooff != 0) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1422 ok = i_cp->klass_at(ooff, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1423 outer_klass = instanceKlassHandle(thread, ok);
1126
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1424 *inner_is_member = true;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1425 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1426 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1427 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1428 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1429
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1430 if (found && outer_klass.is_null()) {
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1431 // It may be anonymous; try for that.
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1432 int encl_method_class_idx = k->enclosing_method_class_index();
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1433 if (encl_method_class_idx != 0) {
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1434 ok = i_cp->klass_at(encl_method_class_idx, CHECK_NULL);
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1435 outer_klass = instanceKlassHandle(thread, ok);
1126
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1436 *inner_is_member = false;
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1437 }
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1438 }
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1439
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1440 // If no inner class attribute found for this class.
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1441 if (outer_klass.is_null()) return NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1442
a61af66fc99e Initial load
duke
parents:
diff changeset
1443 // Throws an exception if outer klass has not declared k as an inner klass
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1444 // We need evidence that each klass knows about the other, or else
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1445 // the system could allow a spoof of an inner class to gain access rights.
1126
933a3e806ce6 6895168: JCK api/signaturetest/sigtest.basic.html#basic test fails for jdk 5.0 with HS 16 in nightly build
xlu
parents: 1059
diff changeset
1446 Reflection::check_for_inner_class(outer_klass, k, *inner_is_member, CHECK_NULL);
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1447 return outer_klass();
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 579
diff changeset
1448 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1449
a61af66fc99e Initial load
duke
parents:
diff changeset
1450 JVM_ENTRY(jstring, JVM_GetClassSignature(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1451 assert (cls != NULL, "illegal class");
a61af66fc99e Initial load
duke
parents:
diff changeset
1452 JVMWrapper("JVM_GetClassSignature");
a61af66fc99e Initial load
duke
parents:
diff changeset
1453 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1454 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
1455 // Return null for arrays and primatives
a61af66fc99e Initial load
duke
parents:
diff changeset
1456 if (!java_lang_Class::is_primitive(JNIHandles::resolve(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1457 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1458 if (Klass::cast(k)->oop_is_instance()) {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1459 Symbol* sym = instanceKlass::cast(k)->generic_signature();
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1460 if (sym == NULL) return NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1461 Handle str = java_lang_String::create_from_symbol(sym, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1462 return (jstring) JNIHandles::make_local(env, str());
a61af66fc99e Initial load
duke
parents:
diff changeset
1463 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1464 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1465 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1466 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1467
a61af66fc99e Initial load
duke
parents:
diff changeset
1468
a61af66fc99e Initial load
duke
parents:
diff changeset
1469 JVM_ENTRY(jbyteArray, JVM_GetClassAnnotations(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1470 assert (cls != NULL, "illegal class");
a61af66fc99e Initial load
duke
parents:
diff changeset
1471 JVMWrapper("JVM_GetClassAnnotations");
a61af66fc99e Initial load
duke
parents:
diff changeset
1472 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
1473 // Return null for arrays and primitives
a61af66fc99e Initial load
duke
parents:
diff changeset
1474 if (!java_lang_Class::is_primitive(JNIHandles::resolve(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1475 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1476 if (Klass::cast(k)->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1477 return (jbyteArray) JNIHandles::make_local(env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1478 instanceKlass::cast(k)->class_annotations());
a61af66fc99e Initial load
duke
parents:
diff changeset
1479 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1480 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1481 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1482 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1483
a61af66fc99e Initial load
duke
parents:
diff changeset
1484
a61af66fc99e Initial load
duke
parents:
diff changeset
1485 JVM_ENTRY(jbyteArray, JVM_GetFieldAnnotations(JNIEnv *env, jobject field))
a61af66fc99e Initial load
duke
parents:
diff changeset
1486 assert(field != NULL, "illegal field");
a61af66fc99e Initial load
duke
parents:
diff changeset
1487 JVMWrapper("JVM_GetFieldAnnotations");
a61af66fc99e Initial load
duke
parents:
diff changeset
1488
a61af66fc99e Initial load
duke
parents:
diff changeset
1489 // some of this code was adapted from from jni_FromReflectedField
a61af66fc99e Initial load
duke
parents:
diff changeset
1490
a61af66fc99e Initial load
duke
parents:
diff changeset
1491 // field is a handle to a java.lang.reflect.Field object
a61af66fc99e Initial load
duke
parents:
diff changeset
1492 oop reflected = JNIHandles::resolve_non_null(field);
a61af66fc99e Initial load
duke
parents:
diff changeset
1493 oop mirror = java_lang_reflect_Field::clazz(reflected);
a61af66fc99e Initial load
duke
parents:
diff changeset
1494 klassOop k = java_lang_Class::as_klassOop(mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1495 int slot = java_lang_reflect_Field::slot(reflected);
a61af66fc99e Initial load
duke
parents:
diff changeset
1496 int modifiers = java_lang_reflect_Field::modifiers(reflected);
a61af66fc99e Initial load
duke
parents:
diff changeset
1497
a61af66fc99e Initial load
duke
parents:
diff changeset
1498 fieldDescriptor fd;
a61af66fc99e Initial load
duke
parents:
diff changeset
1499 KlassHandle kh(THREAD, k);
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
1500 intptr_t offset = instanceKlass::cast(kh())->field_offset(slot);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1501
a61af66fc99e Initial load
duke
parents:
diff changeset
1502 if (modifiers & JVM_ACC_STATIC) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1503 // for static fields we only look in the current class
a61af66fc99e Initial load
duke
parents:
diff changeset
1504 if (!instanceKlass::cast(kh())->find_local_field_from_offset(offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
1505 true, &fd)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1506 assert(false, "cannot find static field");
a61af66fc99e Initial load
duke
parents:
diff changeset
1507 return NULL; // robustness
a61af66fc99e Initial load
duke
parents:
diff changeset
1508 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1509 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
1510 // for instance fields we start with the current class and work
a61af66fc99e Initial load
duke
parents:
diff changeset
1511 // our way up through the superclass chain
a61af66fc99e Initial load
duke
parents:
diff changeset
1512 if (!instanceKlass::cast(kh())->find_field_from_offset(offset, false,
a61af66fc99e Initial load
duke
parents:
diff changeset
1513 &fd)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1514 assert(false, "cannot find instance field");
a61af66fc99e Initial load
duke
parents:
diff changeset
1515 return NULL; // robustness
a61af66fc99e Initial load
duke
parents:
diff changeset
1516 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1517 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1518
a61af66fc99e Initial load
duke
parents:
diff changeset
1519 return (jbyteArray) JNIHandles::make_local(env, fd.annotations());
a61af66fc99e Initial load
duke
parents:
diff changeset
1520 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1521
a61af66fc99e Initial load
duke
parents:
diff changeset
1522
a61af66fc99e Initial load
duke
parents:
diff changeset
1523 static methodOop jvm_get_method_common(jobject method, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1524 // some of this code was adapted from from jni_FromReflectedMethod
a61af66fc99e Initial load
duke
parents:
diff changeset
1525
a61af66fc99e Initial load
duke
parents:
diff changeset
1526 oop reflected = JNIHandles::resolve_non_null(method);
a61af66fc99e Initial load
duke
parents:
diff changeset
1527 oop mirror = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1528 int slot = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1529
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1530 if (reflected->klass() == SystemDictionary::reflect_Constructor_klass()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1531 mirror = java_lang_reflect_Constructor::clazz(reflected);
a61af66fc99e Initial load
duke
parents:
diff changeset
1532 slot = java_lang_reflect_Constructor::slot(reflected);
a61af66fc99e Initial load
duke
parents:
diff changeset
1533 } else {
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1534 assert(reflected->klass() == SystemDictionary::reflect_Method_klass(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1535 "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
1536 mirror = java_lang_reflect_Method::clazz(reflected);
a61af66fc99e Initial load
duke
parents:
diff changeset
1537 slot = java_lang_reflect_Method::slot(reflected);
a61af66fc99e Initial load
duke
parents:
diff changeset
1538 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1539 klassOop k = java_lang_Class::as_klassOop(mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1540
a61af66fc99e Initial load
duke
parents:
diff changeset
1541 KlassHandle kh(THREAD, k);
a61af66fc99e Initial load
duke
parents:
diff changeset
1542 methodOop m = instanceKlass::cast(kh())->method_with_idnum(slot);
a61af66fc99e Initial load
duke
parents:
diff changeset
1543 if (m == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1544 assert(false, "cannot find method");
a61af66fc99e Initial load
duke
parents:
diff changeset
1545 return NULL; // robustness
a61af66fc99e Initial load
duke
parents:
diff changeset
1546 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1547
a61af66fc99e Initial load
duke
parents:
diff changeset
1548 return m;
a61af66fc99e Initial load
duke
parents:
diff changeset
1549 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1550
a61af66fc99e Initial load
duke
parents:
diff changeset
1551
a61af66fc99e Initial load
duke
parents:
diff changeset
1552 JVM_ENTRY(jbyteArray, JVM_GetMethodAnnotations(JNIEnv *env, jobject method))
a61af66fc99e Initial load
duke
parents:
diff changeset
1553 JVMWrapper("JVM_GetMethodAnnotations");
a61af66fc99e Initial load
duke
parents:
diff changeset
1554
a61af66fc99e Initial load
duke
parents:
diff changeset
1555 // method is a handle to a java.lang.reflect.Method object
a61af66fc99e Initial load
duke
parents:
diff changeset
1556 methodOop m = jvm_get_method_common(method, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1557 return (jbyteArray) JNIHandles::make_local(env, m->annotations());
a61af66fc99e Initial load
duke
parents:
diff changeset
1558 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1559
a61af66fc99e Initial load
duke
parents:
diff changeset
1560
a61af66fc99e Initial load
duke
parents:
diff changeset
1561 JVM_ENTRY(jbyteArray, JVM_GetMethodDefaultAnnotationValue(JNIEnv *env, jobject method))
a61af66fc99e Initial load
duke
parents:
diff changeset
1562 JVMWrapper("JVM_GetMethodDefaultAnnotationValue");
a61af66fc99e Initial load
duke
parents:
diff changeset
1563
a61af66fc99e Initial load
duke
parents:
diff changeset
1564 // method is a handle to a java.lang.reflect.Method object
a61af66fc99e Initial load
duke
parents:
diff changeset
1565 methodOop m = jvm_get_method_common(method, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1566 return (jbyteArray) JNIHandles::make_local(env, m->annotation_default());
a61af66fc99e Initial load
duke
parents:
diff changeset
1567 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1568
a61af66fc99e Initial load
duke
parents:
diff changeset
1569
a61af66fc99e Initial load
duke
parents:
diff changeset
1570 JVM_ENTRY(jbyteArray, JVM_GetMethodParameterAnnotations(JNIEnv *env, jobject method))
a61af66fc99e Initial load
duke
parents:
diff changeset
1571 JVMWrapper("JVM_GetMethodParameterAnnotations");
a61af66fc99e Initial load
duke
parents:
diff changeset
1572
a61af66fc99e Initial load
duke
parents:
diff changeset
1573 // method is a handle to a java.lang.reflect.Method object
a61af66fc99e Initial load
duke
parents:
diff changeset
1574 methodOop m = jvm_get_method_common(method, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1575 return (jbyteArray) JNIHandles::make_local(env, m->parameter_annotations());
a61af66fc99e Initial load
duke
parents:
diff changeset
1576 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1577
a61af66fc99e Initial load
duke
parents:
diff changeset
1578
a61af66fc99e Initial load
duke
parents:
diff changeset
1579 // New (JDK 1.4) reflection implementation /////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
1580
a61af66fc99e Initial load
duke
parents:
diff changeset
1581 JVM_ENTRY(jobjectArray, JVM_GetClassDeclaredFields(JNIEnv *env, jclass ofClass, jboolean publicOnly))
a61af66fc99e Initial load
duke
parents:
diff changeset
1582 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1583 JVMWrapper("JVM_GetClassDeclaredFields");
a61af66fc99e Initial load
duke
parents:
diff changeset
1584 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1585
a61af66fc99e Initial load
duke
parents:
diff changeset
1586 // Exclude primitive types and array types
a61af66fc99e Initial load
duke
parents:
diff changeset
1587 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(ofClass)) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
1588 Klass::cast(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)))->oop_is_javaArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1589 // Return empty array
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1590 oop res = oopFactory::new_objArray(SystemDictionary::reflect_Field_klass(), 0, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1591 return (jobjectArray) JNIHandles::make_local(env, res);
a61af66fc99e Initial load
duke
parents:
diff changeset
1592 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1593
a61af66fc99e Initial load
duke
parents:
diff changeset
1594 instanceKlassHandle k(THREAD, java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1595 constantPoolHandle cp(THREAD, k->constants());
a61af66fc99e Initial load
duke
parents:
diff changeset
1596
a61af66fc99e Initial load
duke
parents:
diff changeset
1597 // Ensure class is linked
a61af66fc99e Initial load
duke
parents:
diff changeset
1598 k->link_class(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1599
a61af66fc99e Initial load
duke
parents:
diff changeset
1600 // 4496456 We need to filter out java.lang.Throwable.backtrace
a61af66fc99e Initial load
duke
parents:
diff changeset
1601 bool skip_backtrace = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
1602
a61af66fc99e Initial load
duke
parents:
diff changeset
1603 // Allocate result
a61af66fc99e Initial load
duke
parents:
diff changeset
1604 int num_fields;
a61af66fc99e Initial load
duke
parents:
diff changeset
1605
a61af66fc99e Initial load
duke
parents:
diff changeset
1606 if (publicOnly) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1607 num_fields = 0;
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
1608 for (JavaFieldStream fs(k()); !fs.done(); fs.next()) {
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
1609 if (fs.access_flags().is_public()) ++num_fields;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1610 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1611 } else {
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
1612 num_fields = k->java_fields_count();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1613
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1614 if (k() == SystemDictionary::Throwable_klass()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1615 num_fields--;
a61af66fc99e Initial load
duke
parents:
diff changeset
1616 skip_backtrace = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
1617 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1618 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1619
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1620 objArrayOop r = oopFactory::new_objArray(SystemDictionary::reflect_Field_klass(), num_fields, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1621 objArrayHandle result (THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
1622
a61af66fc99e Initial load
duke
parents:
diff changeset
1623 int out_idx = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1624 fieldDescriptor fd;
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
1625 for (JavaFieldStream fs(k); !fs.done(); fs.next()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1626 if (skip_backtrace) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1627 // 4496456 skip java.lang.Throwable.backtrace
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
1628 int offset = fs.offset();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1629 if (offset == java_lang_Throwable::get_backtrace_offset()) continue;
a61af66fc99e Initial load
duke
parents:
diff changeset
1630 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1631
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
1632 if (!publicOnly || fs.access_flags().is_public()) {
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
1633 fd.initialize(k(), fs.index());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1634 oop field = Reflection::new_field(&fd, UseNewReflection, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1635 result->obj_at_put(out_idx, field);
a61af66fc99e Initial load
duke
parents:
diff changeset
1636 ++out_idx;
a61af66fc99e Initial load
duke
parents:
diff changeset
1637 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1638 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1639 assert(out_idx == num_fields, "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
1640 return (jobjectArray) JNIHandles::make_local(env, result());
a61af66fc99e Initial load
duke
parents:
diff changeset
1641 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1642 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1643
a61af66fc99e Initial load
duke
parents:
diff changeset
1644 JVM_ENTRY(jobjectArray, JVM_GetClassDeclaredMethods(JNIEnv *env, jclass ofClass, jboolean publicOnly))
a61af66fc99e Initial load
duke
parents:
diff changeset
1645 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1646 JVMWrapper("JVM_GetClassDeclaredMethods");
a61af66fc99e Initial load
duke
parents:
diff changeset
1647 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1648
a61af66fc99e Initial load
duke
parents:
diff changeset
1649 // Exclude primitive types and array types
a61af66fc99e Initial load
duke
parents:
diff changeset
1650 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(ofClass))
a61af66fc99e Initial load
duke
parents:
diff changeset
1651 || Klass::cast(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)))->oop_is_javaArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1652 // Return empty array
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1653 oop res = oopFactory::new_objArray(SystemDictionary::reflect_Method_klass(), 0, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1654 return (jobjectArray) JNIHandles::make_local(env, res);
a61af66fc99e Initial load
duke
parents:
diff changeset
1655 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1656
a61af66fc99e Initial load
duke
parents:
diff changeset
1657 instanceKlassHandle k(THREAD, java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1658
a61af66fc99e Initial load
duke
parents:
diff changeset
1659 // Ensure class is linked
a61af66fc99e Initial load
duke
parents:
diff changeset
1660 k->link_class(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1661
a61af66fc99e Initial load
duke
parents:
diff changeset
1662 objArrayHandle methods (THREAD, k->methods());
a61af66fc99e Initial load
duke
parents:
diff changeset
1663 int methods_length = methods->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
1664 int num_methods = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1665
a61af66fc99e Initial load
duke
parents:
diff changeset
1666 int i;
a61af66fc99e Initial load
duke
parents:
diff changeset
1667 for (i = 0; i < methods_length; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1668 methodHandle method(THREAD, (methodOop) methods->obj_at(i));
a61af66fc99e Initial load
duke
parents:
diff changeset
1669 if (!method->is_initializer()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1670 if (!publicOnly || method->is_public()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1671 ++num_methods;
a61af66fc99e Initial load
duke
parents:
diff changeset
1672 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1673 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1674 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1675
a61af66fc99e Initial load
duke
parents:
diff changeset
1676 // Allocate result
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1677 objArrayOop r = oopFactory::new_objArray(SystemDictionary::reflect_Method_klass(), num_methods, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1678 objArrayHandle result (THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
1679
a61af66fc99e Initial load
duke
parents:
diff changeset
1680 int out_idx = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1681 for (i = 0; i < methods_length; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1682 methodHandle method(THREAD, (methodOop) methods->obj_at(i));
a61af66fc99e Initial load
duke
parents:
diff changeset
1683 if (!method->is_initializer()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1684 if (!publicOnly || method->is_public()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1685 oop m = Reflection::new_method(method, UseNewReflection, false, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1686 result->obj_at_put(out_idx, m);
a61af66fc99e Initial load
duke
parents:
diff changeset
1687 ++out_idx;
a61af66fc99e Initial load
duke
parents:
diff changeset
1688 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1689 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1690 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1691 assert(out_idx == num_methods, "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
1692 return (jobjectArray) JNIHandles::make_local(env, result());
a61af66fc99e Initial load
duke
parents:
diff changeset
1693 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1694 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1695
a61af66fc99e Initial load
duke
parents:
diff changeset
1696 JVM_ENTRY(jobjectArray, JVM_GetClassDeclaredConstructors(JNIEnv *env, jclass ofClass, jboolean publicOnly))
a61af66fc99e Initial load
duke
parents:
diff changeset
1697 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1698 JVMWrapper("JVM_GetClassDeclaredConstructors");
a61af66fc99e Initial load
duke
parents:
diff changeset
1699 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1700
a61af66fc99e Initial load
duke
parents:
diff changeset
1701 // Exclude primitive types and array types
a61af66fc99e Initial load
duke
parents:
diff changeset
1702 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(ofClass))
a61af66fc99e Initial load
duke
parents:
diff changeset
1703 || Klass::cast(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)))->oop_is_javaArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1704 // Return empty array
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1705 oop res = oopFactory::new_objArray(SystemDictionary::reflect_Constructor_klass(), 0 , CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1706 return (jobjectArray) JNIHandles::make_local(env, res);
a61af66fc99e Initial load
duke
parents:
diff changeset
1707 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1708
a61af66fc99e Initial load
duke
parents:
diff changeset
1709 instanceKlassHandle k(THREAD, java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1710
a61af66fc99e Initial load
duke
parents:
diff changeset
1711 // Ensure class is linked
a61af66fc99e Initial load
duke
parents:
diff changeset
1712 k->link_class(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1713
a61af66fc99e Initial load
duke
parents:
diff changeset
1714 objArrayHandle methods (THREAD, k->methods());
a61af66fc99e Initial load
duke
parents:
diff changeset
1715 int methods_length = methods->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
1716 int num_constructors = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1717
a61af66fc99e Initial load
duke
parents:
diff changeset
1718 int i;
a61af66fc99e Initial load
duke
parents:
diff changeset
1719 for (i = 0; i < methods_length; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1720 methodHandle method(THREAD, (methodOop) methods->obj_at(i));
a61af66fc99e Initial load
duke
parents:
diff changeset
1721 if (method->is_initializer() && !method->is_static()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1722 if (!publicOnly || method->is_public()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1723 ++num_constructors;
a61af66fc99e Initial load
duke
parents:
diff changeset
1724 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1725 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1726 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1727
a61af66fc99e Initial load
duke
parents:
diff changeset
1728 // Allocate result
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1729 objArrayOop r = oopFactory::new_objArray(SystemDictionary::reflect_Constructor_klass(), num_constructors, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1730 objArrayHandle result(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
1731
a61af66fc99e Initial load
duke
parents:
diff changeset
1732 int out_idx = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1733 for (i = 0; i < methods_length; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1734 methodHandle method(THREAD, (methodOop) methods->obj_at(i));
a61af66fc99e Initial load
duke
parents:
diff changeset
1735 if (method->is_initializer() && !method->is_static()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1736 if (!publicOnly || method->is_public()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1737 oop m = Reflection::new_constructor(method, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1738 result->obj_at_put(out_idx, m);
a61af66fc99e Initial load
duke
parents:
diff changeset
1739 ++out_idx;
a61af66fc99e Initial load
duke
parents:
diff changeset
1740 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1741 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1742 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1743 assert(out_idx == num_constructors, "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
1744 return (jobjectArray) JNIHandles::make_local(env, result());
a61af66fc99e Initial load
duke
parents:
diff changeset
1745 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1746 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1747
a61af66fc99e Initial load
duke
parents:
diff changeset
1748 JVM_ENTRY(jint, JVM_GetClassAccessFlags(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1749 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1750 JVMWrapper("JVM_GetClassAccessFlags");
a61af66fc99e Initial load
duke
parents:
diff changeset
1751 if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1752 // Primitive type
a61af66fc99e Initial load
duke
parents:
diff changeset
1753 return JVM_ACC_ABSTRACT | JVM_ACC_FINAL | JVM_ACC_PUBLIC;
a61af66fc99e Initial load
duke
parents:
diff changeset
1754 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1755
a61af66fc99e Initial load
duke
parents:
diff changeset
1756 Klass* k = Klass::cast(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1757 return k->access_flags().as_int() & JVM_ACC_WRITTEN_FLAGS;
a61af66fc99e Initial load
duke
parents:
diff changeset
1758 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1759 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1760
a61af66fc99e Initial load
duke
parents:
diff changeset
1761
a61af66fc99e Initial load
duke
parents:
diff changeset
1762 // Constant pool access //////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
1763
a61af66fc99e Initial load
duke
parents:
diff changeset
1764 JVM_ENTRY(jobject, JVM_GetClassConstantPool(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
1765 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1766 JVMWrapper("JVM_GetClassConstantPool");
a61af66fc99e Initial load
duke
parents:
diff changeset
1767 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1768
a61af66fc99e Initial load
duke
parents:
diff changeset
1769 // Return null for primitives and arrays
a61af66fc99e Initial load
duke
parents:
diff changeset
1770 if (!java_lang_Class::is_primitive(JNIHandles::resolve_non_null(cls))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1771 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
1772 if (Klass::cast(k)->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1773 instanceKlassHandle k_h(THREAD, k);
a61af66fc99e Initial load
duke
parents:
diff changeset
1774 Handle jcp = sun_reflect_ConstantPool::create(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1775 sun_reflect_ConstantPool::set_cp_oop(jcp(), k_h->constants());
a61af66fc99e Initial load
duke
parents:
diff changeset
1776 return JNIHandles::make_local(jcp());
a61af66fc99e Initial load
duke
parents:
diff changeset
1777 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1778 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1779 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1780 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1781 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1782
a61af66fc99e Initial load
duke
parents:
diff changeset
1783
a61af66fc99e Initial load
duke
parents:
diff changeset
1784 JVM_ENTRY(jint, JVM_ConstantPoolGetSize(JNIEnv *env, jobject unused, jobject jcpool))
a61af66fc99e Initial load
duke
parents:
diff changeset
1785 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1786 JVMWrapper("JVM_ConstantPoolGetSize");
a61af66fc99e Initial load
duke
parents:
diff changeset
1787 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1788 return cp->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
1789 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1790 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1791
a61af66fc99e Initial load
duke
parents:
diff changeset
1792
a61af66fc99e Initial load
duke
parents:
diff changeset
1793 static void bounds_check(constantPoolHandle cp, jint index, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1794 if (!cp->is_within_bounds(index)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1795 THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), "Constant pool index out of bounds");
a61af66fc99e Initial load
duke
parents:
diff changeset
1796 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1797 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1798
a61af66fc99e Initial load
duke
parents:
diff changeset
1799
a61af66fc99e Initial load
duke
parents:
diff changeset
1800 JVM_ENTRY(jclass, JVM_ConstantPoolGetClassAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1801 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1802 JVMWrapper("JVM_ConstantPoolGetClassAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
1803 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1804 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1805 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1806 if (!tag.is_klass() && !tag.is_unresolved_klass()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1807 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
1808 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1809 klassOop k = cp->klass_at(index, CHECK_NULL);
2376
c7f3d0b4570f 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 2191
diff changeset
1810 return (jclass) JNIHandles::make_local(k->java_mirror());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1811 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1812 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1813
a61af66fc99e Initial load
duke
parents:
diff changeset
1814
a61af66fc99e Initial load
duke
parents:
diff changeset
1815 JVM_ENTRY(jclass, JVM_ConstantPoolGetClassAtIfLoaded(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1816 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1817 JVMWrapper("JVM_ConstantPoolGetClassAtIfLoaded");
a61af66fc99e Initial load
duke
parents:
diff changeset
1818 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1819 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1820 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1821 if (!tag.is_klass() && !tag.is_unresolved_klass()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1822 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
1823 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1824 klassOop k = constantPoolOopDesc::klass_at_if_loaded(cp, index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1825 if (k == NULL) return NULL;
2376
c7f3d0b4570f 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 2191
diff changeset
1826 return (jclass) JNIHandles::make_local(k->java_mirror());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1827 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1828 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1829
a61af66fc99e Initial load
duke
parents:
diff changeset
1830 static jobject get_method_at_helper(constantPoolHandle cp, jint index, bool force_resolution, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1831 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1832 if (!tag.is_method() && !tag.is_interface_method()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1833 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
1834 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1835 int klass_ref = cp->uncached_klass_ref_index_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1836 klassOop k_o;
a61af66fc99e Initial load
duke
parents:
diff changeset
1837 if (force_resolution) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1838 k_o = cp->klass_at(klass_ref, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1839 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
1840 k_o = constantPoolOopDesc::klass_at_if_loaded(cp, klass_ref);
a61af66fc99e Initial load
duke
parents:
diff changeset
1841 if (k_o == NULL) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1842 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1843 instanceKlassHandle k(THREAD, k_o);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1844 Symbol* name = cp->uncached_name_ref_at(index);
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1845 Symbol* sig = cp->uncached_signature_ref_at(index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1846 methodHandle m (THREAD, k->find_method(name, sig));
a61af66fc99e Initial load
duke
parents:
diff changeset
1847 if (m.is_null()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1848 THROW_MSG_0(vmSymbols::java_lang_RuntimeException(), "Unable to look up method in target class");
a61af66fc99e Initial load
duke
parents:
diff changeset
1849 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1850 oop method;
a61af66fc99e Initial load
duke
parents:
diff changeset
1851 if (!m->is_initializer() || m->is_static()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1852 method = Reflection::new_method(m, true, true, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1853 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
1854 method = Reflection::new_constructor(m, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1855 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1856 return JNIHandles::make_local(method);
a61af66fc99e Initial load
duke
parents:
diff changeset
1857 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1858
a61af66fc99e Initial load
duke
parents:
diff changeset
1859 JVM_ENTRY(jobject, JVM_ConstantPoolGetMethodAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1860 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1861 JVMWrapper("JVM_ConstantPoolGetMethodAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
1862 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1863 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1864 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1865 jobject res = get_method_at_helper(cp, index, true, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1866 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
1867 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1868 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1869
a61af66fc99e Initial load
duke
parents:
diff changeset
1870 JVM_ENTRY(jobject, JVM_ConstantPoolGetMethodAtIfLoaded(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1871 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1872 JVMWrapper("JVM_ConstantPoolGetMethodAtIfLoaded");
a61af66fc99e Initial load
duke
parents:
diff changeset
1873 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1874 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1875 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1876 jobject res = get_method_at_helper(cp, index, false, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1877 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
1878 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1879 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1880
a61af66fc99e Initial load
duke
parents:
diff changeset
1881 static jobject get_field_at_helper(constantPoolHandle cp, jint index, bool force_resolution, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1882 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1883 if (!tag.is_field()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1884 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
1885 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1886 int klass_ref = cp->uncached_klass_ref_index_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1887 klassOop k_o;
a61af66fc99e Initial load
duke
parents:
diff changeset
1888 if (force_resolution) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1889 k_o = cp->klass_at(klass_ref, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1890 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
1891 k_o = constantPoolOopDesc::klass_at_if_loaded(cp, klass_ref);
a61af66fc99e Initial load
duke
parents:
diff changeset
1892 if (k_o == NULL) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1893 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1894 instanceKlassHandle k(THREAD, k_o);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1895 Symbol* name = cp->uncached_name_ref_at(index);
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1896 Symbol* sig = cp->uncached_signature_ref_at(index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1897 fieldDescriptor fd;
a61af66fc99e Initial load
duke
parents:
diff changeset
1898 klassOop target_klass = k->find_field(name, sig, &fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
1899 if (target_klass == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1900 THROW_MSG_0(vmSymbols::java_lang_RuntimeException(), "Unable to look up field in target class");
a61af66fc99e Initial load
duke
parents:
diff changeset
1901 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1902 oop field = Reflection::new_field(&fd, true, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1903 return JNIHandles::make_local(field);
a61af66fc99e Initial load
duke
parents:
diff changeset
1904 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1905
a61af66fc99e Initial load
duke
parents:
diff changeset
1906 JVM_ENTRY(jobject, JVM_ConstantPoolGetFieldAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1907 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1908 JVMWrapper("JVM_ConstantPoolGetFieldAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
1909 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1910 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1911 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1912 jobject res = get_field_at_helper(cp, index, true, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1913 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
1914 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1915 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1916
a61af66fc99e Initial load
duke
parents:
diff changeset
1917 JVM_ENTRY(jobject, JVM_ConstantPoolGetFieldAtIfLoaded(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1918 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1919 JVMWrapper("JVM_ConstantPoolGetFieldAtIfLoaded");
a61af66fc99e Initial load
duke
parents:
diff changeset
1920 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1921 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1922 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1923 jobject res = get_field_at_helper(cp, index, false, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1924 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
1925 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1926 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1927
a61af66fc99e Initial load
duke
parents:
diff changeset
1928 JVM_ENTRY(jobjectArray, JVM_ConstantPoolGetMemberRefInfoAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1929 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1930 JVMWrapper("JVM_ConstantPoolGetMemberRefInfoAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
1931 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
1932 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1933 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1934 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1935 if (!tag.is_field_or_method()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1936 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
1937 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1938 int klass_ref = cp->uncached_klass_ref_index_at(index);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1939 Symbol* klass_name = cp->klass_name_at(klass_ref);
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1940 Symbol* member_name = cp->uncached_name_ref_at(index);
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
1941 Symbol* member_sig = cp->uncached_signature_ref_at(index);
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
1942 objArrayOop dest_o = oopFactory::new_objArray(SystemDictionary::String_klass(), 3, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1943 objArrayHandle dest(THREAD, dest_o);
a61af66fc99e Initial load
duke
parents:
diff changeset
1944 Handle str = java_lang_String::create_from_symbol(klass_name, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1945 dest->obj_at_put(0, str());
a61af66fc99e Initial load
duke
parents:
diff changeset
1946 str = java_lang_String::create_from_symbol(member_name, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1947 dest->obj_at_put(1, str());
a61af66fc99e Initial load
duke
parents:
diff changeset
1948 str = java_lang_String::create_from_symbol(member_sig, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1949 dest->obj_at_put(2, str());
a61af66fc99e Initial load
duke
parents:
diff changeset
1950 return (jobjectArray) JNIHandles::make_local(dest());
a61af66fc99e Initial load
duke
parents:
diff changeset
1951 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1952 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1953
a61af66fc99e Initial load
duke
parents:
diff changeset
1954 JVM_ENTRY(jint, JVM_ConstantPoolGetIntAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1955 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1956 JVMWrapper("JVM_ConstantPoolGetIntAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
1957 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1958 bounds_check(cp, index, CHECK_0);
a61af66fc99e Initial load
duke
parents:
diff changeset
1959 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1960 if (!tag.is_int()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1961 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
1962 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1963 return cp->int_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1964 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1965 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1966
a61af66fc99e Initial load
duke
parents:
diff changeset
1967 JVM_ENTRY(jlong, JVM_ConstantPoolGetLongAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1968 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1969 JVMWrapper("JVM_ConstantPoolGetLongAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
1970 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1971 bounds_check(cp, index, CHECK_(0L));
a61af66fc99e Initial load
duke
parents:
diff changeset
1972 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1973 if (!tag.is_long()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1974 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
1975 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1976 return cp->long_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1977 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1978 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1979
a61af66fc99e Initial load
duke
parents:
diff changeset
1980 JVM_ENTRY(jfloat, JVM_ConstantPoolGetFloatAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1981 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1982 JVMWrapper("JVM_ConstantPoolGetFloatAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
1983 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1984 bounds_check(cp, index, CHECK_(0.0f));
a61af66fc99e Initial load
duke
parents:
diff changeset
1985 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1986 if (!tag.is_float()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1987 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
1988 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1989 return cp->float_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1990 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1991 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1992
a61af66fc99e Initial load
duke
parents:
diff changeset
1993 JVM_ENTRY(jdouble, JVM_ConstantPoolGetDoubleAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1994 {
a61af66fc99e Initial load
duke
parents:
diff changeset
1995 JVMWrapper("JVM_ConstantPoolGetDoubleAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
1996 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1997 bounds_check(cp, index, CHECK_(0.0));
a61af66fc99e Initial load
duke
parents:
diff changeset
1998 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1999 if (!tag.is_double()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2000 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
2001 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2002 return cp->double_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2003 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2004 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2005
a61af66fc99e Initial load
duke
parents:
diff changeset
2006 JVM_ENTRY(jstring, JVM_ConstantPoolGetStringAt(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2007 {
a61af66fc99e Initial load
duke
parents:
diff changeset
2008 JVMWrapper("JVM_ConstantPoolGetStringAt");
a61af66fc99e Initial load
duke
parents:
diff changeset
2009 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
2010 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
2011 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2012 if (!tag.is_string() && !tag.is_unresolved_string()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2013 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
2014 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2015 oop str = cp->string_at(index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
2016 return (jstring) JNIHandles::make_local(str);
a61af66fc99e Initial load
duke
parents:
diff changeset
2017 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2018 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2019
a61af66fc99e Initial load
duke
parents:
diff changeset
2020 JVM_ENTRY(jstring, JVM_ConstantPoolGetUTF8At(JNIEnv *env, jobject unused, jobject jcpool, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2021 {
a61af66fc99e Initial load
duke
parents:
diff changeset
2022 JVMWrapper("JVM_ConstantPoolGetUTF8At");
a61af66fc99e Initial load
duke
parents:
diff changeset
2023 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
2024 constantPoolHandle cp = constantPoolHandle(THREAD, constantPoolOop(JNIHandles::resolve_non_null(jcpool)));
a61af66fc99e Initial load
duke
parents:
diff changeset
2025 bounds_check(cp, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
2026 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2027 if (!tag.is_symbol()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2028 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Wrong type at constant pool index");
a61af66fc99e Initial load
duke
parents:
diff changeset
2029 }
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2030 Symbol* sym = cp->symbol_at(index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2031 Handle str = java_lang_String::create_from_symbol(sym, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
2032 return (jstring) JNIHandles::make_local(str());
a61af66fc99e Initial load
duke
parents:
diff changeset
2033 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2034 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2035
a61af66fc99e Initial load
duke
parents:
diff changeset
2036
a61af66fc99e Initial load
duke
parents:
diff changeset
2037 // Assertion support. //////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
2038
a61af66fc99e Initial load
duke
parents:
diff changeset
2039 JVM_ENTRY(jboolean, JVM_DesiredAssertionStatus(JNIEnv *env, jclass unused, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
2040 JVMWrapper("JVM_DesiredAssertionStatus");
a61af66fc99e Initial load
duke
parents:
diff changeset
2041 assert(cls != NULL, "bad class");
a61af66fc99e Initial load
duke
parents:
diff changeset
2042
a61af66fc99e Initial load
duke
parents:
diff changeset
2043 oop r = JNIHandles::resolve(cls);
a61af66fc99e Initial load
duke
parents:
diff changeset
2044 assert(! java_lang_Class::is_primitive(r), "primitive classes not allowed");
a61af66fc99e Initial load
duke
parents:
diff changeset
2045 if (java_lang_Class::is_primitive(r)) return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2046
a61af66fc99e Initial load
duke
parents:
diff changeset
2047 klassOop k = java_lang_Class::as_klassOop(r);
a61af66fc99e Initial load
duke
parents:
diff changeset
2048 assert(Klass::cast(k)->oop_is_instance(), "must be an instance klass");
a61af66fc99e Initial load
duke
parents:
diff changeset
2049 if (! Klass::cast(k)->oop_is_instance()) return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2050
a61af66fc99e Initial load
duke
parents:
diff changeset
2051 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
2052 const char* name = Klass::cast(k)->name()->as_C_string();
a61af66fc99e Initial load
duke
parents:
diff changeset
2053 bool system_class = Klass::cast(k)->class_loader() == NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2054 return JavaAssertions::enabled(name, system_class);
a61af66fc99e Initial load
duke
parents:
diff changeset
2055
a61af66fc99e Initial load
duke
parents:
diff changeset
2056 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2057
a61af66fc99e Initial load
duke
parents:
diff changeset
2058
a61af66fc99e Initial load
duke
parents:
diff changeset
2059 // Return a new AssertionStatusDirectives object with the fields filled in with
a61af66fc99e Initial load
duke
parents:
diff changeset
2060 // command-line assertion arguments (i.e., -ea, -da).
a61af66fc99e Initial load
duke
parents:
diff changeset
2061 JVM_ENTRY(jobject, JVM_AssertionStatusDirectives(JNIEnv *env, jclass unused))
a61af66fc99e Initial load
duke
parents:
diff changeset
2062 JVMWrapper("JVM_AssertionStatusDirectives");
a61af66fc99e Initial load
duke
parents:
diff changeset
2063 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
2064 oop asd = JavaAssertions::createAssertionStatusDirectives(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
2065 return JNIHandles::make_local(env, asd);
a61af66fc99e Initial load
duke
parents:
diff changeset
2066 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2067
a61af66fc99e Initial load
duke
parents:
diff changeset
2068 // Verification ////////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
2069
a61af66fc99e Initial load
duke
parents:
diff changeset
2070 // Reflection for the verifier /////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
2071
a61af66fc99e Initial load
duke
parents:
diff changeset
2072 // RedefineClasses support: bug 6214132 caused verification to fail.
a61af66fc99e Initial load
duke
parents:
diff changeset
2073 // All functions from this section should call the jvmtiThreadSate function:
a61af66fc99e Initial load
duke
parents:
diff changeset
2074 // klassOop class_to_verify_considering_redefinition(klassOop klass).
a61af66fc99e Initial load
duke
parents:
diff changeset
2075 // The function returns a klassOop of the _scratch_class if the verifier
a61af66fc99e Initial load
duke
parents:
diff changeset
2076 // was invoked in the middle of the class redefinition.
a61af66fc99e Initial load
duke
parents:
diff changeset
2077 // Otherwise it returns its argument value which is the _the_class klassOop.
a61af66fc99e Initial load
duke
parents:
diff changeset
2078 // Please, refer to the description in the jvmtiThreadSate.hpp.
a61af66fc99e Initial load
duke
parents:
diff changeset
2079
a61af66fc99e Initial load
duke
parents:
diff changeset
2080 JVM_ENTRY(const char*, JVM_GetClassNameUTF(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
2081 JVMWrapper("JVM_GetClassNameUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2082 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2083 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2084 return Klass::cast(k)->name()->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2085 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2086
a61af66fc99e Initial load
duke
parents:
diff changeset
2087
a61af66fc99e Initial load
duke
parents:
diff changeset
2088 JVM_QUICK_ENTRY(void, JVM_GetClassCPTypes(JNIEnv *env, jclass cls, unsigned char *types))
a61af66fc99e Initial load
duke
parents:
diff changeset
2089 JVMWrapper("JVM_GetClassCPTypes");
a61af66fc99e Initial load
duke
parents:
diff changeset
2090 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2091 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2092 // types will have length zero if this is not an instanceKlass
a61af66fc99e Initial load
duke
parents:
diff changeset
2093 // (length is determined by call to JVM_GetClassCPEntriesCount)
a61af66fc99e Initial load
duke
parents:
diff changeset
2094 if (Klass::cast(k)->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2095 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2096 for (int index = cp->length() - 1; index >= 0; index--) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2097 constantTag tag = cp->tag_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2098 types[index] = (tag.is_unresolved_klass()) ? JVM_CONSTANT_Class :
a61af66fc99e Initial load
duke
parents:
diff changeset
2099 (tag.is_unresolved_string()) ? JVM_CONSTANT_String : tag.value();
a61af66fc99e Initial load
duke
parents:
diff changeset
2100 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2101 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2102 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2103
a61af66fc99e Initial load
duke
parents:
diff changeset
2104
a61af66fc99e Initial load
duke
parents:
diff changeset
2105 JVM_QUICK_ENTRY(jint, JVM_GetClassCPEntriesCount(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
2106 JVMWrapper("JVM_GetClassCPEntriesCount");
a61af66fc99e Initial load
duke
parents:
diff changeset
2107 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2108 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2109 if (!Klass::cast(k)->oop_is_instance())
a61af66fc99e Initial load
duke
parents:
diff changeset
2110 return 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
2111 return instanceKlass::cast(k)->constants()->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
2112 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2113
a61af66fc99e Initial load
duke
parents:
diff changeset
2114
a61af66fc99e Initial load
duke
parents:
diff changeset
2115 JVM_QUICK_ENTRY(jint, JVM_GetClassFieldsCount(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
2116 JVMWrapper("JVM_GetClassFieldsCount");
a61af66fc99e Initial load
duke
parents:
diff changeset
2117 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2118 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2119 if (!Klass::cast(k)->oop_is_instance())
a61af66fc99e Initial load
duke
parents:
diff changeset
2120 return 0;
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
2121 return instanceKlass::cast(k)->java_fields_count();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2122 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2123
a61af66fc99e Initial load
duke
parents:
diff changeset
2124
a61af66fc99e Initial load
duke
parents:
diff changeset
2125 JVM_QUICK_ENTRY(jint, JVM_GetClassMethodsCount(JNIEnv *env, jclass cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
2126 JVMWrapper("JVM_GetClassMethodsCount");
a61af66fc99e Initial load
duke
parents:
diff changeset
2127 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2128 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2129 if (!Klass::cast(k)->oop_is_instance())
a61af66fc99e Initial load
duke
parents:
diff changeset
2130 return 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
2131 return instanceKlass::cast(k)->methods()->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
2132 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2133
a61af66fc99e Initial load
duke
parents:
diff changeset
2134
a61af66fc99e Initial load
duke
parents:
diff changeset
2135 // The following methods, used for the verifier, are never called with
a61af66fc99e Initial load
duke
parents:
diff changeset
2136 // array klasses, so a direct cast to instanceKlass is safe.
a61af66fc99e Initial load
duke
parents:
diff changeset
2137 // Typically, these methods are called in a loop with bounds determined
a61af66fc99e Initial load
duke
parents:
diff changeset
2138 // by the results of JVM_GetClass{Fields,Methods}Count, which return
a61af66fc99e Initial load
duke
parents:
diff changeset
2139 // zero for arrays.
a61af66fc99e Initial load
duke
parents:
diff changeset
2140 JVM_QUICK_ENTRY(void, JVM_GetMethodIxExceptionIndexes(JNIEnv *env, jclass cls, jint method_index, unsigned short *exceptions))
a61af66fc99e Initial load
duke
parents:
diff changeset
2141 JVMWrapper("JVM_GetMethodIxExceptionIndexes");
a61af66fc99e Initial load
duke
parents:
diff changeset
2142 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2143 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2144 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2145 int length = methodOop(method)->checked_exceptions_length();
a61af66fc99e Initial load
duke
parents:
diff changeset
2146 if (length > 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2147 CheckedExceptionElement* table= methodOop(method)->checked_exceptions_start();
a61af66fc99e Initial load
duke
parents:
diff changeset
2148 for (int i = 0; i < length; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2149 exceptions[i] = table[i].class_cp_index;
a61af66fc99e Initial load
duke
parents:
diff changeset
2150 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2151 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2152 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2153
a61af66fc99e Initial load
duke
parents:
diff changeset
2154
a61af66fc99e Initial load
duke
parents:
diff changeset
2155 JVM_QUICK_ENTRY(jint, JVM_GetMethodIxExceptionsCount(JNIEnv *env, jclass cls, jint method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2156 JVMWrapper("JVM_GetMethodIxExceptionsCount");
a61af66fc99e Initial load
duke
parents:
diff changeset
2157 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2158 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2159 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2160 return methodOop(method)->checked_exceptions_length();
a61af66fc99e Initial load
duke
parents:
diff changeset
2161 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2162
a61af66fc99e Initial load
duke
parents:
diff changeset
2163
a61af66fc99e Initial load
duke
parents:
diff changeset
2164 JVM_QUICK_ENTRY(void, JVM_GetMethodIxByteCode(JNIEnv *env, jclass cls, jint method_index, unsigned char *code))
a61af66fc99e Initial load
duke
parents:
diff changeset
2165 JVMWrapper("JVM_GetMethodIxByteCode");
a61af66fc99e Initial load
duke
parents:
diff changeset
2166 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2167 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2168 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2169 memcpy(code, methodOop(method)->code_base(), methodOop(method)->code_size());
a61af66fc99e Initial load
duke
parents:
diff changeset
2170 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2171
a61af66fc99e Initial load
duke
parents:
diff changeset
2172
a61af66fc99e Initial load
duke
parents:
diff changeset
2173 JVM_QUICK_ENTRY(jint, JVM_GetMethodIxByteCodeLength(JNIEnv *env, jclass cls, jint method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2174 JVMWrapper("JVM_GetMethodIxByteCodeLength");
a61af66fc99e Initial load
duke
parents:
diff changeset
2175 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2176 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2177 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2178 return methodOop(method)->code_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
2179 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2180
a61af66fc99e Initial load
duke
parents:
diff changeset
2181
a61af66fc99e Initial load
duke
parents:
diff changeset
2182 JVM_QUICK_ENTRY(void, JVM_GetMethodIxExceptionTableEntry(JNIEnv *env, jclass cls, jint method_index, jint entry_index, JVM_ExceptionTableEntryType *entry))
a61af66fc99e Initial load
duke
parents:
diff changeset
2183 JVMWrapper("JVM_GetMethodIxExceptionTableEntry");
a61af66fc99e Initial load
duke
parents:
diff changeset
2184 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2185 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2186 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2187 typeArrayOop extable = methodOop(method)->exception_table();
a61af66fc99e Initial load
duke
parents:
diff changeset
2188 entry->start_pc = extable->int_at(entry_index * 4);
a61af66fc99e Initial load
duke
parents:
diff changeset
2189 entry->end_pc = extable->int_at(entry_index * 4 + 1);
a61af66fc99e Initial load
duke
parents:
diff changeset
2190 entry->handler_pc = extable->int_at(entry_index * 4 + 2);
a61af66fc99e Initial load
duke
parents:
diff changeset
2191 entry->catchType = extable->int_at(entry_index * 4 + 3);
a61af66fc99e Initial load
duke
parents:
diff changeset
2192 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2193
a61af66fc99e Initial load
duke
parents:
diff changeset
2194
a61af66fc99e Initial load
duke
parents:
diff changeset
2195 JVM_QUICK_ENTRY(jint, JVM_GetMethodIxExceptionTableLength(JNIEnv *env, jclass cls, int method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2196 JVMWrapper("JVM_GetMethodIxExceptionTableLength");
a61af66fc99e Initial load
duke
parents:
diff changeset
2197 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2198 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2199 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2200 return methodOop(method)->exception_table()->length() / 4;
a61af66fc99e Initial load
duke
parents:
diff changeset
2201 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2202
a61af66fc99e Initial load
duke
parents:
diff changeset
2203
a61af66fc99e Initial load
duke
parents:
diff changeset
2204 JVM_QUICK_ENTRY(jint, JVM_GetMethodIxModifiers(JNIEnv *env, jclass cls, int method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2205 JVMWrapper("JVM_GetMethodIxModifiers");
a61af66fc99e Initial load
duke
parents:
diff changeset
2206 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2207 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2208 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2209 return methodOop(method)->access_flags().as_int() & JVM_RECOGNIZED_METHOD_MODIFIERS;
a61af66fc99e Initial load
duke
parents:
diff changeset
2210 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2211
a61af66fc99e Initial load
duke
parents:
diff changeset
2212
a61af66fc99e Initial load
duke
parents:
diff changeset
2213 JVM_QUICK_ENTRY(jint, JVM_GetFieldIxModifiers(JNIEnv *env, jclass cls, int field_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2214 JVMWrapper("JVM_GetFieldIxModifiers");
a61af66fc99e Initial load
duke
parents:
diff changeset
2215 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2216 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
2217 return instanceKlass::cast(k)->field_access_flags(field_index) & JVM_RECOGNIZED_FIELD_MODIFIERS;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2218 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2219
a61af66fc99e Initial load
duke
parents:
diff changeset
2220
a61af66fc99e Initial load
duke
parents:
diff changeset
2221 JVM_QUICK_ENTRY(jint, JVM_GetMethodIxLocalsCount(JNIEnv *env, jclass cls, int method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2222 JVMWrapper("JVM_GetMethodIxLocalsCount");
a61af66fc99e Initial load
duke
parents:
diff changeset
2223 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2224 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2225 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2226 return methodOop(method)->max_locals();
a61af66fc99e Initial load
duke
parents:
diff changeset
2227 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2228
a61af66fc99e Initial load
duke
parents:
diff changeset
2229
a61af66fc99e Initial load
duke
parents:
diff changeset
2230 JVM_QUICK_ENTRY(jint, JVM_GetMethodIxArgsSize(JNIEnv *env, jclass cls, int method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2231 JVMWrapper("JVM_GetMethodIxArgsSize");
a61af66fc99e Initial load
duke
parents:
diff changeset
2232 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2233 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2234 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2235 return methodOop(method)->size_of_parameters();
a61af66fc99e Initial load
duke
parents:
diff changeset
2236 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2237
a61af66fc99e Initial load
duke
parents:
diff changeset
2238
a61af66fc99e Initial load
duke
parents:
diff changeset
2239 JVM_QUICK_ENTRY(jint, JVM_GetMethodIxMaxStack(JNIEnv *env, jclass cls, int method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2240 JVMWrapper("JVM_GetMethodIxMaxStack");
a61af66fc99e Initial load
duke
parents:
diff changeset
2241 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2242 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2243 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2244 return methodOop(method)->max_stack();
a61af66fc99e Initial load
duke
parents:
diff changeset
2245 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2246
a61af66fc99e Initial load
duke
parents:
diff changeset
2247
a61af66fc99e Initial load
duke
parents:
diff changeset
2248 JVM_QUICK_ENTRY(jboolean, JVM_IsConstructorIx(JNIEnv *env, jclass cls, int method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2249 JVMWrapper("JVM_IsConstructorIx");
a61af66fc99e Initial load
duke
parents:
diff changeset
2250 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
2251 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2252 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2253 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2254 return methodOop(method)->name() == vmSymbols::object_initializer_name();
a61af66fc99e Initial load
duke
parents:
diff changeset
2255 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2256
a61af66fc99e Initial load
duke
parents:
diff changeset
2257
a61af66fc99e Initial load
duke
parents:
diff changeset
2258 JVM_ENTRY(const char*, JVM_GetMethodIxNameUTF(JNIEnv *env, jclass cls, jint method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2259 JVMWrapper("JVM_GetMethodIxIxUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2260 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2261 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2262 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2263 return methodOop(method)->name()->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2264 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2265
a61af66fc99e Initial load
duke
parents:
diff changeset
2266
a61af66fc99e Initial load
duke
parents:
diff changeset
2267 JVM_ENTRY(const char*, JVM_GetMethodIxSignatureUTF(JNIEnv *env, jclass cls, jint method_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2268 JVMWrapper("JVM_GetMethodIxSignatureUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2269 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2270 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2271 oop method = instanceKlass::cast(k)->methods()->obj_at(method_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
2272 return methodOop(method)->signature()->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2273 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2274
a61af66fc99e Initial load
duke
parents:
diff changeset
2275 /**
a61af66fc99e Initial load
duke
parents:
diff changeset
2276 * All of these JVM_GetCP-xxx methods are used by the old verifier to
a61af66fc99e Initial load
duke
parents:
diff changeset
2277 * read entries in the constant pool. Since the old verifier always
a61af66fc99e Initial load
duke
parents:
diff changeset
2278 * works on a copy of the code, it will not see any rewriting that
a61af66fc99e Initial load
duke
parents:
diff changeset
2279 * may possibly occur in the middle of verification. So it is important
a61af66fc99e Initial load
duke
parents:
diff changeset
2280 * that nothing it calls tries to use the cpCache instead of the raw
a61af66fc99e Initial load
duke
parents:
diff changeset
2281 * constant pool, so we must use cp->uncached_x methods when appropriate.
a61af66fc99e Initial load
duke
parents:
diff changeset
2282 */
a61af66fc99e Initial load
duke
parents:
diff changeset
2283 JVM_ENTRY(const char*, JVM_GetCPFieldNameUTF(JNIEnv *env, jclass cls, jint cp_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2284 JVMWrapper("JVM_GetCPFieldNameUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2285 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2286 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2287 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2288 switch (cp->tag_at(cp_index).value()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2289 case JVM_CONSTANT_Fieldref:
a61af66fc99e Initial load
duke
parents:
diff changeset
2290 return cp->uncached_name_ref_at(cp_index)->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2291 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2292 fatal("JVM_GetCPFieldNameUTF: illegal constant");
a61af66fc99e Initial load
duke
parents:
diff changeset
2293 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2294 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
2295 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2296 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2297
a61af66fc99e Initial load
duke
parents:
diff changeset
2298
a61af66fc99e Initial load
duke
parents:
diff changeset
2299 JVM_ENTRY(const char*, JVM_GetCPMethodNameUTF(JNIEnv *env, jclass cls, jint cp_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2300 JVMWrapper("JVM_GetCPMethodNameUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2301 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2302 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2303 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2304 switch (cp->tag_at(cp_index).value()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2305 case JVM_CONSTANT_InterfaceMethodref:
a61af66fc99e Initial load
duke
parents:
diff changeset
2306 case JVM_CONSTANT_Methodref:
1059
389049f3f393 6858164: invokedynamic code needs some cleanup (post-6655638)
jrose
parents: 973
diff changeset
2307 case JVM_CONSTANT_NameAndType: // for invokedynamic
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2308 return cp->uncached_name_ref_at(cp_index)->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2309 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2310 fatal("JVM_GetCPMethodNameUTF: illegal constant");
a61af66fc99e Initial load
duke
parents:
diff changeset
2311 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2312 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
2313 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2314 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2315
a61af66fc99e Initial load
duke
parents:
diff changeset
2316
a61af66fc99e Initial load
duke
parents:
diff changeset
2317 JVM_ENTRY(const char*, JVM_GetCPMethodSignatureUTF(JNIEnv *env, jclass cls, jint cp_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2318 JVMWrapper("JVM_GetCPMethodSignatureUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2319 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2320 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2321 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2322 switch (cp->tag_at(cp_index).value()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2323 case JVM_CONSTANT_InterfaceMethodref:
a61af66fc99e Initial load
duke
parents:
diff changeset
2324 case JVM_CONSTANT_Methodref:
1059
389049f3f393 6858164: invokedynamic code needs some cleanup (post-6655638)
jrose
parents: 973
diff changeset
2325 case JVM_CONSTANT_NameAndType: // for invokedynamic
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2326 return cp->uncached_signature_ref_at(cp_index)->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2327 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2328 fatal("JVM_GetCPMethodSignatureUTF: illegal constant");
a61af66fc99e Initial load
duke
parents:
diff changeset
2329 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2330 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
2331 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2332 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2333
a61af66fc99e Initial load
duke
parents:
diff changeset
2334
a61af66fc99e Initial load
duke
parents:
diff changeset
2335 JVM_ENTRY(const char*, JVM_GetCPFieldSignatureUTF(JNIEnv *env, jclass cls, jint cp_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2336 JVMWrapper("JVM_GetCPFieldSignatureUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2337 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2338 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2339 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2340 switch (cp->tag_at(cp_index).value()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2341 case JVM_CONSTANT_Fieldref:
a61af66fc99e Initial load
duke
parents:
diff changeset
2342 return cp->uncached_signature_ref_at(cp_index)->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2343 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2344 fatal("JVM_GetCPFieldSignatureUTF: illegal constant");
a61af66fc99e Initial load
duke
parents:
diff changeset
2345 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2346 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
2347 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2348 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2349
a61af66fc99e Initial load
duke
parents:
diff changeset
2350
a61af66fc99e Initial load
duke
parents:
diff changeset
2351 JVM_ENTRY(const char*, JVM_GetCPClassNameUTF(JNIEnv *env, jclass cls, jint cp_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2352 JVMWrapper("JVM_GetCPClassNameUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2353 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2354 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2355 constantPoolOop cp = instanceKlass::cast(k)->constants();
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2356 Symbol* classname = cp->klass_name_at(cp_index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2357 return classname->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2358 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2359
a61af66fc99e Initial load
duke
parents:
diff changeset
2360
a61af66fc99e Initial load
duke
parents:
diff changeset
2361 JVM_ENTRY(const char*, JVM_GetCPFieldClassNameUTF(JNIEnv *env, jclass cls, jint cp_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2362 JVMWrapper("JVM_GetCPFieldClassNameUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2363 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2364 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2365 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2366 switch (cp->tag_at(cp_index).value()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2367 case JVM_CONSTANT_Fieldref: {
a61af66fc99e Initial load
duke
parents:
diff changeset
2368 int class_index = cp->uncached_klass_ref_index_at(cp_index);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2369 Symbol* classname = cp->klass_name_at(class_index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2370 return classname->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2371 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2372 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2373 fatal("JVM_GetCPFieldClassNameUTF: illegal constant");
a61af66fc99e Initial load
duke
parents:
diff changeset
2374 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2375 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
2376 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2377 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2378
a61af66fc99e Initial load
duke
parents:
diff changeset
2379
a61af66fc99e Initial load
duke
parents:
diff changeset
2380 JVM_ENTRY(const char*, JVM_GetCPMethodClassNameUTF(JNIEnv *env, jclass cls, jint cp_index))
a61af66fc99e Initial load
duke
parents:
diff changeset
2381 JVMWrapper("JVM_GetCPMethodClassNameUTF");
a61af66fc99e Initial load
duke
parents:
diff changeset
2382 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2383 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2384 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2385 switch (cp->tag_at(cp_index).value()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2386 case JVM_CONSTANT_Methodref:
a61af66fc99e Initial load
duke
parents:
diff changeset
2387 case JVM_CONSTANT_InterfaceMethodref: {
a61af66fc99e Initial load
duke
parents:
diff changeset
2388 int class_index = cp->uncached_klass_ref_index_at(cp_index);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2389 Symbol* classname = cp->klass_name_at(class_index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2390 return classname->as_utf8();
a61af66fc99e Initial load
duke
parents:
diff changeset
2391 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2392 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2393 fatal("JVM_GetCPMethodClassNameUTF: illegal constant");
a61af66fc99e Initial load
duke
parents:
diff changeset
2394 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2395 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
2396 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2397 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2398
a61af66fc99e Initial load
duke
parents:
diff changeset
2399
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
2400 JVM_ENTRY(jint, JVM_GetCPFieldModifiers(JNIEnv *env, jclass cls, int cp_index, jclass called_cls))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2401 JVMWrapper("JVM_GetCPFieldModifiers");
a61af66fc99e Initial load
duke
parents:
diff changeset
2402 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2403 klassOop k_called = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(called_cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2404 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2405 k_called = JvmtiThreadState::class_to_verify_considering_redefinition(k_called, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2406 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2407 constantPoolOop cp_called = instanceKlass::cast(k_called)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2408 switch (cp->tag_at(cp_index).value()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2409 case JVM_CONSTANT_Fieldref: {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2410 Symbol* name = cp->uncached_name_ref_at(cp_index);
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2411 Symbol* signature = cp->uncached_signature_ref_at(cp_index);
3938
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
2412 for (JavaFieldStream fs(k_called); !fs.done(); fs.next()) {
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
2413 if (fs.name() == name && fs.signature() == signature) {
e6b1331a51d2 7086585: make Java field injection more flexible
never
parents: 3895
diff changeset
2414 return fs.access_flags().as_short() & JVM_RECOGNIZED_FIELD_MODIFIERS;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2415 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2416 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2417 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
2418 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2419 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2420 fatal("JVM_GetCPFieldModifiers: illegal constant");
a61af66fc99e Initial load
duke
parents:
diff changeset
2421 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2422 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
2423 return 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
2424 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2425
a61af66fc99e Initial load
duke
parents:
diff changeset
2426
a61af66fc99e Initial load
duke
parents:
diff changeset
2427 JVM_QUICK_ENTRY(jint, JVM_GetCPMethodModifiers(JNIEnv *env, jclass cls, int cp_index, jclass called_cls))
a61af66fc99e Initial load
duke
parents:
diff changeset
2428 JVMWrapper("JVM_GetCPMethodModifiers");
a61af66fc99e Initial load
duke
parents:
diff changeset
2429 klassOop k = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2430 klassOop k_called = java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(called_cls));
a61af66fc99e Initial load
duke
parents:
diff changeset
2431 k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2432 k_called = JvmtiThreadState::class_to_verify_considering_redefinition(k_called, thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2433 constantPoolOop cp = instanceKlass::cast(k)->constants();
a61af66fc99e Initial load
duke
parents:
diff changeset
2434 switch (cp->tag_at(cp_index).value()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2435 case JVM_CONSTANT_Methodref:
a61af66fc99e Initial load
duke
parents:
diff changeset
2436 case JVM_CONSTANT_InterfaceMethodref: {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2437 Symbol* name = cp->uncached_name_ref_at(cp_index);
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2438 Symbol* signature = cp->uncached_signature_ref_at(cp_index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2439 objArrayOop methods = instanceKlass::cast(k_called)->methods();
a61af66fc99e Initial load
duke
parents:
diff changeset
2440 int methods_count = methods->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
2441 for (int i = 0; i < methods_count; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2442 methodOop method = methodOop(methods->obj_at(i));
a61af66fc99e Initial load
duke
parents:
diff changeset
2443 if (method->name() == name && method->signature() == signature) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2444 return method->access_flags().as_int() & JVM_RECOGNIZED_METHOD_MODIFIERS;
a61af66fc99e Initial load
duke
parents:
diff changeset
2445 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2446 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2447 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
2448 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2449 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2450 fatal("JVM_GetCPMethodModifiers: illegal constant");
a61af66fc99e Initial load
duke
parents:
diff changeset
2451 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2452 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
2453 return 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
2454 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2455
a61af66fc99e Initial load
duke
parents:
diff changeset
2456
a61af66fc99e Initial load
duke
parents:
diff changeset
2457 // Misc //////////////////////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
2458
a61af66fc99e Initial load
duke
parents:
diff changeset
2459 JVM_LEAF(void, JVM_ReleaseUTF(const char *utf))
a61af66fc99e Initial load
duke
parents:
diff changeset
2460 // So long as UTF8::convert_to_utf8 returns resource strings, we don't have to do anything
a61af66fc99e Initial load
duke
parents:
diff changeset
2461 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2462
a61af66fc99e Initial load
duke
parents:
diff changeset
2463
a61af66fc99e Initial load
duke
parents:
diff changeset
2464 JVM_ENTRY(jboolean, JVM_IsSameClassPackage(JNIEnv *env, jclass class1, jclass class2))
a61af66fc99e Initial load
duke
parents:
diff changeset
2465 JVMWrapper("JVM_IsSameClassPackage");
a61af66fc99e Initial load
duke
parents:
diff changeset
2466 oop class1_mirror = JNIHandles::resolve_non_null(class1);
a61af66fc99e Initial load
duke
parents:
diff changeset
2467 oop class2_mirror = JNIHandles::resolve_non_null(class2);
a61af66fc99e Initial load
duke
parents:
diff changeset
2468 klassOop klass1 = java_lang_Class::as_klassOop(class1_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
2469 klassOop klass2 = java_lang_Class::as_klassOop(class2_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
2470 return (jboolean) Reflection::is_same_class_package(klass1, klass2);
a61af66fc99e Initial load
duke
parents:
diff changeset
2471 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2472
a61af66fc99e Initial load
duke
parents:
diff changeset
2473
a61af66fc99e Initial load
duke
parents:
diff changeset
2474 // IO functions ////////////////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
2475
a61af66fc99e Initial load
duke
parents:
diff changeset
2476 JVM_LEAF(jint, JVM_Open(const char *fname, jint flags, jint mode))
a61af66fc99e Initial load
duke
parents:
diff changeset
2477 JVMWrapper2("JVM_Open (%s)", fname);
a61af66fc99e Initial load
duke
parents:
diff changeset
2478
a61af66fc99e Initial load
duke
parents:
diff changeset
2479 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
2480 int result = os::open(fname, flags, mode);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2481 if (result >= 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2482 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
2483 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2484 switch(errno) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2485 case EEXIST:
a61af66fc99e Initial load
duke
parents:
diff changeset
2486 return JVM_EEXIST;
a61af66fc99e Initial load
duke
parents:
diff changeset
2487 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
2488 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
2489 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2490 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2491 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2492
a61af66fc99e Initial load
duke
parents:
diff changeset
2493
a61af66fc99e Initial load
duke
parents:
diff changeset
2494 JVM_LEAF(jint, JVM_Close(jint fd))
a61af66fc99e Initial load
duke
parents:
diff changeset
2495 JVMWrapper2("JVM_Close (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
2496 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
2497 return os::close(fd);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2498 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2499
a61af66fc99e Initial load
duke
parents:
diff changeset
2500
a61af66fc99e Initial load
duke
parents:
diff changeset
2501 JVM_LEAF(jint, JVM_Read(jint fd, char *buf, jint nbytes))
a61af66fc99e Initial load
duke
parents:
diff changeset
2502 JVMWrapper2("JVM_Read (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
2503
a61af66fc99e Initial load
duke
parents:
diff changeset
2504 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
2505 return (jint)os::restartable_read(fd, buf, nbytes);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2506 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2507
a61af66fc99e Initial load
duke
parents:
diff changeset
2508
a61af66fc99e Initial load
duke
parents:
diff changeset
2509 JVM_LEAF(jint, JVM_Write(jint fd, char *buf, jint nbytes))
a61af66fc99e Initial load
duke
parents:
diff changeset
2510 JVMWrapper2("JVM_Write (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
2511
a61af66fc99e Initial load
duke
parents:
diff changeset
2512 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
2513 return (jint)os::write(fd, buf, nbytes);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2514 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2515
a61af66fc99e Initial load
duke
parents:
diff changeset
2516
a61af66fc99e Initial load
duke
parents:
diff changeset
2517 JVM_LEAF(jint, JVM_Available(jint fd, jlong *pbytes))
a61af66fc99e Initial load
duke
parents:
diff changeset
2518 JVMWrapper2("JVM_Available (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
2519 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
2520 return os::available(fd, pbytes);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2521 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2522
a61af66fc99e Initial load
duke
parents:
diff changeset
2523
a61af66fc99e Initial load
duke
parents:
diff changeset
2524 JVM_LEAF(jlong, JVM_Lseek(jint fd, jlong offset, jint whence))
a61af66fc99e Initial load
duke
parents:
diff changeset
2525 JVMWrapper4("JVM_Lseek (0x%x, %Ld, %d)", fd, offset, whence);
a61af66fc99e Initial load
duke
parents:
diff changeset
2526 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
2527 return os::lseek(fd, offset, whence);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2528 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2529
a61af66fc99e Initial load
duke
parents:
diff changeset
2530
a61af66fc99e Initial load
duke
parents:
diff changeset
2531 JVM_LEAF(jint, JVM_SetLength(jint fd, jlong length))
a61af66fc99e Initial load
duke
parents:
diff changeset
2532 JVMWrapper3("JVM_SetLength (0x%x, %Ld)", fd, length);
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
2533 return os::ftruncate(fd, length);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2534 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2535
a61af66fc99e Initial load
duke
parents:
diff changeset
2536
a61af66fc99e Initial load
duke
parents:
diff changeset
2537 JVM_LEAF(jint, JVM_Sync(jint fd))
a61af66fc99e Initial load
duke
parents:
diff changeset
2538 JVMWrapper2("JVM_Sync (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
2539 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
2540 return os::fsync(fd);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2541 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2542
a61af66fc99e Initial load
duke
parents:
diff changeset
2543
a61af66fc99e Initial load
duke
parents:
diff changeset
2544 // Printing support //////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
2545 extern "C" {
a61af66fc99e Initial load
duke
parents:
diff changeset
2546
a61af66fc99e Initial load
duke
parents:
diff changeset
2547 int jio_vsnprintf(char *str, size_t count, const char *fmt, va_list args) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2548 // see bug 4399518, 4417214
a61af66fc99e Initial load
duke
parents:
diff changeset
2549 if ((intptr_t)count <= 0) return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
2550 return vsnprintf(str, count, fmt, args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2551 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2552
a61af66fc99e Initial load
duke
parents:
diff changeset
2553
a61af66fc99e Initial load
duke
parents:
diff changeset
2554 int jio_snprintf(char *str, size_t count, const char *fmt, ...) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2555 va_list args;
a61af66fc99e Initial load
duke
parents:
diff changeset
2556 int len;
a61af66fc99e Initial load
duke
parents:
diff changeset
2557 va_start(args, fmt);
a61af66fc99e Initial load
duke
parents:
diff changeset
2558 len = jio_vsnprintf(str, count, fmt, args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2559 va_end(args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2560 return len;
a61af66fc99e Initial load
duke
parents:
diff changeset
2561 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2562
a61af66fc99e Initial load
duke
parents:
diff changeset
2563
a61af66fc99e Initial load
duke
parents:
diff changeset
2564 int jio_fprintf(FILE* f, const char *fmt, ...) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2565 int len;
a61af66fc99e Initial load
duke
parents:
diff changeset
2566 va_list args;
a61af66fc99e Initial load
duke
parents:
diff changeset
2567 va_start(args, fmt);
a61af66fc99e Initial load
duke
parents:
diff changeset
2568 len = jio_vfprintf(f, fmt, args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2569 va_end(args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2570 return len;
a61af66fc99e Initial load
duke
parents:
diff changeset
2571 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2572
a61af66fc99e Initial load
duke
parents:
diff changeset
2573
a61af66fc99e Initial load
duke
parents:
diff changeset
2574 int jio_vfprintf(FILE* f, const char *fmt, va_list args) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2575 if (Arguments::vfprintf_hook() != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2576 return Arguments::vfprintf_hook()(f, fmt, args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2577 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2578 return vfprintf(f, fmt, args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2579 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2580 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2581
a61af66fc99e Initial load
duke
parents:
diff changeset
2582
2191
d70fe6ab4436 6588413: Use -fvisibility=hidden for gcc compiles
coleenp
parents: 2177
diff changeset
2583 JNIEXPORT int jio_printf(const char *fmt, ...) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2584 int len;
a61af66fc99e Initial load
duke
parents:
diff changeset
2585 va_list args;
a61af66fc99e Initial load
duke
parents:
diff changeset
2586 va_start(args, fmt);
a61af66fc99e Initial load
duke
parents:
diff changeset
2587 len = jio_vfprintf(defaultStream::output_stream(), fmt, args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2588 va_end(args);
a61af66fc99e Initial load
duke
parents:
diff changeset
2589 return len;
a61af66fc99e Initial load
duke
parents:
diff changeset
2590 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2591
a61af66fc99e Initial load
duke
parents:
diff changeset
2592
a61af66fc99e Initial load
duke
parents:
diff changeset
2593 // HotSpot specific jio method
a61af66fc99e Initial load
duke
parents:
diff changeset
2594 void jio_print(const char* s) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2595 // Try to make this function as atomic as possible.
a61af66fc99e Initial load
duke
parents:
diff changeset
2596 if (Arguments::vfprintf_hook() != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2597 jio_fprintf(defaultStream::output_stream(), "%s", s);
a61af66fc99e Initial load
duke
parents:
diff changeset
2598 } else {
513
2328d1d3f8cf 6781583: Hotspot build fails on linux 64 bit platform with gcc 4.3.2
xlu
parents: 431
diff changeset
2599 // Make an unused local variable to avoid warning from gcc 4.x compiler.
2328d1d3f8cf 6781583: Hotspot build fails on linux 64 bit platform with gcc 4.3.2
xlu
parents: 431
diff changeset
2600 size_t count = ::write(defaultStream::output_fd(), s, (int)strlen(s));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2601 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2602 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2603
a61af66fc99e Initial load
duke
parents:
diff changeset
2604 } // Extern C
a61af66fc99e Initial load
duke
parents:
diff changeset
2605
a61af66fc99e Initial load
duke
parents:
diff changeset
2606 // java.lang.Thread //////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
2607
a61af66fc99e Initial load
duke
parents:
diff changeset
2608 // In most of the JVM Thread support functions we need to be sure to lock the Threads_lock
a61af66fc99e Initial load
duke
parents:
diff changeset
2609 // to prevent the target thread from exiting after we have a pointer to the C++ Thread or
a61af66fc99e Initial load
duke
parents:
diff changeset
2610 // OSThread objects. The exception to this rule is when the target object is the thread
a61af66fc99e Initial load
duke
parents:
diff changeset
2611 // doing the operation, in which case we know that the thread won't exit until the
a61af66fc99e Initial load
duke
parents:
diff changeset
2612 // operation is done (all exits being voluntary). There are a few cases where it is
a61af66fc99e Initial load
duke
parents:
diff changeset
2613 // rather silly to do operations on yourself, like resuming yourself or asking whether
a61af66fc99e Initial load
duke
parents:
diff changeset
2614 // you are alive. While these can still happen, they are not subject to deadlocks if
a61af66fc99e Initial load
duke
parents:
diff changeset
2615 // the lock is held while the operation occurs (this is not the case for suspend, for
a61af66fc99e Initial load
duke
parents:
diff changeset
2616 // instance), and are very unlikely. Because IsAlive needs to be fast and its
a61af66fc99e Initial load
duke
parents:
diff changeset
2617 // implementation is local to this file, we always lock Threads_lock for that one.
a61af66fc99e Initial load
duke
parents:
diff changeset
2618
a61af66fc99e Initial load
duke
parents:
diff changeset
2619 static void thread_entry(JavaThread* thread, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2620 HandleMark hm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
2621 Handle obj(THREAD, thread->threadObj());
a61af66fc99e Initial load
duke
parents:
diff changeset
2622 JavaValue result(T_VOID);
a61af66fc99e Initial load
duke
parents:
diff changeset
2623 JavaCalls::call_virtual(&result,
a61af66fc99e Initial load
duke
parents:
diff changeset
2624 obj,
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
2625 KlassHandle(THREAD, SystemDictionary::Thread_klass()),
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2626 vmSymbols::run_method_name(),
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
2627 vmSymbols::void_method_signature(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2628 THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
2629 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2630
a61af66fc99e Initial load
duke
parents:
diff changeset
2631
a61af66fc99e Initial load
duke
parents:
diff changeset
2632 JVM_ENTRY(void, JVM_StartThread(JNIEnv* env, jobject jthread))
a61af66fc99e Initial load
duke
parents:
diff changeset
2633 JVMWrapper("JVM_StartThread");
a61af66fc99e Initial load
duke
parents:
diff changeset
2634 JavaThread *native_thread = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2635
a61af66fc99e Initial load
duke
parents:
diff changeset
2636 // We cannot hold the Threads_lock when we throw an exception,
a61af66fc99e Initial load
duke
parents:
diff changeset
2637 // due to rank ordering issues. Example: we might need to grab the
a61af66fc99e Initial load
duke
parents:
diff changeset
2638 // Heap_lock while we construct the exception.
a61af66fc99e Initial load
duke
parents:
diff changeset
2639 bool throw_illegal_thread_state = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2640
a61af66fc99e Initial load
duke
parents:
diff changeset
2641 // We must release the Threads_lock before we can post a jvmti event
a61af66fc99e Initial load
duke
parents:
diff changeset
2642 // in Thread::start.
a61af66fc99e Initial load
duke
parents:
diff changeset
2643 {
a61af66fc99e Initial load
duke
parents:
diff changeset
2644 // Ensure that the C++ Thread and OSThread structures aren't freed before
a61af66fc99e Initial load
duke
parents:
diff changeset
2645 // we operate.
a61af66fc99e Initial load
duke
parents:
diff changeset
2646 MutexLocker mu(Threads_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
2647
2162
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2648 // Since JDK 5 the java.lang.Thread threadStatus is used to prevent
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2649 // re-starting an already started thread, so we should usually find
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2650 // that the JavaThread is null. However for a JNI attached thread
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2651 // there is a small window between the Thread object being created
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2652 // (with its JavaThread set) and the update to its threadStatus, so we
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2653 // have to check for this
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2654 if (java_lang_Thread::thread(JNIHandles::resolve_non_null(jthread)) != NULL) {
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2655 throw_illegal_thread_state = true;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2656 } else {
2162
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2657 // We could also check the stillborn flag to see if this thread was already stopped, but
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2658 // for historical reasons we let the thread detect that itself when it starts running
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2659
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2660 jlong size =
a61af66fc99e Initial load
duke
parents:
diff changeset
2661 java_lang_Thread::stackSize(JNIHandles::resolve_non_null(jthread));
a61af66fc99e Initial load
duke
parents:
diff changeset
2662 // Allocate the C++ Thread structure and create the native thread. The
a61af66fc99e Initial load
duke
parents:
diff changeset
2663 // stack size retrieved from java is signed, but the constructor takes
a61af66fc99e Initial load
duke
parents:
diff changeset
2664 // size_t (an unsigned type), so avoid passing negative values which would
a61af66fc99e Initial load
duke
parents:
diff changeset
2665 // result in really large stacks.
a61af66fc99e Initial load
duke
parents:
diff changeset
2666 size_t sz = size > 0 ? (size_t) size : 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
2667 native_thread = new JavaThread(&thread_entry, sz);
a61af66fc99e Initial load
duke
parents:
diff changeset
2668
a61af66fc99e Initial load
duke
parents:
diff changeset
2669 // At this point it may be possible that no osthread was created for the
a61af66fc99e Initial load
duke
parents:
diff changeset
2670 // JavaThread due to lack of memory. Check for this situation and throw
a61af66fc99e Initial load
duke
parents:
diff changeset
2671 // an exception if necessary. Eventually we may want to change this so
a61af66fc99e Initial load
duke
parents:
diff changeset
2672 // that we only grab the lock if the thread was created successfully -
a61af66fc99e Initial load
duke
parents:
diff changeset
2673 // then we can also do this check and throw the exception in the
a61af66fc99e Initial load
duke
parents:
diff changeset
2674 // JavaThread constructor.
a61af66fc99e Initial load
duke
parents:
diff changeset
2675 if (native_thread->osthread() != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2676 // Note: the current thread is not being used within "prepare".
a61af66fc99e Initial load
duke
parents:
diff changeset
2677 native_thread->prepare(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2678 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2679 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2680 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2681
a61af66fc99e Initial load
duke
parents:
diff changeset
2682 if (throw_illegal_thread_state) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2683 THROW(vmSymbols::java_lang_IllegalThreadStateException());
a61af66fc99e Initial load
duke
parents:
diff changeset
2684 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2685
a61af66fc99e Initial load
duke
parents:
diff changeset
2686 assert(native_thread != NULL, "Starting null thread?");
a61af66fc99e Initial load
duke
parents:
diff changeset
2687
a61af66fc99e Initial load
duke
parents:
diff changeset
2688 if (native_thread->osthread() == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2689 // No one should hold a reference to the 'native_thread'.
a61af66fc99e Initial load
duke
parents:
diff changeset
2690 delete native_thread;
a61af66fc99e Initial load
duke
parents:
diff changeset
2691 if (JvmtiExport::should_post_resource_exhausted()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2692 JvmtiExport::post_resource_exhausted(
a61af66fc99e Initial load
duke
parents:
diff changeset
2693 JVMTI_RESOURCE_EXHAUSTED_OOM_ERROR | JVMTI_RESOURCE_EXHAUSTED_THREADS,
a61af66fc99e Initial load
duke
parents:
diff changeset
2694 "unable to create new native thread");
a61af66fc99e Initial load
duke
parents:
diff changeset
2695 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2696 THROW_MSG(vmSymbols::java_lang_OutOfMemoryError(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2697 "unable to create new native thread");
a61af66fc99e Initial load
duke
parents:
diff changeset
2698 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2699
a61af66fc99e Initial load
duke
parents:
diff changeset
2700 Thread::start(native_thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2701
a61af66fc99e Initial load
duke
parents:
diff changeset
2702 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2703
a61af66fc99e Initial load
duke
parents:
diff changeset
2704 // JVM_Stop is implemented using a VM_Operation, so threads are forced to safepoints
a61af66fc99e Initial load
duke
parents:
diff changeset
2705 // before the quasi-asynchronous exception is delivered. This is a little obtrusive,
a61af66fc99e Initial load
duke
parents:
diff changeset
2706 // but is thought to be reliable and simple. In the case, where the receiver is the
2162
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2707 // same thread as the sender, no safepoint is needed.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2708 JVM_ENTRY(void, JVM_StopThread(JNIEnv* env, jobject jthread, jobject throwable))
a61af66fc99e Initial load
duke
parents:
diff changeset
2709 JVMWrapper("JVM_StopThread");
a61af66fc99e Initial load
duke
parents:
diff changeset
2710
a61af66fc99e Initial load
duke
parents:
diff changeset
2711 oop java_throwable = JNIHandles::resolve(throwable);
a61af66fc99e Initial load
duke
parents:
diff changeset
2712 if (java_throwable == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2713 THROW(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
2714 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2715 oop java_thread = JNIHandles::resolve_non_null(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2716 JavaThread* receiver = java_lang_Thread::thread(java_thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2717 Events::log("JVM_StopThread thread JavaThread " INTPTR_FORMAT " as oop " INTPTR_FORMAT " [exception " INTPTR_FORMAT "]", receiver, (address)java_thread, throwable);
2162
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2718 // First check if thread is alive
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2719 if (receiver != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2720 // Check if exception is getting thrown at self (use oop equality, since the
a61af66fc99e Initial load
duke
parents:
diff changeset
2721 // target object might exit)
a61af66fc99e Initial load
duke
parents:
diff changeset
2722 if (java_thread == thread->threadObj()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2723 THROW_OOP(java_throwable);
a61af66fc99e Initial load
duke
parents:
diff changeset
2724 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2725 // Enques a VM_Operation to stop all threads and then deliver the exception...
a61af66fc99e Initial load
duke
parents:
diff changeset
2726 Thread::send_async_exception(java_thread, JNIHandles::resolve(throwable));
a61af66fc99e Initial load
duke
parents:
diff changeset
2727 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2728 }
2162
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2729 else {
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2730 // Either:
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2731 // - target thread has not been started before being stopped, or
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2732 // - target thread already terminated
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2733 // We could read the threadStatus to determine which case it is
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2734 // but that is overkill as it doesn't matter. We must set the
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2735 // stillborn flag for the first case, and if the thread has already
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2736 // exited setting this flag has no affect
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2737 java_lang_Thread::set_stillborn(java_thread);
ccfcb502af3f 6566340: Restore use of stillborn flag to signify a thread that was stopped before it started
dholmes
parents: 1980
diff changeset
2738 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2739 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2740
a61af66fc99e Initial load
duke
parents:
diff changeset
2741
a61af66fc99e Initial load
duke
parents:
diff changeset
2742 JVM_ENTRY(jboolean, JVM_IsThreadAlive(JNIEnv* env, jobject jthread))
a61af66fc99e Initial load
duke
parents:
diff changeset
2743 JVMWrapper("JVM_IsThreadAlive");
a61af66fc99e Initial load
duke
parents:
diff changeset
2744
a61af66fc99e Initial load
duke
parents:
diff changeset
2745 oop thread_oop = JNIHandles::resolve_non_null(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2746 return java_lang_Thread::is_alive(thread_oop);
a61af66fc99e Initial load
duke
parents:
diff changeset
2747 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2748
a61af66fc99e Initial load
duke
parents:
diff changeset
2749
a61af66fc99e Initial load
duke
parents:
diff changeset
2750 JVM_ENTRY(void, JVM_SuspendThread(JNIEnv* env, jobject jthread))
a61af66fc99e Initial load
duke
parents:
diff changeset
2751 JVMWrapper("JVM_SuspendThread");
a61af66fc99e Initial load
duke
parents:
diff changeset
2752 oop java_thread = JNIHandles::resolve_non_null(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2753 JavaThread* receiver = java_lang_Thread::thread(java_thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2754
a61af66fc99e Initial load
duke
parents:
diff changeset
2755 if (receiver != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2756 // thread has run and has not exited (still on threads list)
a61af66fc99e Initial load
duke
parents:
diff changeset
2757
a61af66fc99e Initial load
duke
parents:
diff changeset
2758 {
a61af66fc99e Initial load
duke
parents:
diff changeset
2759 MutexLockerEx ml(receiver->SR_lock(), Mutex::_no_safepoint_check_flag);
a61af66fc99e Initial load
duke
parents:
diff changeset
2760 if (receiver->is_external_suspend()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2761 // Don't allow nested external suspend requests. We can't return
a61af66fc99e Initial load
duke
parents:
diff changeset
2762 // an error from this interface so just ignore the problem.
a61af66fc99e Initial load
duke
parents:
diff changeset
2763 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
2764 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2765 if (receiver->is_exiting()) { // thread is in the process of exiting
a61af66fc99e Initial load
duke
parents:
diff changeset
2766 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
2767 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2768 receiver->set_external_suspend();
a61af66fc99e Initial load
duke
parents:
diff changeset
2769 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2770
a61af66fc99e Initial load
duke
parents:
diff changeset
2771 // java_suspend() will catch threads in the process of exiting
a61af66fc99e Initial load
duke
parents:
diff changeset
2772 // and will ignore them.
a61af66fc99e Initial load
duke
parents:
diff changeset
2773 receiver->java_suspend();
a61af66fc99e Initial load
duke
parents:
diff changeset
2774
a61af66fc99e Initial load
duke
parents:
diff changeset
2775 // It would be nice to have the following assertion in all the
a61af66fc99e Initial load
duke
parents:
diff changeset
2776 // time, but it is possible for a racing resume request to have
a61af66fc99e Initial load
duke
parents:
diff changeset
2777 // resumed this thread right after we suspended it. Temporarily
a61af66fc99e Initial load
duke
parents:
diff changeset
2778 // enable this assertion if you are chasing a different kind of
a61af66fc99e Initial load
duke
parents:
diff changeset
2779 // bug.
a61af66fc99e Initial load
duke
parents:
diff changeset
2780 //
a61af66fc99e Initial load
duke
parents:
diff changeset
2781 // assert(java_lang_Thread::thread(receiver->threadObj()) == NULL ||
a61af66fc99e Initial load
duke
parents:
diff changeset
2782 // receiver->is_being_ext_suspended(), "thread is not suspended");
a61af66fc99e Initial load
duke
parents:
diff changeset
2783 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2784 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2785
a61af66fc99e Initial load
duke
parents:
diff changeset
2786
a61af66fc99e Initial load
duke
parents:
diff changeset
2787 JVM_ENTRY(void, JVM_ResumeThread(JNIEnv* env, jobject jthread))
a61af66fc99e Initial load
duke
parents:
diff changeset
2788 JVMWrapper("JVM_ResumeThread");
a61af66fc99e Initial load
duke
parents:
diff changeset
2789 // Ensure that the C++ Thread and OSThread structures aren't freed before we operate.
a61af66fc99e Initial load
duke
parents:
diff changeset
2790 // We need to *always* get the threads lock here, since this operation cannot be allowed during
a61af66fc99e Initial load
duke
parents:
diff changeset
2791 // a safepoint. The safepoint code relies on suspending a thread to examine its state. If other
a61af66fc99e Initial load
duke
parents:
diff changeset
2792 // threads randomly resumes threads, then a thread might not be suspended when the safepoint code
a61af66fc99e Initial load
duke
parents:
diff changeset
2793 // looks at it.
a61af66fc99e Initial load
duke
parents:
diff changeset
2794 MutexLocker ml(Threads_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
2795 JavaThread* thr = java_lang_Thread::thread(JNIHandles::resolve_non_null(jthread));
a61af66fc99e Initial load
duke
parents:
diff changeset
2796 if (thr != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2797 // the thread has run and is not in the process of exiting
a61af66fc99e Initial load
duke
parents:
diff changeset
2798 thr->java_resume();
a61af66fc99e Initial load
duke
parents:
diff changeset
2799 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2800 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2801
a61af66fc99e Initial load
duke
parents:
diff changeset
2802
a61af66fc99e Initial load
duke
parents:
diff changeset
2803 JVM_ENTRY(void, JVM_SetThreadPriority(JNIEnv* env, jobject jthread, jint prio))
a61af66fc99e Initial load
duke
parents:
diff changeset
2804 JVMWrapper("JVM_SetThreadPriority");
a61af66fc99e Initial load
duke
parents:
diff changeset
2805 // Ensure that the C++ Thread and OSThread structures aren't freed before we operate
a61af66fc99e Initial load
duke
parents:
diff changeset
2806 MutexLocker ml(Threads_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
2807 oop java_thread = JNIHandles::resolve_non_null(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2808 java_lang_Thread::set_priority(java_thread, (ThreadPriority)prio);
a61af66fc99e Initial load
duke
parents:
diff changeset
2809 JavaThread* thr = java_lang_Thread::thread(java_thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2810 if (thr != NULL) { // Thread not yet started; priority pushed down when it is
a61af66fc99e Initial load
duke
parents:
diff changeset
2811 Thread::set_priority(thr, (ThreadPriority)prio);
a61af66fc99e Initial load
duke
parents:
diff changeset
2812 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2813 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2814
a61af66fc99e Initial load
duke
parents:
diff changeset
2815
a61af66fc99e Initial load
duke
parents:
diff changeset
2816 JVM_ENTRY(void, JVM_Yield(JNIEnv *env, jclass threadClass))
a61af66fc99e Initial load
duke
parents:
diff changeset
2817 JVMWrapper("JVM_Yield");
a61af66fc99e Initial load
duke
parents:
diff changeset
2818 if (os::dont_yield()) return;
1324
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
2819 HS_DTRACE_PROBE0(hotspot, thread__yield);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2820 // When ConvertYieldToSleep is off (default), this matches the classic VM use of yield.
a61af66fc99e Initial load
duke
parents:
diff changeset
2821 // Critical for similar threading behaviour
a61af66fc99e Initial load
duke
parents:
diff changeset
2822 if (ConvertYieldToSleep) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2823 os::sleep(thread, MinSleepInterval, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
2824 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2825 os::yield();
a61af66fc99e Initial load
duke
parents:
diff changeset
2826 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2827 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2828
a61af66fc99e Initial load
duke
parents:
diff changeset
2829
a61af66fc99e Initial load
duke
parents:
diff changeset
2830 JVM_ENTRY(void, JVM_Sleep(JNIEnv* env, jclass threadClass, jlong millis))
a61af66fc99e Initial load
duke
parents:
diff changeset
2831 JVMWrapper("JVM_Sleep");
a61af66fc99e Initial load
duke
parents:
diff changeset
2832
a61af66fc99e Initial load
duke
parents:
diff changeset
2833 if (millis < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2834 THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), "timeout value is negative");
a61af66fc99e Initial load
duke
parents:
diff changeset
2835 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2836
a61af66fc99e Initial load
duke
parents:
diff changeset
2837 if (Thread::is_interrupted (THREAD, true) && !HAS_PENDING_EXCEPTION) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2838 THROW_MSG(vmSymbols::java_lang_InterruptedException(), "sleep interrupted");
a61af66fc99e Initial load
duke
parents:
diff changeset
2839 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2840
a61af66fc99e Initial load
duke
parents:
diff changeset
2841 // Save current thread state and restore it at the end of this block.
a61af66fc99e Initial load
duke
parents:
diff changeset
2842 // And set new thread state to SLEEPING.
a61af66fc99e Initial load
duke
parents:
diff changeset
2843 JavaThreadSleepState jtss(thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2844
1324
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
2845 HS_DTRACE_PROBE1(hotspot, thread__sleep__begin, millis);
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
2846
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2847 if (millis == 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2848 // When ConvertSleepToYield is on, this matches the classic VM implementation of
a61af66fc99e Initial load
duke
parents:
diff changeset
2849 // JVM_Sleep. Critical for similar threading behaviour (Win32)
a61af66fc99e Initial load
duke
parents:
diff changeset
2850 // It appears that in certain GUI contexts, it may be beneficial to do a short sleep
a61af66fc99e Initial load
duke
parents:
diff changeset
2851 // for SOLARIS
a61af66fc99e Initial load
duke
parents:
diff changeset
2852 if (ConvertSleepToYield) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2853 os::yield();
a61af66fc99e Initial load
duke
parents:
diff changeset
2854 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2855 ThreadState old_state = thread->osthread()->get_state();
a61af66fc99e Initial load
duke
parents:
diff changeset
2856 thread->osthread()->set_state(SLEEPING);
a61af66fc99e Initial load
duke
parents:
diff changeset
2857 os::sleep(thread, MinSleepInterval, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
2858 thread->osthread()->set_state(old_state);
a61af66fc99e Initial load
duke
parents:
diff changeset
2859 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2860 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2861 ThreadState old_state = thread->osthread()->get_state();
a61af66fc99e Initial load
duke
parents:
diff changeset
2862 thread->osthread()->set_state(SLEEPING);
a61af66fc99e Initial load
duke
parents:
diff changeset
2863 if (os::sleep(thread, millis, true) == OS_INTRPT) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2864 // An asynchronous exception (e.g., ThreadDeathException) could have been thrown on
a61af66fc99e Initial load
duke
parents:
diff changeset
2865 // us while we were sleeping. We do not overwrite those.
a61af66fc99e Initial load
duke
parents:
diff changeset
2866 if (!HAS_PENDING_EXCEPTION) {
1324
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
2867 HS_DTRACE_PROBE1(hotspot, thread__sleep__end,1);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2868 // TODO-FIXME: THROW_MSG returns which means we will not call set_state()
a61af66fc99e Initial load
duke
parents:
diff changeset
2869 // to properly restore the thread state. That's likely wrong.
a61af66fc99e Initial load
duke
parents:
diff changeset
2870 THROW_MSG(vmSymbols::java_lang_InterruptedException(), "sleep interrupted");
a61af66fc99e Initial load
duke
parents:
diff changeset
2871 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2872 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2873 thread->osthread()->set_state(old_state);
a61af66fc99e Initial load
duke
parents:
diff changeset
2874 }
1324
e392695de029 6935224: Adding new DTrace probes to work with Palantir
fparain
parents: 1144
diff changeset
2875 HS_DTRACE_PROBE1(hotspot, thread__sleep__end,0);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2876 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2877
a61af66fc99e Initial load
duke
parents:
diff changeset
2878 JVM_ENTRY(jobject, JVM_CurrentThread(JNIEnv* env, jclass threadClass))
a61af66fc99e Initial load
duke
parents:
diff changeset
2879 JVMWrapper("JVM_CurrentThread");
a61af66fc99e Initial load
duke
parents:
diff changeset
2880 oop jthread = thread->threadObj();
a61af66fc99e Initial load
duke
parents:
diff changeset
2881 assert (thread != NULL, "no current thread!");
a61af66fc99e Initial load
duke
parents:
diff changeset
2882 return JNIHandles::make_local(env, jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2883 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2884
a61af66fc99e Initial load
duke
parents:
diff changeset
2885
a61af66fc99e Initial load
duke
parents:
diff changeset
2886 JVM_ENTRY(jint, JVM_CountStackFrames(JNIEnv* env, jobject jthread))
a61af66fc99e Initial load
duke
parents:
diff changeset
2887 JVMWrapper("JVM_CountStackFrames");
a61af66fc99e Initial load
duke
parents:
diff changeset
2888
a61af66fc99e Initial load
duke
parents:
diff changeset
2889 // Ensure that the C++ Thread and OSThread structures aren't freed before we operate
a61af66fc99e Initial load
duke
parents:
diff changeset
2890 oop java_thread = JNIHandles::resolve_non_null(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2891 bool throw_illegal_thread_state = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2892 int count = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
2893
a61af66fc99e Initial load
duke
parents:
diff changeset
2894 {
a61af66fc99e Initial load
duke
parents:
diff changeset
2895 MutexLockerEx ml(thread->threadObj() == java_thread ? NULL : Threads_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
2896 // We need to re-resolve the java_thread, since a GC might have happened during the
a61af66fc99e Initial load
duke
parents:
diff changeset
2897 // acquire of the lock
a61af66fc99e Initial load
duke
parents:
diff changeset
2898 JavaThread* thr = java_lang_Thread::thread(JNIHandles::resolve_non_null(jthread));
a61af66fc99e Initial load
duke
parents:
diff changeset
2899
a61af66fc99e Initial load
duke
parents:
diff changeset
2900 if (thr == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2901 // do nothing
a61af66fc99e Initial load
duke
parents:
diff changeset
2902 } else if(! thr->is_external_suspend() || ! thr->frame_anchor()->walkable()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2903 // Check whether this java thread has been suspended already. If not, throws
a61af66fc99e Initial load
duke
parents:
diff changeset
2904 // IllegalThreadStateException. We defer to throw that exception until
a61af66fc99e Initial load
duke
parents:
diff changeset
2905 // Threads_lock is released since loading exception class has to leave VM.
a61af66fc99e Initial load
duke
parents:
diff changeset
2906 // The correct way to test a thread is actually suspended is
a61af66fc99e Initial load
duke
parents:
diff changeset
2907 // wait_for_ext_suspend_completion(), but we can't call that while holding
a61af66fc99e Initial load
duke
parents:
diff changeset
2908 // the Threads_lock. The above tests are sufficient for our purposes
a61af66fc99e Initial load
duke
parents:
diff changeset
2909 // provided the walkability of the stack is stable - which it isn't
a61af66fc99e Initial load
duke
parents:
diff changeset
2910 // 100% but close enough for most practical purposes.
a61af66fc99e Initial load
duke
parents:
diff changeset
2911 throw_illegal_thread_state = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
2912 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2913 // Count all java activation, i.e., number of vframes
a61af66fc99e Initial load
duke
parents:
diff changeset
2914 for(vframeStream vfst(thr); !vfst.at_end(); vfst.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2915 // Native frames are not counted
a61af66fc99e Initial load
duke
parents:
diff changeset
2916 if (!vfst.method()->is_native()) count++;
a61af66fc99e Initial load
duke
parents:
diff changeset
2917 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2918 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2919 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2920
a61af66fc99e Initial load
duke
parents:
diff changeset
2921 if (throw_illegal_thread_state) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2922 THROW_MSG_0(vmSymbols::java_lang_IllegalThreadStateException(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2923 "this thread is not suspended");
a61af66fc99e Initial load
duke
parents:
diff changeset
2924 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2925 return count;
a61af66fc99e Initial load
duke
parents:
diff changeset
2926 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2927
a61af66fc99e Initial load
duke
parents:
diff changeset
2928 // Consider: A better way to implement JVM_Interrupt() is to acquire
a61af66fc99e Initial load
duke
parents:
diff changeset
2929 // Threads_lock to resolve the jthread into a Thread pointer, fetch
a61af66fc99e Initial load
duke
parents:
diff changeset
2930 // Thread->platformevent, Thread->native_thr, Thread->parker, etc.,
a61af66fc99e Initial load
duke
parents:
diff changeset
2931 // drop Threads_lock, and the perform the unpark() and thr_kill() operations
a61af66fc99e Initial load
duke
parents:
diff changeset
2932 // outside the critical section. Threads_lock is hot so we want to minimize
a61af66fc99e Initial load
duke
parents:
diff changeset
2933 // the hold-time. A cleaner interface would be to decompose interrupt into
a61af66fc99e Initial load
duke
parents:
diff changeset
2934 // two steps. The 1st phase, performed under Threads_lock, would return
a61af66fc99e Initial load
duke
parents:
diff changeset
2935 // a closure that'd be invoked after Threads_lock was dropped.
a61af66fc99e Initial load
duke
parents:
diff changeset
2936 // This tactic is safe as PlatformEvent and Parkers are type-stable (TSM) and
a61af66fc99e Initial load
duke
parents:
diff changeset
2937 // admit spurious wakeups.
a61af66fc99e Initial load
duke
parents:
diff changeset
2938
a61af66fc99e Initial load
duke
parents:
diff changeset
2939 JVM_ENTRY(void, JVM_Interrupt(JNIEnv* env, jobject jthread))
a61af66fc99e Initial load
duke
parents:
diff changeset
2940 JVMWrapper("JVM_Interrupt");
a61af66fc99e Initial load
duke
parents:
diff changeset
2941
a61af66fc99e Initial load
duke
parents:
diff changeset
2942 // Ensure that the C++ Thread and OSThread structures aren't freed before we operate
a61af66fc99e Initial load
duke
parents:
diff changeset
2943 oop java_thread = JNIHandles::resolve_non_null(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2944 MutexLockerEx ml(thread->threadObj() == java_thread ? NULL : Threads_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
2945 // We need to re-resolve the java_thread, since a GC might have happened during the
a61af66fc99e Initial load
duke
parents:
diff changeset
2946 // acquire of the lock
a61af66fc99e Initial load
duke
parents:
diff changeset
2947 JavaThread* thr = java_lang_Thread::thread(JNIHandles::resolve_non_null(jthread));
a61af66fc99e Initial load
duke
parents:
diff changeset
2948 if (thr != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2949 Thread::interrupt(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
2950 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2951 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2952
a61af66fc99e Initial load
duke
parents:
diff changeset
2953
a61af66fc99e Initial load
duke
parents:
diff changeset
2954 JVM_QUICK_ENTRY(jboolean, JVM_IsInterrupted(JNIEnv* env, jobject jthread, jboolean clear_interrupted))
a61af66fc99e Initial load
duke
parents:
diff changeset
2955 JVMWrapper("JVM_IsInterrupted");
a61af66fc99e Initial load
duke
parents:
diff changeset
2956
a61af66fc99e Initial load
duke
parents:
diff changeset
2957 // Ensure that the C++ Thread and OSThread structures aren't freed before we operate
a61af66fc99e Initial load
duke
parents:
diff changeset
2958 oop java_thread = JNIHandles::resolve_non_null(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2959 MutexLockerEx ml(thread->threadObj() == java_thread ? NULL : Threads_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
2960 // We need to re-resolve the java_thread, since a GC might have happened during the
a61af66fc99e Initial load
duke
parents:
diff changeset
2961 // acquire of the lock
a61af66fc99e Initial load
duke
parents:
diff changeset
2962 JavaThread* thr = java_lang_Thread::thread(JNIHandles::resolve_non_null(jthread));
a61af66fc99e Initial load
duke
parents:
diff changeset
2963 if (thr == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2964 return JNI_FALSE;
a61af66fc99e Initial load
duke
parents:
diff changeset
2965 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2966 return (jboolean) Thread::is_interrupted(thr, clear_interrupted != 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
2967 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2968 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2969
a61af66fc99e Initial load
duke
parents:
diff changeset
2970
a61af66fc99e Initial load
duke
parents:
diff changeset
2971 // Return true iff the current thread has locked the object passed in
a61af66fc99e Initial load
duke
parents:
diff changeset
2972
a61af66fc99e Initial load
duke
parents:
diff changeset
2973 JVM_ENTRY(jboolean, JVM_HoldsLock(JNIEnv* env, jclass threadClass, jobject obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
2974 JVMWrapper("JVM_HoldsLock");
a61af66fc99e Initial load
duke
parents:
diff changeset
2975 assert(THREAD->is_Java_thread(), "sanity check");
a61af66fc99e Initial load
duke
parents:
diff changeset
2976 if (obj == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2977 THROW_(vmSymbols::java_lang_NullPointerException(), JNI_FALSE);
a61af66fc99e Initial load
duke
parents:
diff changeset
2978 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2979 Handle h_obj(THREAD, JNIHandles::resolve(obj));
a61af66fc99e Initial load
duke
parents:
diff changeset
2980 return ObjectSynchronizer::current_thread_holds_lock((JavaThread*)THREAD, h_obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
2981 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2982
a61af66fc99e Initial load
duke
parents:
diff changeset
2983
a61af66fc99e Initial load
duke
parents:
diff changeset
2984 JVM_ENTRY(void, JVM_DumpAllStacks(JNIEnv* env, jclass))
a61af66fc99e Initial load
duke
parents:
diff changeset
2985 JVMWrapper("JVM_DumpAllStacks");
a61af66fc99e Initial load
duke
parents:
diff changeset
2986 VM_PrintThreads op;
a61af66fc99e Initial load
duke
parents:
diff changeset
2987 VMThread::execute(&op);
a61af66fc99e Initial load
duke
parents:
diff changeset
2988 if (JvmtiExport::should_post_data_dump()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2989 JvmtiExport::post_data_dump();
a61af66fc99e Initial load
duke
parents:
diff changeset
2990 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2991 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
2992
a61af66fc99e Initial load
duke
parents:
diff changeset
2993
a61af66fc99e Initial load
duke
parents:
diff changeset
2994 // java.lang.SecurityManager ///////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
2995
a61af66fc99e Initial load
duke
parents:
diff changeset
2996 static bool is_trusted_frame(JavaThread* jthread, vframeStream* vfst) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2997 assert(jthread->is_Java_thread(), "must be a Java thread");
a61af66fc99e Initial load
duke
parents:
diff changeset
2998 if (jthread->privileged_stack_top() == NULL) return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2999 if (jthread->privileged_stack_top()->frame_id() == vfst->frame_id()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3000 oop loader = jthread->privileged_stack_top()->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
3001 if (loader == NULL) return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
3002 bool trusted = java_lang_ClassLoader::is_trusted_loader(loader);
a61af66fc99e Initial load
duke
parents:
diff changeset
3003 if (trusted) return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
3004 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3005 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
3006 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3007
a61af66fc99e Initial load
duke
parents:
diff changeset
3008 JVM_ENTRY(jclass, JVM_CurrentLoadedClass(JNIEnv *env))
a61af66fc99e Initial load
duke
parents:
diff changeset
3009 JVMWrapper("JVM_CurrentLoadedClass");
a61af66fc99e Initial load
duke
parents:
diff changeset
3010 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3011
a61af66fc99e Initial load
duke
parents:
diff changeset
3012 for (vframeStream vfst(thread); !vfst.at_end(); vfst.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3013 // if a method in a class in a trusted loader is in a doPrivileged, return NULL
a61af66fc99e Initial load
duke
parents:
diff changeset
3014 bool trusted = is_trusted_frame(thread, &vfst);
a61af66fc99e Initial load
duke
parents:
diff changeset
3015 if (trusted) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3016
a61af66fc99e Initial load
duke
parents:
diff changeset
3017 methodOop m = vfst.method();
a61af66fc99e Initial load
duke
parents:
diff changeset
3018 if (!m->is_native()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3019 klassOop holder = m->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
3020 oop loader = instanceKlass::cast(holder)->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
3021 if (loader != NULL && !java_lang_ClassLoader::is_trusted_loader(loader)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3022 return (jclass) JNIHandles::make_local(env, Klass::cast(holder)->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
3023 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3024 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3025 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3026 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3027 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3028
a61af66fc99e Initial load
duke
parents:
diff changeset
3029
a61af66fc99e Initial load
duke
parents:
diff changeset
3030 JVM_ENTRY(jobject, JVM_CurrentClassLoader(JNIEnv *env))
a61af66fc99e Initial load
duke
parents:
diff changeset
3031 JVMWrapper("JVM_CurrentClassLoader");
a61af66fc99e Initial load
duke
parents:
diff changeset
3032 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3033
a61af66fc99e Initial load
duke
parents:
diff changeset
3034 for (vframeStream vfst(thread); !vfst.at_end(); vfst.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3035
a61af66fc99e Initial load
duke
parents:
diff changeset
3036 // if a method in a class in a trusted loader is in a doPrivileged, return NULL
a61af66fc99e Initial load
duke
parents:
diff changeset
3037 bool trusted = is_trusted_frame(thread, &vfst);
a61af66fc99e Initial load
duke
parents:
diff changeset
3038 if (trusted) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3039
a61af66fc99e Initial load
duke
parents:
diff changeset
3040 methodOop m = vfst.method();
a61af66fc99e Initial load
duke
parents:
diff changeset
3041 if (!m->is_native()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3042 klassOop holder = m->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
3043 assert(holder->is_klass(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
3044 oop loader = instanceKlass::cast(holder)->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
3045 if (loader != NULL && !java_lang_ClassLoader::is_trusted_loader(loader)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3046 return JNIHandles::make_local(env, loader);
a61af66fc99e Initial load
duke
parents:
diff changeset
3047 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3048 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3049 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3050 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3051 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3052
a61af66fc99e Initial load
duke
parents:
diff changeset
3053
a61af66fc99e Initial load
duke
parents:
diff changeset
3054 // Utility object for collecting method holders walking down the stack
a61af66fc99e Initial load
duke
parents:
diff changeset
3055 class KlassLink: public ResourceObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
3056 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
3057 KlassHandle klass;
a61af66fc99e Initial load
duke
parents:
diff changeset
3058 KlassLink* next;
a61af66fc99e Initial load
duke
parents:
diff changeset
3059
a61af66fc99e Initial load
duke
parents:
diff changeset
3060 KlassLink(KlassHandle k) { klass = k; next = NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
3061 };
a61af66fc99e Initial load
duke
parents:
diff changeset
3062
a61af66fc99e Initial load
duke
parents:
diff changeset
3063
a61af66fc99e Initial load
duke
parents:
diff changeset
3064 JVM_ENTRY(jobjectArray, JVM_GetClassContext(JNIEnv *env))
a61af66fc99e Initial load
duke
parents:
diff changeset
3065 JVMWrapper("JVM_GetClassContext");
a61af66fc99e Initial load
duke
parents:
diff changeset
3066 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3067 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3068 // Collect linked list of (handles to) method holders
a61af66fc99e Initial load
duke
parents:
diff changeset
3069 KlassLink* first = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3070 KlassLink* last = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3071 int depth = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
3072
a61af66fc99e Initial load
duke
parents:
diff changeset
3073 for(vframeStream vfst(thread); !vfst.at_end(); vfst.security_get_caller_frame(1)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3074 // Native frames are not returned
a61af66fc99e Initial load
duke
parents:
diff changeset
3075 if (!vfst.method()->is_native()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3076 klassOop holder = vfst.method()->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
3077 assert(holder->is_klass(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
3078 depth++;
a61af66fc99e Initial load
duke
parents:
diff changeset
3079 KlassLink* l = new KlassLink(KlassHandle(thread, holder));
a61af66fc99e Initial load
duke
parents:
diff changeset
3080 if (first == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3081 first = last = l;
a61af66fc99e Initial load
duke
parents:
diff changeset
3082 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
3083 last->next = l;
a61af66fc99e Initial load
duke
parents:
diff changeset
3084 last = l;
a61af66fc99e Initial load
duke
parents:
diff changeset
3085 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3086 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3087 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3088
a61af66fc99e Initial load
duke
parents:
diff changeset
3089 // Create result array of type [Ljava/lang/Class;
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
3090 objArrayOop result = oopFactory::new_objArray(SystemDictionary::Class_klass(), depth, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3091 // Fill in mirrors corresponding to method holders
a61af66fc99e Initial load
duke
parents:
diff changeset
3092 int index = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
3093 while (first != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3094 result->obj_at_put(index++, Klass::cast(first->klass())->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
3095 first = first->next;
a61af66fc99e Initial load
duke
parents:
diff changeset
3096 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3097 assert(index == depth, "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
3098
a61af66fc99e Initial load
duke
parents:
diff changeset
3099 return (jobjectArray) JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
3100 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3101
a61af66fc99e Initial load
duke
parents:
diff changeset
3102
a61af66fc99e Initial load
duke
parents:
diff changeset
3103 JVM_ENTRY(jint, JVM_ClassDepth(JNIEnv *env, jstring name))
a61af66fc99e Initial load
duke
parents:
diff changeset
3104 JVMWrapper("JVM_ClassDepth");
a61af66fc99e Initial load
duke
parents:
diff changeset
3105 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3106 Handle h_name (THREAD, JNIHandles::resolve_non_null(name));
a61af66fc99e Initial load
duke
parents:
diff changeset
3107 Handle class_name_str = java_lang_String::internalize_classname(h_name, CHECK_0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3108
a61af66fc99e Initial load
duke
parents:
diff changeset
3109 const char* str = java_lang_String::as_utf8_string(class_name_str());
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
3110 TempNewSymbol class_name_sym = SymbolTable::probe(str, (int)strlen(str));
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
3111 if (class_name_sym == NULL) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3112 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
3113 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3114
a61af66fc99e Initial load
duke
parents:
diff changeset
3115 int depth = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
3116
a61af66fc99e Initial load
duke
parents:
diff changeset
3117 for(vframeStream vfst(thread); !vfst.at_end(); vfst.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3118 if (!vfst.method()->is_native()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3119 klassOop holder = vfst.method()->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
3120 assert(holder->is_klass(), "just checking");
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
3121 if (instanceKlass::cast(holder)->name() == class_name_sym) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3122 return depth;
a61af66fc99e Initial load
duke
parents:
diff changeset
3123 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3124 depth++;
a61af66fc99e Initial load
duke
parents:
diff changeset
3125 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3126 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3127 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
3128 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3129
a61af66fc99e Initial load
duke
parents:
diff changeset
3130
a61af66fc99e Initial load
duke
parents:
diff changeset
3131 JVM_ENTRY(jint, JVM_ClassLoaderDepth(JNIEnv *env))
a61af66fc99e Initial load
duke
parents:
diff changeset
3132 JVMWrapper("JVM_ClassLoaderDepth");
a61af66fc99e Initial load
duke
parents:
diff changeset
3133 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3134 int depth = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
3135 for (vframeStream vfst(thread); !vfst.at_end(); vfst.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3136 // if a method in a class in a trusted loader is in a doPrivileged, return -1
a61af66fc99e Initial load
duke
parents:
diff changeset
3137 bool trusted = is_trusted_frame(thread, &vfst);
a61af66fc99e Initial load
duke
parents:
diff changeset
3138 if (trusted) return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
3139
a61af66fc99e Initial load
duke
parents:
diff changeset
3140 methodOop m = vfst.method();
a61af66fc99e Initial load
duke
parents:
diff changeset
3141 if (!m->is_native()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3142 klassOop holder = m->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
3143 assert(holder->is_klass(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
3144 oop loader = instanceKlass::cast(holder)->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
3145 if (loader != NULL && !java_lang_ClassLoader::is_trusted_loader(loader)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3146 return depth;
a61af66fc99e Initial load
duke
parents:
diff changeset
3147 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3148 depth++;
a61af66fc99e Initial load
duke
parents:
diff changeset
3149 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3150 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3151 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
3152 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3153
a61af66fc99e Initial load
duke
parents:
diff changeset
3154
a61af66fc99e Initial load
duke
parents:
diff changeset
3155 // java.lang.Package ////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3156
a61af66fc99e Initial load
duke
parents:
diff changeset
3157
a61af66fc99e Initial load
duke
parents:
diff changeset
3158 JVM_ENTRY(jstring, JVM_GetSystemPackage(JNIEnv *env, jstring name))
a61af66fc99e Initial load
duke
parents:
diff changeset
3159 JVMWrapper("JVM_GetSystemPackage");
a61af66fc99e Initial load
duke
parents:
diff changeset
3160 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3161 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3162 char* str = java_lang_String::as_utf8_string(JNIHandles::resolve_non_null(name));
a61af66fc99e Initial load
duke
parents:
diff changeset
3163 oop result = ClassLoader::get_system_package(str, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3164 return (jstring) JNIHandles::make_local(result);
a61af66fc99e Initial load
duke
parents:
diff changeset
3165 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3166
a61af66fc99e Initial load
duke
parents:
diff changeset
3167
a61af66fc99e Initial load
duke
parents:
diff changeset
3168 JVM_ENTRY(jobjectArray, JVM_GetSystemPackages(JNIEnv *env))
a61af66fc99e Initial load
duke
parents:
diff changeset
3169 JVMWrapper("JVM_GetSystemPackages");
a61af66fc99e Initial load
duke
parents:
diff changeset
3170 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3171 objArrayOop result = ClassLoader::get_system_packages(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3172 return (jobjectArray) JNIHandles::make_local(result);
a61af66fc99e Initial load
duke
parents:
diff changeset
3173 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3174
a61af66fc99e Initial load
duke
parents:
diff changeset
3175
a61af66fc99e Initial load
duke
parents:
diff changeset
3176 // ObjectInputStream ///////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3177
a61af66fc99e Initial load
duke
parents:
diff changeset
3178 bool force_verify_field_access(klassOop current_class, klassOop field_class, AccessFlags access, bool classloader_only) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3179 if (current_class == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3180 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
3181 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3182 if ((current_class == field_class) || access.is_public()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3183 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
3184 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3185
a61af66fc99e Initial load
duke
parents:
diff changeset
3186 if (access.is_protected()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3187 // See if current_class is a subclass of field_class
a61af66fc99e Initial load
duke
parents:
diff changeset
3188 if (Klass::cast(current_class)->is_subclass_of(field_class)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3189 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
3190 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3191 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3192
a61af66fc99e Initial load
duke
parents:
diff changeset
3193 return (!access.is_private() && instanceKlass::cast(current_class)->is_same_class_package(field_class));
a61af66fc99e Initial load
duke
parents:
diff changeset
3194 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3195
a61af66fc99e Initial load
duke
parents:
diff changeset
3196
a61af66fc99e Initial load
duke
parents:
diff changeset
3197 // JVM_AllocateNewObject and JVM_AllocateNewArray are unused as of 1.4
a61af66fc99e Initial load
duke
parents:
diff changeset
3198 JVM_ENTRY(jobject, JVM_AllocateNewObject(JNIEnv *env, jobject receiver, jclass currClass, jclass initClass))
a61af66fc99e Initial load
duke
parents:
diff changeset
3199 JVMWrapper("JVM_AllocateNewObject");
a61af66fc99e Initial load
duke
parents:
diff changeset
3200 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3201 // Receiver is not used
a61af66fc99e Initial load
duke
parents:
diff changeset
3202 oop curr_mirror = JNIHandles::resolve_non_null(currClass);
a61af66fc99e Initial load
duke
parents:
diff changeset
3203 oop init_mirror = JNIHandles::resolve_non_null(initClass);
a61af66fc99e Initial load
duke
parents:
diff changeset
3204
a61af66fc99e Initial load
duke
parents:
diff changeset
3205 // Cannot instantiate primitive types
a61af66fc99e Initial load
duke
parents:
diff changeset
3206 if (java_lang_Class::is_primitive(curr_mirror) || java_lang_Class::is_primitive(init_mirror)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3207 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3208 THROW_0(vmSymbols::java_lang_InvalidClassException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3209 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3210
a61af66fc99e Initial load
duke
parents:
diff changeset
3211 // Arrays not allowed here, must use JVM_AllocateNewArray
a61af66fc99e Initial load
duke
parents:
diff changeset
3212 if (Klass::cast(java_lang_Class::as_klassOop(curr_mirror))->oop_is_javaArray() ||
a61af66fc99e Initial load
duke
parents:
diff changeset
3213 Klass::cast(java_lang_Class::as_klassOop(init_mirror))->oop_is_javaArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3214 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3215 THROW_0(vmSymbols::java_lang_InvalidClassException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3216 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3217
a61af66fc99e Initial load
duke
parents:
diff changeset
3218 instanceKlassHandle curr_klass (THREAD, java_lang_Class::as_klassOop(curr_mirror));
a61af66fc99e Initial load
duke
parents:
diff changeset
3219 instanceKlassHandle init_klass (THREAD, java_lang_Class::as_klassOop(init_mirror));
a61af66fc99e Initial load
duke
parents:
diff changeset
3220
a61af66fc99e Initial load
duke
parents:
diff changeset
3221 assert(curr_klass->is_subclass_of(init_klass()), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
3222
a61af66fc99e Initial load
duke
parents:
diff changeset
3223 // Interfaces, abstract classes, and java.lang.Class classes cannot be instantiated directly.
a61af66fc99e Initial load
duke
parents:
diff changeset
3224 curr_klass->check_valid_for_instantiation(false, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3225
a61af66fc99e Initial load
duke
parents:
diff changeset
3226 // Make sure klass is initialized, since we are about to instantiate one of them.
a61af66fc99e Initial load
duke
parents:
diff changeset
3227 curr_klass->initialize(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3228
a61af66fc99e Initial load
duke
parents:
diff changeset
3229 methodHandle m (THREAD,
a61af66fc99e Initial load
duke
parents:
diff changeset
3230 init_klass->find_method(vmSymbols::object_initializer_name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
3231 vmSymbols::void_method_signature()));
a61af66fc99e Initial load
duke
parents:
diff changeset
3232 if (m.is_null()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3233 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3234 THROW_MSG_0(vmSymbols::java_lang_NoSuchMethodError(),
a61af66fc99e Initial load
duke
parents:
diff changeset
3235 methodOopDesc::name_and_sig_as_C_string(Klass::cast(init_klass()),
a61af66fc99e Initial load
duke
parents:
diff changeset
3236 vmSymbols::object_initializer_name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
3237 vmSymbols::void_method_signature()));
a61af66fc99e Initial load
duke
parents:
diff changeset
3238 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3239
a61af66fc99e Initial load
duke
parents:
diff changeset
3240 if (curr_klass == init_klass && !m->is_public()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3241 // Calling the constructor for class 'curr_klass'.
a61af66fc99e Initial load
duke
parents:
diff changeset
3242 // Only allow calls to a public no-arg constructor.
a61af66fc99e Initial load
duke
parents:
diff changeset
3243 // This path corresponds to creating an Externalizable object.
a61af66fc99e Initial load
duke
parents:
diff changeset
3244 THROW_0(vmSymbols::java_lang_IllegalAccessException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3245 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3246
a61af66fc99e Initial load
duke
parents:
diff changeset
3247 if (!force_verify_field_access(curr_klass(), init_klass(), m->access_flags(), false)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3248 // subclass 'curr_klass' does not have access to no-arg constructor of 'initcb'
a61af66fc99e Initial load
duke
parents:
diff changeset
3249 THROW_0(vmSymbols::java_lang_IllegalAccessException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3250 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3251
a61af66fc99e Initial load
duke
parents:
diff changeset
3252 Handle obj = curr_klass->allocate_instance_handle(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3253 // Call constructor m. This might call a constructor higher up in the hierachy
a61af66fc99e Initial load
duke
parents:
diff changeset
3254 JavaCalls::call_default_constructor(thread, m, obj, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3255
a61af66fc99e Initial load
duke
parents:
diff changeset
3256 return JNIHandles::make_local(obj());
a61af66fc99e Initial load
duke
parents:
diff changeset
3257 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3258
a61af66fc99e Initial load
duke
parents:
diff changeset
3259
a61af66fc99e Initial load
duke
parents:
diff changeset
3260 JVM_ENTRY(jobject, JVM_AllocateNewArray(JNIEnv *env, jobject obj, jclass currClass, jint length))
a61af66fc99e Initial load
duke
parents:
diff changeset
3261 JVMWrapper("JVM_AllocateNewArray");
a61af66fc99e Initial load
duke
parents:
diff changeset
3262 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3263 oop mirror = JNIHandles::resolve_non_null(currClass);
a61af66fc99e Initial load
duke
parents:
diff changeset
3264
a61af66fc99e Initial load
duke
parents:
diff changeset
3265 if (java_lang_Class::is_primitive(mirror)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3266 THROW_0(vmSymbols::java_lang_InvalidClassException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3267 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3268 klassOop k = java_lang_Class::as_klassOop(mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
3269 oop result;
a61af66fc99e Initial load
duke
parents:
diff changeset
3270
a61af66fc99e Initial load
duke
parents:
diff changeset
3271 if (k->klass_part()->oop_is_typeArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3272 // typeArray
a61af66fc99e Initial load
duke
parents:
diff changeset
3273 result = typeArrayKlass::cast(k)->allocate(length, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3274 } else if (k->klass_part()->oop_is_objArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3275 // objArray
a61af66fc99e Initial load
duke
parents:
diff changeset
3276 objArrayKlassHandle oak(THREAD, k);
a61af66fc99e Initial load
duke
parents:
diff changeset
3277 oak->initialize(CHECK_NULL); // make sure class is initialized (matches Classic VM behavior)
a61af66fc99e Initial load
duke
parents:
diff changeset
3278 result = oak->allocate(length, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3279 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
3280 THROW_0(vmSymbols::java_lang_InvalidClassException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3281 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3282 return JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
3283 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3284
a61af66fc99e Initial load
duke
parents:
diff changeset
3285
a61af66fc99e Initial load
duke
parents:
diff changeset
3286 // Return the first non-null class loader up the execution stack, or null
a61af66fc99e Initial load
duke
parents:
diff changeset
3287 // if only code from the null class loader is on the stack.
a61af66fc99e Initial load
duke
parents:
diff changeset
3288
a61af66fc99e Initial load
duke
parents:
diff changeset
3289 JVM_ENTRY(jobject, JVM_LatestUserDefinedLoader(JNIEnv *env))
a61af66fc99e Initial load
duke
parents:
diff changeset
3290 for (vframeStream vfst(thread); !vfst.at_end(); vfst.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3291 // UseNewReflection
a61af66fc99e Initial load
duke
parents:
diff changeset
3292 vfst.skip_reflection_related_frames(); // Only needed for 1.4 reflection
a61af66fc99e Initial load
duke
parents:
diff changeset
3293 klassOop holder = vfst.method()->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
3294 oop loader = instanceKlass::cast(holder)->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
3295 if (loader != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3296 return JNIHandles::make_local(env, loader);
a61af66fc99e Initial load
duke
parents:
diff changeset
3297 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3298 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3299 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3300 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3301
a61af66fc99e Initial load
duke
parents:
diff changeset
3302
a61af66fc99e Initial load
duke
parents:
diff changeset
3303 // Load a class relative to the most recent class on the stack with a non-null
a61af66fc99e Initial load
duke
parents:
diff changeset
3304 // classloader.
a61af66fc99e Initial load
duke
parents:
diff changeset
3305 // This function has been deprecated and should not be considered part of the
a61af66fc99e Initial load
duke
parents:
diff changeset
3306 // specified JVM interface.
a61af66fc99e Initial load
duke
parents:
diff changeset
3307
a61af66fc99e Initial load
duke
parents:
diff changeset
3308 JVM_ENTRY(jclass, JVM_LoadClass0(JNIEnv *env, jobject receiver,
a61af66fc99e Initial load
duke
parents:
diff changeset
3309 jclass currClass, jstring currClassName))
a61af66fc99e Initial load
duke
parents:
diff changeset
3310 JVMWrapper("JVM_LoadClass0");
a61af66fc99e Initial load
duke
parents:
diff changeset
3311 // Receiver is not used
a61af66fc99e Initial load
duke
parents:
diff changeset
3312 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
3313
a61af66fc99e Initial load
duke
parents:
diff changeset
3314 // Class name argument is not guaranteed to be in internal format
a61af66fc99e Initial load
duke
parents:
diff changeset
3315 Handle classname (THREAD, JNIHandles::resolve_non_null(currClassName));
a61af66fc99e Initial load
duke
parents:
diff changeset
3316 Handle string = java_lang_String::internalize_classname(classname, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3317
a61af66fc99e Initial load
duke
parents:
diff changeset
3318 const char* str = java_lang_String::as_utf8_string(string());
a61af66fc99e Initial load
duke
parents:
diff changeset
3319
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
3320 if (str == NULL || (int)strlen(str) > Symbol::max_length()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3321 // It's impossible to create this class; the name cannot fit
a61af66fc99e Initial load
duke
parents:
diff changeset
3322 // into the constant pool.
a61af66fc99e Initial load
duke
parents:
diff changeset
3323 THROW_MSG_0(vmSymbols::java_lang_NoClassDefFoundError(), str);
a61af66fc99e Initial load
duke
parents:
diff changeset
3324 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3325
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
3326 TempNewSymbol name = SymbolTable::new_symbol(str, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3327 Handle curr_klass (THREAD, JNIHandles::resolve(currClass));
a61af66fc99e Initial load
duke
parents:
diff changeset
3328 // Find the most recent class on the stack with a non-null classloader
a61af66fc99e Initial load
duke
parents:
diff changeset
3329 oop loader = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3330 oop protection_domain = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3331 if (curr_klass.is_null()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3332 for (vframeStream vfst(thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
3333 !vfst.at_end() && loader == NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3334 vfst.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3335 if (!vfst.method()->is_native()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3336 klassOop holder = vfst.method()->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
3337 loader = instanceKlass::cast(holder)->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
3338 protection_domain = instanceKlass::cast(holder)->protection_domain();
a61af66fc99e Initial load
duke
parents:
diff changeset
3339 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3340 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3341 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
3342 klassOop curr_klass_oop = java_lang_Class::as_klassOop(curr_klass());
a61af66fc99e Initial load
duke
parents:
diff changeset
3343 loader = instanceKlass::cast(curr_klass_oop)->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
3344 protection_domain = instanceKlass::cast(curr_klass_oop)->protection_domain();
a61af66fc99e Initial load
duke
parents:
diff changeset
3345 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3346 Handle h_loader(THREAD, loader);
a61af66fc99e Initial load
duke
parents:
diff changeset
3347 Handle h_prot (THREAD, protection_domain);
657
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
3348 jclass result = find_class_from_class_loader(env, name, true, h_loader, h_prot,
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
3349 false, thread);
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
3350 if (TraceClassResolution && result != NULL) {
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
3351 trace_class_resolution(java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(result)));
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
3352 }
715dceaa89b7 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 579
diff changeset
3353 return result;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3354 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3355
a61af66fc99e Initial load
duke
parents:
diff changeset
3356
a61af66fc99e Initial load
duke
parents:
diff changeset
3357 // Array ///////////////////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3358
a61af66fc99e Initial load
duke
parents:
diff changeset
3359
a61af66fc99e Initial load
duke
parents:
diff changeset
3360 // resolve array handle and check arguments
a61af66fc99e Initial load
duke
parents:
diff changeset
3361 static inline arrayOop check_array(JNIEnv *env, jobject arr, bool type_array_only, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3362 if (arr == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3363 THROW_0(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3364 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3365 oop a = JNIHandles::resolve_non_null(arr);
a61af66fc99e Initial load
duke
parents:
diff changeset
3366 if (!a->is_javaArray() || (type_array_only && !a->is_typeArray())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3367 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "Argument is not an array");
a61af66fc99e Initial load
duke
parents:
diff changeset
3368 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3369 return arrayOop(a);
a61af66fc99e Initial load
duke
parents:
diff changeset
3370 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3371
a61af66fc99e Initial load
duke
parents:
diff changeset
3372
a61af66fc99e Initial load
duke
parents:
diff changeset
3373 JVM_ENTRY(jint, JVM_GetArrayLength(JNIEnv *env, jobject arr))
a61af66fc99e Initial load
duke
parents:
diff changeset
3374 JVMWrapper("JVM_GetArrayLength");
a61af66fc99e Initial load
duke
parents:
diff changeset
3375 arrayOop a = check_array(env, arr, false, CHECK_0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3376 return a->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
3377 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3378
a61af66fc99e Initial load
duke
parents:
diff changeset
3379
a61af66fc99e Initial load
duke
parents:
diff changeset
3380 JVM_ENTRY(jobject, JVM_GetArrayElement(JNIEnv *env, jobject arr, jint index))
a61af66fc99e Initial load
duke
parents:
diff changeset
3381 JVMWrapper("JVM_Array_Get");
a61af66fc99e Initial load
duke
parents:
diff changeset
3382 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3383 arrayOop a = check_array(env, arr, false, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3384 jvalue value;
a61af66fc99e Initial load
duke
parents:
diff changeset
3385 BasicType type = Reflection::array_get(&value, a, index, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3386 oop box = Reflection::box(&value, type, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3387 return JNIHandles::make_local(env, box);
a61af66fc99e Initial load
duke
parents:
diff changeset
3388 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3389
a61af66fc99e Initial load
duke
parents:
diff changeset
3390
a61af66fc99e Initial load
duke
parents:
diff changeset
3391 JVM_ENTRY(jvalue, JVM_GetPrimitiveArrayElement(JNIEnv *env, jobject arr, jint index, jint wCode))
a61af66fc99e Initial load
duke
parents:
diff changeset
3392 JVMWrapper("JVM_GetPrimitiveArrayElement");
a61af66fc99e Initial load
duke
parents:
diff changeset
3393 jvalue value;
a61af66fc99e Initial load
duke
parents:
diff changeset
3394 value.i = 0; // to initialize value before getting used in CHECK
a61af66fc99e Initial load
duke
parents:
diff changeset
3395 arrayOop a = check_array(env, arr, true, CHECK_(value));
a61af66fc99e Initial load
duke
parents:
diff changeset
3396 assert(a->is_typeArray(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
3397 BasicType type = Reflection::array_get(&value, a, index, CHECK_(value));
a61af66fc99e Initial load
duke
parents:
diff changeset
3398 BasicType wide_type = (BasicType) wCode;
a61af66fc99e Initial load
duke
parents:
diff changeset
3399 if (type != wide_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3400 Reflection::widen(&value, type, wide_type, CHECK_(value));
a61af66fc99e Initial load
duke
parents:
diff changeset
3401 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3402 return value;
a61af66fc99e Initial load
duke
parents:
diff changeset
3403 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3404
a61af66fc99e Initial load
duke
parents:
diff changeset
3405
a61af66fc99e Initial load
duke
parents:
diff changeset
3406 JVM_ENTRY(void, JVM_SetArrayElement(JNIEnv *env, jobject arr, jint index, jobject val))
a61af66fc99e Initial load
duke
parents:
diff changeset
3407 JVMWrapper("JVM_SetArrayElement");
a61af66fc99e Initial load
duke
parents:
diff changeset
3408 arrayOop a = check_array(env, arr, false, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
3409 oop box = JNIHandles::resolve(val);
a61af66fc99e Initial load
duke
parents:
diff changeset
3410 jvalue value;
a61af66fc99e Initial load
duke
parents:
diff changeset
3411 value.i = 0; // to initialize value before getting used in CHECK
a61af66fc99e Initial load
duke
parents:
diff changeset
3412 BasicType value_type;
a61af66fc99e Initial load
duke
parents:
diff changeset
3413 if (a->is_objArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3414 // Make sure we do no unbox e.g. java/lang/Integer instances when storing into an object array
a61af66fc99e Initial load
duke
parents:
diff changeset
3415 value_type = Reflection::unbox_for_regular_object(box, &value);
a61af66fc99e Initial load
duke
parents:
diff changeset
3416 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
3417 value_type = Reflection::unbox_for_primitive(box, &value, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
3418 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3419 Reflection::array_set(&value, a, index, value_type, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
3420 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3421
a61af66fc99e Initial load
duke
parents:
diff changeset
3422
a61af66fc99e Initial load
duke
parents:
diff changeset
3423 JVM_ENTRY(void, JVM_SetPrimitiveArrayElement(JNIEnv *env, jobject arr, jint index, jvalue v, unsigned char vCode))
a61af66fc99e Initial load
duke
parents:
diff changeset
3424 JVMWrapper("JVM_SetPrimitiveArrayElement");
a61af66fc99e Initial load
duke
parents:
diff changeset
3425 arrayOop a = check_array(env, arr, true, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
3426 assert(a->is_typeArray(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
3427 BasicType value_type = (BasicType) vCode;
a61af66fc99e Initial load
duke
parents:
diff changeset
3428 Reflection::array_set(&v, a, index, value_type, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
3429 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3430
a61af66fc99e Initial load
duke
parents:
diff changeset
3431
a61af66fc99e Initial load
duke
parents:
diff changeset
3432 JVM_ENTRY(jobject, JVM_NewArray(JNIEnv *env, jclass eltClass, jint length))
a61af66fc99e Initial load
duke
parents:
diff changeset
3433 JVMWrapper("JVM_NewArray");
a61af66fc99e Initial load
duke
parents:
diff changeset
3434 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3435 oop element_mirror = JNIHandles::resolve(eltClass);
a61af66fc99e Initial load
duke
parents:
diff changeset
3436 oop result = Reflection::reflect_new_array(element_mirror, length, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3437 return JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
3438 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3439
a61af66fc99e Initial load
duke
parents:
diff changeset
3440
a61af66fc99e Initial load
duke
parents:
diff changeset
3441 JVM_ENTRY(jobject, JVM_NewMultiArray(JNIEnv *env, jclass eltClass, jintArray dim))
a61af66fc99e Initial load
duke
parents:
diff changeset
3442 JVMWrapper("JVM_NewMultiArray");
a61af66fc99e Initial load
duke
parents:
diff changeset
3443 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3444 arrayOop dim_array = check_array(env, dim, true, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3445 oop element_mirror = JNIHandles::resolve(eltClass);
a61af66fc99e Initial load
duke
parents:
diff changeset
3446 assert(dim_array->is_typeArray(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
3447 oop result = Reflection::reflect_new_multi_array(element_mirror, typeArrayOop(dim_array), CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3448 return JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
3449 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3450
a61af66fc99e Initial load
duke
parents:
diff changeset
3451
a61af66fc99e Initial load
duke
parents:
diff changeset
3452 // Networking library support ////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3453
a61af66fc99e Initial load
duke
parents:
diff changeset
3454 JVM_LEAF(jint, JVM_InitializeSocketLibrary())
a61af66fc99e Initial load
duke
parents:
diff changeset
3455 JVMWrapper("JVM_InitializeSocketLibrary");
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3456 return 0;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3457 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3458
a61af66fc99e Initial load
duke
parents:
diff changeset
3459
a61af66fc99e Initial load
duke
parents:
diff changeset
3460 JVM_LEAF(jint, JVM_Socket(jint domain, jint type, jint protocol))
a61af66fc99e Initial load
duke
parents:
diff changeset
3461 JVMWrapper("JVM_Socket");
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3462 return os::socket(domain, type, protocol);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3463 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3464
a61af66fc99e Initial load
duke
parents:
diff changeset
3465
a61af66fc99e Initial load
duke
parents:
diff changeset
3466 JVM_LEAF(jint, JVM_SocketClose(jint fd))
a61af66fc99e Initial load
duke
parents:
diff changeset
3467 JVMWrapper2("JVM_SocketClose (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3468 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3469 return os::socket_close(fd);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3470 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3471
a61af66fc99e Initial load
duke
parents:
diff changeset
3472
a61af66fc99e Initial load
duke
parents:
diff changeset
3473 JVM_LEAF(jint, JVM_SocketShutdown(jint fd, jint howto))
a61af66fc99e Initial load
duke
parents:
diff changeset
3474 JVMWrapper2("JVM_SocketShutdown (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3475 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3476 return os::socket_shutdown(fd, howto);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3477 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3478
a61af66fc99e Initial load
duke
parents:
diff changeset
3479
a61af66fc99e Initial load
duke
parents:
diff changeset
3480 JVM_LEAF(jint, JVM_Recv(jint fd, char *buf, jint nBytes, jint flags))
a61af66fc99e Initial load
duke
parents:
diff changeset
3481 JVMWrapper2("JVM_Recv (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3482 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3483 return os::recv(fd, buf, nBytes, flags);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3484 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3485
a61af66fc99e Initial load
duke
parents:
diff changeset
3486
a61af66fc99e Initial load
duke
parents:
diff changeset
3487 JVM_LEAF(jint, JVM_Send(jint fd, char *buf, jint nBytes, jint flags))
a61af66fc99e Initial load
duke
parents:
diff changeset
3488 JVMWrapper2("JVM_Send (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3489 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3490 return os::send(fd, buf, nBytes, flags);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3491 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3492
a61af66fc99e Initial load
duke
parents:
diff changeset
3493
a61af66fc99e Initial load
duke
parents:
diff changeset
3494 JVM_LEAF(jint, JVM_Timeout(int fd, long timeout))
a61af66fc99e Initial load
duke
parents:
diff changeset
3495 JVMWrapper2("JVM_Timeout (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3496 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3497 return os::timeout(fd, timeout);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3498 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3499
a61af66fc99e Initial load
duke
parents:
diff changeset
3500
a61af66fc99e Initial load
duke
parents:
diff changeset
3501 JVM_LEAF(jint, JVM_Listen(jint fd, jint count))
a61af66fc99e Initial load
duke
parents:
diff changeset
3502 JVMWrapper2("JVM_Listen (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3503 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3504 return os::listen(fd, count);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3505 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3506
a61af66fc99e Initial load
duke
parents:
diff changeset
3507
a61af66fc99e Initial load
duke
parents:
diff changeset
3508 JVM_LEAF(jint, JVM_Connect(jint fd, struct sockaddr *him, jint len))
a61af66fc99e Initial load
duke
parents:
diff changeset
3509 JVMWrapper2("JVM_Connect (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3510 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3511 return os::connect(fd, him, len);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3512 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3513
a61af66fc99e Initial load
duke
parents:
diff changeset
3514
a61af66fc99e Initial load
duke
parents:
diff changeset
3515 JVM_LEAF(jint, JVM_Bind(jint fd, struct sockaddr *him, jint len))
a61af66fc99e Initial load
duke
parents:
diff changeset
3516 JVMWrapper2("JVM_Bind (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3517 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3518 return os::bind(fd, him, len);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3519 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3520
a61af66fc99e Initial load
duke
parents:
diff changeset
3521
a61af66fc99e Initial load
duke
parents:
diff changeset
3522 JVM_LEAF(jint, JVM_Accept(jint fd, struct sockaddr *him, jint *len))
a61af66fc99e Initial load
duke
parents:
diff changeset
3523 JVMWrapper2("JVM_Accept (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3524 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3525 return os::accept(fd, him, (int *)len);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3526 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3527
a61af66fc99e Initial load
duke
parents:
diff changeset
3528
a61af66fc99e Initial load
duke
parents:
diff changeset
3529 JVM_LEAF(jint, JVM_RecvFrom(jint fd, char *buf, int nBytes, int flags, struct sockaddr *from, int *fromlen))
a61af66fc99e Initial load
duke
parents:
diff changeset
3530 JVMWrapper2("JVM_RecvFrom (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3531 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3532 return os::recvfrom(fd, buf, nBytes, flags, from, fromlen);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3533 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3534
a61af66fc99e Initial load
duke
parents:
diff changeset
3535
a61af66fc99e Initial load
duke
parents:
diff changeset
3536 JVM_LEAF(jint, JVM_GetSockName(jint fd, struct sockaddr *him, int *len))
a61af66fc99e Initial load
duke
parents:
diff changeset
3537 JVMWrapper2("JVM_GetSockName (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3538 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3539 return os::get_sock_name(fd, him, len);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3540 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3541
a61af66fc99e Initial load
duke
parents:
diff changeset
3542
a61af66fc99e Initial load
duke
parents:
diff changeset
3543 JVM_LEAF(jint, JVM_SendTo(jint fd, char *buf, int len, int flags, struct sockaddr *to, int tolen))
a61af66fc99e Initial load
duke
parents:
diff changeset
3544 JVMWrapper2("JVM_SendTo (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3545 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3546 return os::sendto(fd, buf, len, flags, to, tolen);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3547 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3548
a61af66fc99e Initial load
duke
parents:
diff changeset
3549
a61af66fc99e Initial load
duke
parents:
diff changeset
3550 JVM_LEAF(jint, JVM_SocketAvailable(jint fd, jint *pbytes))
a61af66fc99e Initial load
duke
parents:
diff changeset
3551 JVMWrapper2("JVM_SocketAvailable (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3552 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3553 return os::socket_available(fd, pbytes);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3554 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3555
a61af66fc99e Initial load
duke
parents:
diff changeset
3556
a61af66fc99e Initial load
duke
parents:
diff changeset
3557 JVM_LEAF(jint, JVM_GetSockOpt(jint fd, int level, int optname, char *optval, int *optlen))
a61af66fc99e Initial load
duke
parents:
diff changeset
3558 JVMWrapper2("JVM_GetSockOpt (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3559 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3560 return os::get_sock_opt(fd, level, optname, optval, optlen);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3561 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3562
a61af66fc99e Initial load
duke
parents:
diff changeset
3563
a61af66fc99e Initial load
duke
parents:
diff changeset
3564 JVM_LEAF(jint, JVM_SetSockOpt(jint fd, int level, int optname, const char *optval, int optlen))
a61af66fc99e Initial load
duke
parents:
diff changeset
3565 JVMWrapper2("JVM_GetSockOpt (0x%x)", fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
3566 //%note jvm_r6
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3567 return os::set_sock_opt(fd, level, optname, optval, optlen);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3568 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3569
a61af66fc99e Initial load
duke
parents:
diff changeset
3570 JVM_LEAF(int, JVM_GetHostName(char* name, int namelen))
a61af66fc99e Initial load
duke
parents:
diff changeset
3571 JVMWrapper("JVM_GetHostName");
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3572 return os::get_host_name(name, namelen);
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3573 JVM_END
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3574
a61af66fc99e Initial load
duke
parents:
diff changeset
3575 // Library support ///////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3576
a61af66fc99e Initial load
duke
parents:
diff changeset
3577 JVM_ENTRY_NO_ENV(void*, JVM_LoadLibrary(const char* name))
a61af66fc99e Initial load
duke
parents:
diff changeset
3578 //%note jvm_ct
a61af66fc99e Initial load
duke
parents:
diff changeset
3579 JVMWrapper2("JVM_LoadLibrary (%s)", name);
a61af66fc99e Initial load
duke
parents:
diff changeset
3580 char ebuf[1024];
a61af66fc99e Initial load
duke
parents:
diff changeset
3581 void *load_result;
a61af66fc99e Initial load
duke
parents:
diff changeset
3582 {
a61af66fc99e Initial load
duke
parents:
diff changeset
3583 ThreadToNativeFromVM ttnfvm(thread);
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3584 load_result = os::dll_load(name, ebuf, sizeof ebuf);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3585 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3586 if (load_result == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3587 char msg[1024];
a61af66fc99e Initial load
duke
parents:
diff changeset
3588 jio_snprintf(msg, sizeof msg, "%s: %s", name, ebuf);
a61af66fc99e Initial load
duke
parents:
diff changeset
3589 // Since 'ebuf' may contain a string encoded using
a61af66fc99e Initial load
duke
parents:
diff changeset
3590 // platform encoding scheme, we need to pass
a61af66fc99e Initial load
duke
parents:
diff changeset
3591 // Exceptions::unsafe_to_utf8 to the new_exception method
a61af66fc99e Initial load
duke
parents:
diff changeset
3592 // as the last argument. See bug 6367357.
a61af66fc99e Initial load
duke
parents:
diff changeset
3593 Handle h_exception =
a61af66fc99e Initial load
duke
parents:
diff changeset
3594 Exceptions::new_exception(thread,
a61af66fc99e Initial load
duke
parents:
diff changeset
3595 vmSymbols::java_lang_UnsatisfiedLinkError(),
a61af66fc99e Initial load
duke
parents:
diff changeset
3596 msg, Exceptions::unsafe_to_utf8);
a61af66fc99e Initial load
duke
parents:
diff changeset
3597
a61af66fc99e Initial load
duke
parents:
diff changeset
3598 THROW_HANDLE_0(h_exception);
a61af66fc99e Initial load
duke
parents:
diff changeset
3599 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3600 return load_result;
a61af66fc99e Initial load
duke
parents:
diff changeset
3601 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3602
a61af66fc99e Initial load
duke
parents:
diff changeset
3603
a61af66fc99e Initial load
duke
parents:
diff changeset
3604 JVM_LEAF(void, JVM_UnloadLibrary(void* handle))
a61af66fc99e Initial load
duke
parents:
diff changeset
3605 JVMWrapper("JVM_UnloadLibrary");
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3606 os::dll_unload(handle);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3607 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3608
a61af66fc99e Initial load
duke
parents:
diff changeset
3609
a61af66fc99e Initial load
duke
parents:
diff changeset
3610 JVM_LEAF(void*, JVM_FindLibraryEntry(void* handle, const char* name))
a61af66fc99e Initial load
duke
parents:
diff changeset
3611 JVMWrapper2("JVM_FindLibraryEntry (%s)", name);
1980
828eafbd85cc 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 1972
diff changeset
3612 return os::dll_lookup(handle, name);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3613 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3614
a61af66fc99e Initial load
duke
parents:
diff changeset
3615 // Floating point support ////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3616
a61af66fc99e Initial load
duke
parents:
diff changeset
3617 JVM_LEAF(jboolean, JVM_IsNaN(jdouble a))
a61af66fc99e Initial load
duke
parents:
diff changeset
3618 JVMWrapper("JVM_IsNaN");
a61af66fc99e Initial load
duke
parents:
diff changeset
3619 return g_isnan(a);
a61af66fc99e Initial load
duke
parents:
diff changeset
3620 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3621
a61af66fc99e Initial load
duke
parents:
diff changeset
3622
a61af66fc99e Initial load
duke
parents:
diff changeset
3623
a61af66fc99e Initial load
duke
parents:
diff changeset
3624 // JNI version ///////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3625
a61af66fc99e Initial load
duke
parents:
diff changeset
3626 JVM_LEAF(jboolean, JVM_IsSupportedJNIVersion(jint version))
a61af66fc99e Initial load
duke
parents:
diff changeset
3627 JVMWrapper2("JVM_IsSupportedJNIVersion (%d)", version);
a61af66fc99e Initial load
duke
parents:
diff changeset
3628 return Threads::is_supported_jni_version_including_1_1(version);
a61af66fc99e Initial load
duke
parents:
diff changeset
3629 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3630
a61af66fc99e Initial load
duke
parents:
diff changeset
3631
a61af66fc99e Initial load
duke
parents:
diff changeset
3632 // String support ///////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3633
a61af66fc99e Initial load
duke
parents:
diff changeset
3634 JVM_ENTRY(jstring, JVM_InternString(JNIEnv *env, jstring str))
a61af66fc99e Initial load
duke
parents:
diff changeset
3635 JVMWrapper("JVM_InternString");
a61af66fc99e Initial load
duke
parents:
diff changeset
3636 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
3637 if (str == NULL) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3638 oop string = JNIHandles::resolve_non_null(str);
a61af66fc99e Initial load
duke
parents:
diff changeset
3639 oop result = StringTable::intern(string, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3640 return (jstring) JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
3641 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3642
a61af66fc99e Initial load
duke
parents:
diff changeset
3643
a61af66fc99e Initial load
duke
parents:
diff changeset
3644 // Raw monitor support //////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3645
a61af66fc99e Initial load
duke
parents:
diff changeset
3646 // The lock routine below calls lock_without_safepoint_check in order to get a raw lock
a61af66fc99e Initial load
duke
parents:
diff changeset
3647 // without interfering with the safepoint mechanism. The routines are not JVM_LEAF because
a61af66fc99e Initial load
duke
parents:
diff changeset
3648 // they might be called by non-java threads. The JVM_LEAF installs a NoHandleMark check
a61af66fc99e Initial load
duke
parents:
diff changeset
3649 // that only works with java threads.
a61af66fc99e Initial load
duke
parents:
diff changeset
3650
a61af66fc99e Initial load
duke
parents:
diff changeset
3651
a61af66fc99e Initial load
duke
parents:
diff changeset
3652 JNIEXPORT void* JNICALL JVM_RawMonitorCreate(void) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3653 VM_Exit::block_if_vm_exited();
a61af66fc99e Initial load
duke
parents:
diff changeset
3654 JVMWrapper("JVM_RawMonitorCreate");
a61af66fc99e Initial load
duke
parents:
diff changeset
3655 return new Mutex(Mutex::native, "JVM_RawMonitorCreate");
a61af66fc99e Initial load
duke
parents:
diff changeset
3656 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3657
a61af66fc99e Initial load
duke
parents:
diff changeset
3658
a61af66fc99e Initial load
duke
parents:
diff changeset
3659 JNIEXPORT void JNICALL JVM_RawMonitorDestroy(void *mon) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3660 VM_Exit::block_if_vm_exited();
a61af66fc99e Initial load
duke
parents:
diff changeset
3661 JVMWrapper("JVM_RawMonitorDestroy");
a61af66fc99e Initial load
duke
parents:
diff changeset
3662 delete ((Mutex*) mon);
a61af66fc99e Initial load
duke
parents:
diff changeset
3663 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3664
a61af66fc99e Initial load
duke
parents:
diff changeset
3665
a61af66fc99e Initial load
duke
parents:
diff changeset
3666 JNIEXPORT jint JNICALL JVM_RawMonitorEnter(void *mon) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3667 VM_Exit::block_if_vm_exited();
a61af66fc99e Initial load
duke
parents:
diff changeset
3668 JVMWrapper("JVM_RawMonitorEnter");
a61af66fc99e Initial load
duke
parents:
diff changeset
3669 ((Mutex*) mon)->jvm_raw_lock();
a61af66fc99e Initial load
duke
parents:
diff changeset
3670 return 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
3671 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3672
a61af66fc99e Initial load
duke
parents:
diff changeset
3673
a61af66fc99e Initial load
duke
parents:
diff changeset
3674 JNIEXPORT void JNICALL JVM_RawMonitorExit(void *mon) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3675 VM_Exit::block_if_vm_exited();
a61af66fc99e Initial load
duke
parents:
diff changeset
3676 JVMWrapper("JVM_RawMonitorExit");
a61af66fc99e Initial load
duke
parents:
diff changeset
3677 ((Mutex*) mon)->jvm_raw_unlock();
a61af66fc99e Initial load
duke
parents:
diff changeset
3678 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3679
a61af66fc99e Initial load
duke
parents:
diff changeset
3680
a61af66fc99e Initial load
duke
parents:
diff changeset
3681 // Support for Serialization
a61af66fc99e Initial load
duke
parents:
diff changeset
3682
a61af66fc99e Initial load
duke
parents:
diff changeset
3683 typedef jfloat (JNICALL *IntBitsToFloatFn )(JNIEnv* env, jclass cb, jint value);
a61af66fc99e Initial load
duke
parents:
diff changeset
3684 typedef jdouble (JNICALL *LongBitsToDoubleFn)(JNIEnv* env, jclass cb, jlong value);
a61af66fc99e Initial load
duke
parents:
diff changeset
3685 typedef jint (JNICALL *FloatToIntBitsFn )(JNIEnv* env, jclass cb, jfloat value);
a61af66fc99e Initial load
duke
parents:
diff changeset
3686 typedef jlong (JNICALL *DoubleToLongBitsFn)(JNIEnv* env, jclass cb, jdouble value);
a61af66fc99e Initial load
duke
parents:
diff changeset
3687
a61af66fc99e Initial load
duke
parents:
diff changeset
3688 static IntBitsToFloatFn int_bits_to_float_fn = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3689 static LongBitsToDoubleFn long_bits_to_double_fn = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3690 static FloatToIntBitsFn float_to_int_bits_fn = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3691 static DoubleToLongBitsFn double_to_long_bits_fn = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
3692
a61af66fc99e Initial load
duke
parents:
diff changeset
3693
a61af66fc99e Initial load
duke
parents:
diff changeset
3694 void initialize_converter_functions() {
a61af66fc99e Initial load
duke
parents:
diff changeset
3695 if (JDK_Version::is_gte_jdk14x_version()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3696 // These functions only exist for compatibility with 1.3.1 and earlier
a61af66fc99e Initial load
duke
parents:
diff changeset
3697 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
3698 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3699
a61af66fc99e Initial load
duke
parents:
diff changeset
3700 // called from universe_post_init()
a61af66fc99e Initial load
duke
parents:
diff changeset
3701 assert(
a61af66fc99e Initial load
duke
parents:
diff changeset
3702 int_bits_to_float_fn == NULL &&
a61af66fc99e Initial load
duke
parents:
diff changeset
3703 long_bits_to_double_fn == NULL &&
a61af66fc99e Initial load
duke
parents:
diff changeset
3704 float_to_int_bits_fn == NULL &&
a61af66fc99e Initial load
duke
parents:
diff changeset
3705 double_to_long_bits_fn == NULL ,
a61af66fc99e Initial load
duke
parents:
diff changeset
3706 "initialization done twice"
a61af66fc99e Initial load
duke
parents:
diff changeset
3707 );
a61af66fc99e Initial load
duke
parents:
diff changeset
3708 // initialize
a61af66fc99e Initial load
duke
parents:
diff changeset
3709 int_bits_to_float_fn = CAST_TO_FN_PTR(IntBitsToFloatFn , NativeLookup::base_library_lookup("java/lang/Float" , "intBitsToFloat" , "(I)F"));
a61af66fc99e Initial load
duke
parents:
diff changeset
3710 long_bits_to_double_fn = CAST_TO_FN_PTR(LongBitsToDoubleFn, NativeLookup::base_library_lookup("java/lang/Double", "longBitsToDouble", "(J)D"));
a61af66fc99e Initial load
duke
parents:
diff changeset
3711 float_to_int_bits_fn = CAST_TO_FN_PTR(FloatToIntBitsFn , NativeLookup::base_library_lookup("java/lang/Float" , "floatToIntBits" , "(F)I"));
a61af66fc99e Initial load
duke
parents:
diff changeset
3712 double_to_long_bits_fn = CAST_TO_FN_PTR(DoubleToLongBitsFn, NativeLookup::base_library_lookup("java/lang/Double", "doubleToLongBits", "(D)J"));
a61af66fc99e Initial load
duke
parents:
diff changeset
3713 // verify
a61af66fc99e Initial load
duke
parents:
diff changeset
3714 assert(
a61af66fc99e Initial load
duke
parents:
diff changeset
3715 int_bits_to_float_fn != NULL &&
a61af66fc99e Initial load
duke
parents:
diff changeset
3716 long_bits_to_double_fn != NULL &&
a61af66fc99e Initial load
duke
parents:
diff changeset
3717 float_to_int_bits_fn != NULL &&
a61af66fc99e Initial load
duke
parents:
diff changeset
3718 double_to_long_bits_fn != NULL ,
a61af66fc99e Initial load
duke
parents:
diff changeset
3719 "initialization failed"
a61af66fc99e Initial load
duke
parents:
diff changeset
3720 );
a61af66fc99e Initial load
duke
parents:
diff changeset
3721 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3722
a61af66fc99e Initial load
duke
parents:
diff changeset
3723
a61af66fc99e Initial load
duke
parents:
diff changeset
3724 // Serialization
a61af66fc99e Initial load
duke
parents:
diff changeset
3725 JVM_ENTRY(void, JVM_SetPrimitiveFieldValues(JNIEnv *env, jclass cb, jobject obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
3726 jlongArray fieldIDs, jcharArray typecodes, jbyteArray data))
a61af66fc99e Initial load
duke
parents:
diff changeset
3727 assert(!JDK_Version::is_gte_jdk14x_version(), "should only be used in 1.3.1 and earlier");
a61af66fc99e Initial load
duke
parents:
diff changeset
3728
a61af66fc99e Initial load
duke
parents:
diff changeset
3729 typeArrayOop tcodes = typeArrayOop(JNIHandles::resolve(typecodes));
a61af66fc99e Initial load
duke
parents:
diff changeset
3730 typeArrayOop dbuf = typeArrayOop(JNIHandles::resolve(data));
a61af66fc99e Initial load
duke
parents:
diff changeset
3731 typeArrayOop fids = typeArrayOop(JNIHandles::resolve(fieldIDs));
a61af66fc99e Initial load
duke
parents:
diff changeset
3732 oop o = JNIHandles::resolve(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
3733
a61af66fc99e Initial load
duke
parents:
diff changeset
3734 if (o == NULL || fids == NULL || dbuf == NULL || tcodes == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3735 THROW(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3736 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3737
a61af66fc99e Initial load
duke
parents:
diff changeset
3738 jsize nfids = fids->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
3739 if (nfids == 0) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
3740
a61af66fc99e Initial load
duke
parents:
diff changeset
3741 if (tcodes->length() < nfids) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3742 THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3743 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3744
a61af66fc99e Initial load
duke
parents:
diff changeset
3745 jsize off = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
3746 /* loop through fields, setting values */
a61af66fc99e Initial load
duke
parents:
diff changeset
3747 for (jsize i = 0; i < nfids; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3748 jfieldID fid = (jfieldID)(intptr_t) fids->long_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
3749 int field_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
3750 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3751 // NULL is a legal value for fid, but retrieving the field offset
a61af66fc99e Initial load
duke
parents:
diff changeset
3752 // trigger assertion in that case
a61af66fc99e Initial load
duke
parents:
diff changeset
3753 field_offset = jfieldIDWorkaround::from_instance_jfieldID(o->klass(), fid);
a61af66fc99e Initial load
duke
parents:
diff changeset
3754 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3755
a61af66fc99e Initial load
duke
parents:
diff changeset
3756 switch (tcodes->char_at(i)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3757 case 'Z':
a61af66fc99e Initial load
duke
parents:
diff changeset
3758 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3759 jboolean val = (dbuf->byte_at(off) != 0) ? JNI_TRUE : JNI_FALSE;
a61af66fc99e Initial load
duke
parents:
diff changeset
3760 o->bool_field_put(field_offset, val);
a61af66fc99e Initial load
duke
parents:
diff changeset
3761 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3762 off++;
a61af66fc99e Initial load
duke
parents:
diff changeset
3763 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3764
a61af66fc99e Initial load
duke
parents:
diff changeset
3765 case 'B':
a61af66fc99e Initial load
duke
parents:
diff changeset
3766 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3767 o->byte_field_put(field_offset, dbuf->byte_at(off));
a61af66fc99e Initial load
duke
parents:
diff changeset
3768 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3769 off++;
a61af66fc99e Initial load
duke
parents:
diff changeset
3770 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3771
a61af66fc99e Initial load
duke
parents:
diff changeset
3772 case 'C':
a61af66fc99e Initial load
duke
parents:
diff changeset
3773 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3774 jchar val = ((dbuf->byte_at(off + 0) & 0xFF) << 8)
a61af66fc99e Initial load
duke
parents:
diff changeset
3775 + ((dbuf->byte_at(off + 1) & 0xFF) << 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3776 o->char_field_put(field_offset, val);
a61af66fc99e Initial load
duke
parents:
diff changeset
3777 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3778 off += 2;
a61af66fc99e Initial load
duke
parents:
diff changeset
3779 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3780
a61af66fc99e Initial load
duke
parents:
diff changeset
3781 case 'S':
a61af66fc99e Initial load
duke
parents:
diff changeset
3782 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3783 jshort val = ((dbuf->byte_at(off + 0) & 0xFF) << 8)
a61af66fc99e Initial load
duke
parents:
diff changeset
3784 + ((dbuf->byte_at(off + 1) & 0xFF) << 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3785 o->short_field_put(field_offset, val);
a61af66fc99e Initial load
duke
parents:
diff changeset
3786 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3787 off += 2;
a61af66fc99e Initial load
duke
parents:
diff changeset
3788 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3789
a61af66fc99e Initial load
duke
parents:
diff changeset
3790 case 'I':
a61af66fc99e Initial load
duke
parents:
diff changeset
3791 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3792 jint ival = ((dbuf->byte_at(off + 0) & 0xFF) << 24)
a61af66fc99e Initial load
duke
parents:
diff changeset
3793 + ((dbuf->byte_at(off + 1) & 0xFF) << 16)
a61af66fc99e Initial load
duke
parents:
diff changeset
3794 + ((dbuf->byte_at(off + 2) & 0xFF) << 8)
a61af66fc99e Initial load
duke
parents:
diff changeset
3795 + ((dbuf->byte_at(off + 3) & 0xFF) << 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3796 o->int_field_put(field_offset, ival);
a61af66fc99e Initial load
duke
parents:
diff changeset
3797 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3798 off += 4;
a61af66fc99e Initial load
duke
parents:
diff changeset
3799 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3800
a61af66fc99e Initial load
duke
parents:
diff changeset
3801 case 'F':
a61af66fc99e Initial load
duke
parents:
diff changeset
3802 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3803 jint ival = ((dbuf->byte_at(off + 0) & 0xFF) << 24)
a61af66fc99e Initial load
duke
parents:
diff changeset
3804 + ((dbuf->byte_at(off + 1) & 0xFF) << 16)
a61af66fc99e Initial load
duke
parents:
diff changeset
3805 + ((dbuf->byte_at(off + 2) & 0xFF) << 8)
a61af66fc99e Initial load
duke
parents:
diff changeset
3806 + ((dbuf->byte_at(off + 3) & 0xFF) << 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3807 jfloat fval = (*int_bits_to_float_fn)(env, NULL, ival);
a61af66fc99e Initial load
duke
parents:
diff changeset
3808 o->float_field_put(field_offset, fval);
a61af66fc99e Initial load
duke
parents:
diff changeset
3809 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3810 off += 4;
a61af66fc99e Initial load
duke
parents:
diff changeset
3811 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3812
a61af66fc99e Initial load
duke
parents:
diff changeset
3813 case 'J':
a61af66fc99e Initial load
duke
parents:
diff changeset
3814 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3815 jlong lval = (((jlong) dbuf->byte_at(off + 0) & 0xFF) << 56)
a61af66fc99e Initial load
duke
parents:
diff changeset
3816 + (((jlong) dbuf->byte_at(off + 1) & 0xFF) << 48)
a61af66fc99e Initial load
duke
parents:
diff changeset
3817 + (((jlong) dbuf->byte_at(off + 2) & 0xFF) << 40)
a61af66fc99e Initial load
duke
parents:
diff changeset
3818 + (((jlong) dbuf->byte_at(off + 3) & 0xFF) << 32)
a61af66fc99e Initial load
duke
parents:
diff changeset
3819 + (((jlong) dbuf->byte_at(off + 4) & 0xFF) << 24)
a61af66fc99e Initial load
duke
parents:
diff changeset
3820 + (((jlong) dbuf->byte_at(off + 5) & 0xFF) << 16)
a61af66fc99e Initial load
duke
parents:
diff changeset
3821 + (((jlong) dbuf->byte_at(off + 6) & 0xFF) << 8)
a61af66fc99e Initial load
duke
parents:
diff changeset
3822 + (((jlong) dbuf->byte_at(off + 7) & 0xFF) << 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3823 o->long_field_put(field_offset, lval);
a61af66fc99e Initial load
duke
parents:
diff changeset
3824 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3825 off += 8;
a61af66fc99e Initial load
duke
parents:
diff changeset
3826 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3827
a61af66fc99e Initial load
duke
parents:
diff changeset
3828 case 'D':
a61af66fc99e Initial load
duke
parents:
diff changeset
3829 if (fid != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3830 jlong lval = (((jlong) dbuf->byte_at(off + 0) & 0xFF) << 56)
a61af66fc99e Initial load
duke
parents:
diff changeset
3831 + (((jlong) dbuf->byte_at(off + 1) & 0xFF) << 48)
a61af66fc99e Initial load
duke
parents:
diff changeset
3832 + (((jlong) dbuf->byte_at(off + 2) & 0xFF) << 40)
a61af66fc99e Initial load
duke
parents:
diff changeset
3833 + (((jlong) dbuf->byte_at(off + 3) & 0xFF) << 32)
a61af66fc99e Initial load
duke
parents:
diff changeset
3834 + (((jlong) dbuf->byte_at(off + 4) & 0xFF) << 24)
a61af66fc99e Initial load
duke
parents:
diff changeset
3835 + (((jlong) dbuf->byte_at(off + 5) & 0xFF) << 16)
a61af66fc99e Initial load
duke
parents:
diff changeset
3836 + (((jlong) dbuf->byte_at(off + 6) & 0xFF) << 8)
a61af66fc99e Initial load
duke
parents:
diff changeset
3837 + (((jlong) dbuf->byte_at(off + 7) & 0xFF) << 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3838 jdouble dval = (*long_bits_to_double_fn)(env, NULL, lval);
a61af66fc99e Initial load
duke
parents:
diff changeset
3839 o->double_field_put(field_offset, dval);
a61af66fc99e Initial load
duke
parents:
diff changeset
3840 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3841 off += 8;
a61af66fc99e Initial load
duke
parents:
diff changeset
3842 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3843
a61af66fc99e Initial load
duke
parents:
diff changeset
3844 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
3845 // Illegal typecode
a61af66fc99e Initial load
duke
parents:
diff changeset
3846 THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), "illegal typecode");
a61af66fc99e Initial load
duke
parents:
diff changeset
3847 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3848 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3849 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3850
a61af66fc99e Initial load
duke
parents:
diff changeset
3851
a61af66fc99e Initial load
duke
parents:
diff changeset
3852 JVM_ENTRY(void, JVM_GetPrimitiveFieldValues(JNIEnv *env, jclass cb, jobject obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
3853 jlongArray fieldIDs, jcharArray typecodes, jbyteArray data))
a61af66fc99e Initial load
duke
parents:
diff changeset
3854 assert(!JDK_Version::is_gte_jdk14x_version(), "should only be used in 1.3.1 and earlier");
a61af66fc99e Initial load
duke
parents:
diff changeset
3855
a61af66fc99e Initial load
duke
parents:
diff changeset
3856 typeArrayOop tcodes = typeArrayOop(JNIHandles::resolve(typecodes));
a61af66fc99e Initial load
duke
parents:
diff changeset
3857 typeArrayOop dbuf = typeArrayOop(JNIHandles::resolve(data));
a61af66fc99e Initial load
duke
parents:
diff changeset
3858 typeArrayOop fids = typeArrayOop(JNIHandles::resolve(fieldIDs));
a61af66fc99e Initial load
duke
parents:
diff changeset
3859 oop o = JNIHandles::resolve(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
3860
a61af66fc99e Initial load
duke
parents:
diff changeset
3861 if (o == NULL || fids == NULL || dbuf == NULL || tcodes == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3862 THROW(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3863 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3864
a61af66fc99e Initial load
duke
parents:
diff changeset
3865 jsize nfids = fids->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
3866 if (nfids == 0) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
3867
a61af66fc99e Initial load
duke
parents:
diff changeset
3868 if (tcodes->length() < nfids) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3869 THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3870 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3871
a61af66fc99e Initial load
duke
parents:
diff changeset
3872 /* loop through fields, fetching values */
a61af66fc99e Initial load
duke
parents:
diff changeset
3873 jsize off = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
3874 for (jsize i = 0; i < nfids; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3875 jfieldID fid = (jfieldID)(intptr_t) fids->long_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
3876 if (fid == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3877 THROW(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
3878 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3879 int field_offset = jfieldIDWorkaround::from_instance_jfieldID(o->klass(), fid);
a61af66fc99e Initial load
duke
parents:
diff changeset
3880
a61af66fc99e Initial load
duke
parents:
diff changeset
3881 switch (tcodes->char_at(i)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3882 case 'Z':
a61af66fc99e Initial load
duke
parents:
diff changeset
3883 {
a61af66fc99e Initial load
duke
parents:
diff changeset
3884 jboolean val = o->bool_field(field_offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
3885 dbuf->byte_at_put(off++, (val != 0) ? 1 : 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
3886 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3887 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3888
a61af66fc99e Initial load
duke
parents:
diff changeset
3889 case 'B':
a61af66fc99e Initial load
duke
parents:
diff changeset
3890 dbuf->byte_at_put(off++, o->byte_field(field_offset));
a61af66fc99e Initial load
duke
parents:
diff changeset
3891 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3892
a61af66fc99e Initial load
duke
parents:
diff changeset
3893 case 'C':
a61af66fc99e Initial load
duke
parents:
diff changeset
3894 {
a61af66fc99e Initial load
duke
parents:
diff changeset
3895 jchar val = o->char_field(field_offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
3896 dbuf->byte_at_put(off++, (val >> 8) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3897 dbuf->byte_at_put(off++, (val >> 0) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3898 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3899 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3900
a61af66fc99e Initial load
duke
parents:
diff changeset
3901 case 'S':
a61af66fc99e Initial load
duke
parents:
diff changeset
3902 {
a61af66fc99e Initial load
duke
parents:
diff changeset
3903 jshort val = o->short_field(field_offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
3904 dbuf->byte_at_put(off++, (val >> 8) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3905 dbuf->byte_at_put(off++, (val >> 0) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3906 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3907 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3908
a61af66fc99e Initial load
duke
parents:
diff changeset
3909 case 'I':
a61af66fc99e Initial load
duke
parents:
diff changeset
3910 {
a61af66fc99e Initial load
duke
parents:
diff changeset
3911 jint val = o->int_field(field_offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
3912 dbuf->byte_at_put(off++, (val >> 24) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3913 dbuf->byte_at_put(off++, (val >> 16) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3914 dbuf->byte_at_put(off++, (val >> 8) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3915 dbuf->byte_at_put(off++, (val >> 0) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3916 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3917 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3918
a61af66fc99e Initial load
duke
parents:
diff changeset
3919 case 'F':
a61af66fc99e Initial load
duke
parents:
diff changeset
3920 {
a61af66fc99e Initial load
duke
parents:
diff changeset
3921 jfloat fval = o->float_field(field_offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
3922 jint ival = (*float_to_int_bits_fn)(env, NULL, fval);
a61af66fc99e Initial load
duke
parents:
diff changeset
3923 dbuf->byte_at_put(off++, (ival >> 24) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3924 dbuf->byte_at_put(off++, (ival >> 16) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3925 dbuf->byte_at_put(off++, (ival >> 8) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3926 dbuf->byte_at_put(off++, (ival >> 0) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3927 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3928 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3929
a61af66fc99e Initial load
duke
parents:
diff changeset
3930 case 'J':
a61af66fc99e Initial load
duke
parents:
diff changeset
3931 {
a61af66fc99e Initial load
duke
parents:
diff changeset
3932 jlong val = o->long_field(field_offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
3933 dbuf->byte_at_put(off++, (val >> 56) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3934 dbuf->byte_at_put(off++, (val >> 48) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3935 dbuf->byte_at_put(off++, (val >> 40) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3936 dbuf->byte_at_put(off++, (val >> 32) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3937 dbuf->byte_at_put(off++, (val >> 24) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3938 dbuf->byte_at_put(off++, (val >> 16) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3939 dbuf->byte_at_put(off++, (val >> 8) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3940 dbuf->byte_at_put(off++, (val >> 0) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3941 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3942 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3943
a61af66fc99e Initial load
duke
parents:
diff changeset
3944 case 'D':
a61af66fc99e Initial load
duke
parents:
diff changeset
3945 {
a61af66fc99e Initial load
duke
parents:
diff changeset
3946 jdouble dval = o->double_field(field_offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
3947 jlong lval = (*double_to_long_bits_fn)(env, NULL, dval);
a61af66fc99e Initial load
duke
parents:
diff changeset
3948 dbuf->byte_at_put(off++, (lval >> 56) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3949 dbuf->byte_at_put(off++, (lval >> 48) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3950 dbuf->byte_at_put(off++, (lval >> 40) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3951 dbuf->byte_at_put(off++, (lval >> 32) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3952 dbuf->byte_at_put(off++, (lval >> 24) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3953 dbuf->byte_at_put(off++, (lval >> 16) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3954 dbuf->byte_at_put(off++, (lval >> 8) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3955 dbuf->byte_at_put(off++, (lval >> 0) & 0xFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
3956 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3957 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3958
a61af66fc99e Initial load
duke
parents:
diff changeset
3959 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
3960 // Illegal typecode
a61af66fc99e Initial load
duke
parents:
diff changeset
3961 THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), "illegal typecode");
a61af66fc99e Initial load
duke
parents:
diff changeset
3962 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3963 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3964 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3965
a61af66fc99e Initial load
duke
parents:
diff changeset
3966
a61af66fc99e Initial load
duke
parents:
diff changeset
3967 // Shared JNI/JVM entry points //////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3968
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
3969 jclass find_class_from_class_loader(JNIEnv* env, Symbol* name, jboolean init, Handle loader, Handle protection_domain, jboolean throwError, TRAPS) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3970 // Security Note:
a61af66fc99e Initial load
duke
parents:
diff changeset
3971 // The Java level wrapper will perform the necessary security check allowing
a61af66fc99e Initial load
duke
parents:
diff changeset
3972 // us to pass the NULL as the initiating class loader.
a61af66fc99e Initial load
duke
parents:
diff changeset
3973 klassOop klass = SystemDictionary::resolve_or_fail(name, loader, protection_domain, throwError != 0, CHECK_NULL);
878
abe076e3636f 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 875
diff changeset
3974
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3975 KlassHandle klass_handle(THREAD, klass);
a61af66fc99e Initial load
duke
parents:
diff changeset
3976 // Check if we should initialize the class
a61af66fc99e Initial load
duke
parents:
diff changeset
3977 if (init && klass_handle->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3978 klass_handle->initialize(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3979 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3980 return (jclass) JNIHandles::make_local(env, klass_handle->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
3981 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3982
a61af66fc99e Initial load
duke
parents:
diff changeset
3983
a61af66fc99e Initial load
duke
parents:
diff changeset
3984 // Internal SQE debugging support ///////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
3985
a61af66fc99e Initial load
duke
parents:
diff changeset
3986 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
3987
a61af66fc99e Initial load
duke
parents:
diff changeset
3988 extern "C" {
a61af66fc99e Initial load
duke
parents:
diff changeset
3989 JNIEXPORT jboolean JNICALL JVM_AccessVMBooleanFlag(const char* name, jboolean* value, jboolean is_get);
a61af66fc99e Initial load
duke
parents:
diff changeset
3990 JNIEXPORT jboolean JNICALL JVM_AccessVMIntFlag(const char* name, jint* value, jboolean is_get);
a61af66fc99e Initial load
duke
parents:
diff changeset
3991 JNIEXPORT void JNICALL JVM_VMBreakPoint(JNIEnv *env, jobject obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
3992 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3993
a61af66fc99e Initial load
duke
parents:
diff changeset
3994 JVM_LEAF(jboolean, JVM_AccessVMBooleanFlag(const char* name, jboolean* value, jboolean is_get))
a61af66fc99e Initial load
duke
parents:
diff changeset
3995 JVMWrapper("JVM_AccessBoolVMFlag");
a61af66fc99e Initial load
duke
parents:
diff changeset
3996 return is_get ? CommandLineFlags::boolAt((char*) name, (bool*) value) : CommandLineFlags::boolAtPut((char*) name, (bool*) value, INTERNAL);
a61af66fc99e Initial load
duke
parents:
diff changeset
3997 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
3998
a61af66fc99e Initial load
duke
parents:
diff changeset
3999 JVM_LEAF(jboolean, JVM_AccessVMIntFlag(const char* name, jint* value, jboolean is_get))
a61af66fc99e Initial load
duke
parents:
diff changeset
4000 JVMWrapper("JVM_AccessVMIntFlag");
a61af66fc99e Initial load
duke
parents:
diff changeset
4001 intx v;
a61af66fc99e Initial load
duke
parents:
diff changeset
4002 jboolean result = is_get ? CommandLineFlags::intxAt((char*) name, &v) : CommandLineFlags::intxAtPut((char*) name, &v, INTERNAL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4003 *value = (jint)v;
a61af66fc99e Initial load
duke
parents:
diff changeset
4004 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
4005 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4006
a61af66fc99e Initial load
duke
parents:
diff changeset
4007
a61af66fc99e Initial load
duke
parents:
diff changeset
4008 JVM_ENTRY(void, JVM_VMBreakPoint(JNIEnv *env, jobject obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
4009 JVMWrapper("JVM_VMBreakPoint");
a61af66fc99e Initial load
duke
parents:
diff changeset
4010 oop the_obj = JNIHandles::resolve(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
4011 BREAKPOINT;
a61af66fc99e Initial load
duke
parents:
diff changeset
4012 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4013
a61af66fc99e Initial load
duke
parents:
diff changeset
4014
a61af66fc99e Initial load
duke
parents:
diff changeset
4015 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
4016
a61af66fc99e Initial load
duke
parents:
diff changeset
4017
a61af66fc99e Initial load
duke
parents:
diff changeset
4018 // Method ///////////////////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
4019
a61af66fc99e Initial load
duke
parents:
diff changeset
4020 JVM_ENTRY(jobject, JVM_InvokeMethod(JNIEnv *env, jobject method, jobject obj, jobjectArray args0))
a61af66fc99e Initial load
duke
parents:
diff changeset
4021 JVMWrapper("JVM_InvokeMethod");
a61af66fc99e Initial load
duke
parents:
diff changeset
4022 Handle method_handle;
a61af66fc99e Initial load
duke
parents:
diff changeset
4023 if (thread->stack_available((address) &method_handle) >= JVMInvokeMethodSlack) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4024 method_handle = Handle(THREAD, JNIHandles::resolve(method));
a61af66fc99e Initial load
duke
parents:
diff changeset
4025 Handle receiver(THREAD, JNIHandles::resolve(obj));
a61af66fc99e Initial load
duke
parents:
diff changeset
4026 objArrayHandle args(THREAD, objArrayOop(JNIHandles::resolve(args0)));
a61af66fc99e Initial load
duke
parents:
diff changeset
4027 oop result = Reflection::invoke_method(method_handle(), receiver, args, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4028 jobject res = JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
4029 if (JvmtiExport::should_post_vm_object_alloc()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4030 oop ret_type = java_lang_reflect_Method::return_type(method_handle());
a61af66fc99e Initial load
duke
parents:
diff changeset
4031 assert(ret_type != NULL, "sanity check: ret_type oop must not be NULL!");
a61af66fc99e Initial load
duke
parents:
diff changeset
4032 if (java_lang_Class::is_primitive(ret_type)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4033 // Only for primitive type vm allocates memory for java object.
a61af66fc99e Initial load
duke
parents:
diff changeset
4034 // See box() method.
a61af66fc99e Initial load
duke
parents:
diff changeset
4035 JvmtiExport::post_vm_object_alloc(JavaThread::current(), result);
a61af66fc99e Initial load
duke
parents:
diff changeset
4036 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4037 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4038 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
4039 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
4040 THROW_0(vmSymbols::java_lang_StackOverflowError());
a61af66fc99e Initial load
duke
parents:
diff changeset
4041 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4042 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4043
a61af66fc99e Initial load
duke
parents:
diff changeset
4044
a61af66fc99e Initial load
duke
parents:
diff changeset
4045 JVM_ENTRY(jobject, JVM_NewInstanceFromConstructor(JNIEnv *env, jobject c, jobjectArray args0))
a61af66fc99e Initial load
duke
parents:
diff changeset
4046 JVMWrapper("JVM_NewInstanceFromConstructor");
a61af66fc99e Initial load
duke
parents:
diff changeset
4047 oop constructor_mirror = JNIHandles::resolve(c);
a61af66fc99e Initial load
duke
parents:
diff changeset
4048 objArrayHandle args(THREAD, objArrayOop(JNIHandles::resolve(args0)));
a61af66fc99e Initial load
duke
parents:
diff changeset
4049 oop result = Reflection::invoke_constructor(constructor_mirror, args, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4050 jobject res = JNIHandles::make_local(env, result);
a61af66fc99e Initial load
duke
parents:
diff changeset
4051 if (JvmtiExport::should_post_vm_object_alloc()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4052 JvmtiExport::post_vm_object_alloc(JavaThread::current(), result);
a61af66fc99e Initial load
duke
parents:
diff changeset
4053 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4054 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
4055 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4056
a61af66fc99e Initial load
duke
parents:
diff changeset
4057 // Atomic ///////////////////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
4058
a61af66fc99e Initial load
duke
parents:
diff changeset
4059 JVM_LEAF(jboolean, JVM_SupportsCX8())
a61af66fc99e Initial load
duke
parents:
diff changeset
4060 JVMWrapper("JVM_SupportsCX8");
a61af66fc99e Initial load
duke
parents:
diff changeset
4061 return VM_Version::supports_cx8();
a61af66fc99e Initial load
duke
parents:
diff changeset
4062 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4063
a61af66fc99e Initial load
duke
parents:
diff changeset
4064
a61af66fc99e Initial load
duke
parents:
diff changeset
4065 JVM_ENTRY(jboolean, JVM_CX8Field(JNIEnv *env, jobject obj, jfieldID fid, jlong oldVal, jlong newVal))
a61af66fc99e Initial load
duke
parents:
diff changeset
4066 JVMWrapper("JVM_CX8Field");
a61af66fc99e Initial load
duke
parents:
diff changeset
4067 jlong res;
a61af66fc99e Initial load
duke
parents:
diff changeset
4068 oop o = JNIHandles::resolve(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
4069 intptr_t fldOffs = jfieldIDWorkaround::from_instance_jfieldID(o->klass(), fid);
a61af66fc99e Initial load
duke
parents:
diff changeset
4070 volatile jlong* addr = (volatile jlong*)((address)o + fldOffs);
a61af66fc99e Initial load
duke
parents:
diff changeset
4071
a61af66fc99e Initial load
duke
parents:
diff changeset
4072 assert(VM_Version::supports_cx8(), "cx8 not supported");
a61af66fc99e Initial load
duke
parents:
diff changeset
4073 res = Atomic::cmpxchg(newVal, addr, oldVal);
a61af66fc99e Initial load
duke
parents:
diff changeset
4074
a61af66fc99e Initial load
duke
parents:
diff changeset
4075 return res == oldVal;
a61af66fc99e Initial load
duke
parents:
diff changeset
4076 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4077
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4078 // DTrace ///////////////////////////////////////////////////////////////////
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4079
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4080 JVM_ENTRY(jint, JVM_DTraceGetVersion(JNIEnv* env))
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4081 JVMWrapper("JVM_DTraceGetVersion");
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4082 return (jint)JVM_TRACING_DTRACE_VERSION;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4083 JVM_END
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4084
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4085 JVM_ENTRY(jlong,JVM_DTraceActivate(
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4086 JNIEnv* env, jint version, jstring module_name, jint providers_count,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4087 JVM_DTraceProvider* providers))
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4088 JVMWrapper("JVM_DTraceActivate");
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4089 return DTraceJSDT::activate(
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4090 version, module_name, providers_count, providers, CHECK_0);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4091 JVM_END
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4092
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4093 JVM_ENTRY(jboolean,JVM_DTraceIsProbeEnabled(JNIEnv* env, jmethodID method))
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4094 JVMWrapper("JVM_DTraceIsProbeEnabled");
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4095 return DTraceJSDT::is_probe_enabled(method);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4096 JVM_END
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4097
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4098 JVM_ENTRY(void,JVM_DTraceDispose(JNIEnv* env, jlong handle))
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4099 JVMWrapper("JVM_DTraceDispose");
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4100 DTraceJSDT::dispose(handle);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4101 JVM_END
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4102
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4103 JVM_ENTRY(jboolean,JVM_DTraceIsSupported(JNIEnv* env))
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4104 JVMWrapper("JVM_DTraceIsSupported");
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4105 return DTraceJSDT::is_supported();
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4106 JVM_END
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 0
diff changeset
4107
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4108 // Returns an array of all live Thread objects (VM internal JavaThreads,
a61af66fc99e Initial load
duke
parents:
diff changeset
4109 // jvmti agent threads, and JNI attaching threads are skipped)
a61af66fc99e Initial load
duke
parents:
diff changeset
4110 // See CR 6404306 regarding JNI attaching threads
a61af66fc99e Initial load
duke
parents:
diff changeset
4111 JVM_ENTRY(jobjectArray, JVM_GetAllThreads(JNIEnv *env, jclass dummy))
a61af66fc99e Initial load
duke
parents:
diff changeset
4112 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
4113 ThreadsListEnumerator tle(THREAD, false, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
4114 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
4115
a61af66fc99e Initial load
duke
parents:
diff changeset
4116 int num_threads = tle.num_threads();
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4117 objArrayOop r = oopFactory::new_objArray(SystemDictionary::Thread_klass(), num_threads, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4118 objArrayHandle threads_ah(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4119
a61af66fc99e Initial load
duke
parents:
diff changeset
4120 for (int i = 0; i < num_threads; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4121 Handle h = tle.get_threadObj(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
4122 threads_ah->obj_at_put(i, h());
a61af66fc99e Initial load
duke
parents:
diff changeset
4123 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4124
a61af66fc99e Initial load
duke
parents:
diff changeset
4125 return (jobjectArray) JNIHandles::make_local(env, threads_ah());
a61af66fc99e Initial load
duke
parents:
diff changeset
4126 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4127
a61af66fc99e Initial load
duke
parents:
diff changeset
4128
a61af66fc99e Initial load
duke
parents:
diff changeset
4129 // Support for java.lang.Thread.getStackTrace() and getAllStackTraces() methods
a61af66fc99e Initial load
duke
parents:
diff changeset
4130 // Return StackTraceElement[][], each element is the stack trace of a thread in
a61af66fc99e Initial load
duke
parents:
diff changeset
4131 // the corresponding entry in the given threads array
a61af66fc99e Initial load
duke
parents:
diff changeset
4132 JVM_ENTRY(jobjectArray, JVM_DumpThreads(JNIEnv *env, jclass threadClass, jobjectArray threads))
a61af66fc99e Initial load
duke
parents:
diff changeset
4133 JVMWrapper("JVM_DumpThreads");
a61af66fc99e Initial load
duke
parents:
diff changeset
4134 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
4135
a61af66fc99e Initial load
duke
parents:
diff changeset
4136 // Check if threads is null
a61af66fc99e Initial load
duke
parents:
diff changeset
4137 if (threads == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4138 THROW_(vmSymbols::java_lang_NullPointerException(), 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
4139 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4140
a61af66fc99e Initial load
duke
parents:
diff changeset
4141 objArrayOop a = objArrayOop(JNIHandles::resolve_non_null(threads));
a61af66fc99e Initial load
duke
parents:
diff changeset
4142 objArrayHandle ah(THREAD, a);
a61af66fc99e Initial load
duke
parents:
diff changeset
4143 int num_threads = ah->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
4144 // check if threads is non-empty array
a61af66fc99e Initial load
duke
parents:
diff changeset
4145 if (num_threads == 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4146 THROW_(vmSymbols::java_lang_IllegalArgumentException(), 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
4147 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4148
a61af66fc99e Initial load
duke
parents:
diff changeset
4149 // check if threads is not an array of objects of Thread class
a61af66fc99e Initial load
duke
parents:
diff changeset
4150 klassOop k = objArrayKlass::cast(ah->klass())->element_klass();
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4151 if (k != SystemDictionary::Thread_klass()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4152 THROW_(vmSymbols::java_lang_IllegalArgumentException(), 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
4153 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4154
a61af66fc99e Initial load
duke
parents:
diff changeset
4155 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
4156
a61af66fc99e Initial load
duke
parents:
diff changeset
4157 GrowableArray<instanceHandle>* thread_handle_array = new GrowableArray<instanceHandle>(num_threads);
a61af66fc99e Initial load
duke
parents:
diff changeset
4158 for (int i = 0; i < num_threads; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4159 oop thread_obj = ah->obj_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
4160 instanceHandle h(THREAD, (instanceOop) thread_obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
4161 thread_handle_array->append(h);
a61af66fc99e Initial load
duke
parents:
diff changeset
4162 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4163
a61af66fc99e Initial load
duke
parents:
diff changeset
4164 Handle stacktraces = ThreadService::dump_stack_traces(thread_handle_array, num_threads, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4165 return (jobjectArray)JNIHandles::make_local(env, stacktraces());
a61af66fc99e Initial load
duke
parents:
diff changeset
4166
a61af66fc99e Initial load
duke
parents:
diff changeset
4167 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4168
a61af66fc99e Initial load
duke
parents:
diff changeset
4169 // JVM monitoring and management support
a61af66fc99e Initial load
duke
parents:
diff changeset
4170 JVM_ENTRY_NO_ENV(void*, JVM_GetManagement(jint version))
a61af66fc99e Initial load
duke
parents:
diff changeset
4171 return Management::get_jmm_interface(version);
a61af66fc99e Initial load
duke
parents:
diff changeset
4172 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4173
a61af66fc99e Initial load
duke
parents:
diff changeset
4174 // com.sun.tools.attach.VirtualMachine agent properties support
a61af66fc99e Initial load
duke
parents:
diff changeset
4175 //
a61af66fc99e Initial load
duke
parents:
diff changeset
4176 // Initialize the agent properties with the properties maintained in the VM
a61af66fc99e Initial load
duke
parents:
diff changeset
4177 JVM_ENTRY(jobject, JVM_InitAgentProperties(JNIEnv *env, jobject properties))
a61af66fc99e Initial load
duke
parents:
diff changeset
4178 JVMWrapper("JVM_InitAgentProperties");
a61af66fc99e Initial load
duke
parents:
diff changeset
4179 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
4180
a61af66fc99e Initial load
duke
parents:
diff changeset
4181 Handle props(THREAD, JNIHandles::resolve_non_null(properties));
a61af66fc99e Initial load
duke
parents:
diff changeset
4182
a61af66fc99e Initial load
duke
parents:
diff changeset
4183 PUTPROP(props, "sun.java.command", Arguments::java_command());
a61af66fc99e Initial load
duke
parents:
diff changeset
4184 PUTPROP(props, "sun.jvm.flags", Arguments::jvm_flags());
a61af66fc99e Initial load
duke
parents:
diff changeset
4185 PUTPROP(props, "sun.jvm.args", Arguments::jvm_args());
a61af66fc99e Initial load
duke
parents:
diff changeset
4186 return properties;
a61af66fc99e Initial load
duke
parents:
diff changeset
4187 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4188
a61af66fc99e Initial load
duke
parents:
diff changeset
4189 JVM_ENTRY(jobjectArray, JVM_GetEnclosingMethodInfo(JNIEnv *env, jclass ofClass))
a61af66fc99e Initial load
duke
parents:
diff changeset
4190 {
a61af66fc99e Initial load
duke
parents:
diff changeset
4191 JVMWrapper("JVM_GetEnclosingMethodInfo");
a61af66fc99e Initial load
duke
parents:
diff changeset
4192 JvmtiVMObjectAllocEventCollector oam;
a61af66fc99e Initial load
duke
parents:
diff changeset
4193
a61af66fc99e Initial load
duke
parents:
diff changeset
4194 if (ofClass == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4195 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
4196 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4197 Handle mirror(THREAD, JNIHandles::resolve_non_null(ofClass));
a61af66fc99e Initial load
duke
parents:
diff changeset
4198 // Special handling for primitive objects
a61af66fc99e Initial load
duke
parents:
diff changeset
4199 if (java_lang_Class::is_primitive(mirror())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4200 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
4201 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4202 klassOop k = java_lang_Class::as_klassOop(mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
4203 if (!Klass::cast(k)->oop_is_instance()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4204 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
4205 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4206 instanceKlassHandle ik_h(THREAD, k);
a61af66fc99e Initial load
duke
parents:
diff changeset
4207 int encl_method_class_idx = ik_h->enclosing_method_class_index();
a61af66fc99e Initial load
duke
parents:
diff changeset
4208 if (encl_method_class_idx == 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4209 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
4210 }
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4211 objArrayOop dest_o = oopFactory::new_objArray(SystemDictionary::Object_klass(), 3, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4212 objArrayHandle dest(THREAD, dest_o);
a61af66fc99e Initial load
duke
parents:
diff changeset
4213 klassOop enc_k = ik_h->constants()->klass_at(encl_method_class_idx, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4214 dest->obj_at_put(0, Klass::cast(enc_k)->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
4215 int encl_method_method_idx = ik_h->enclosing_method_method_index();
a61af66fc99e Initial load
duke
parents:
diff changeset
4216 if (encl_method_method_idx != 0) {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
4217 Symbol* sym = ik_h->constants()->symbol_at(
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4218 extract_low_short_from_int(
a61af66fc99e Initial load
duke
parents:
diff changeset
4219 ik_h->constants()->name_and_type_at(encl_method_method_idx)));
a61af66fc99e Initial load
duke
parents:
diff changeset
4220 Handle str = java_lang_String::create_from_symbol(sym, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4221 dest->obj_at_put(1, str());
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2162
diff changeset
4222 sym = ik_h->constants()->symbol_at(
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4223 extract_high_short_from_int(
a61af66fc99e Initial load
duke
parents:
diff changeset
4224 ik_h->constants()->name_and_type_at(encl_method_method_idx)));
a61af66fc99e Initial load
duke
parents:
diff changeset
4225 str = java_lang_String::create_from_symbol(sym, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4226 dest->obj_at_put(2, str());
a61af66fc99e Initial load
duke
parents:
diff changeset
4227 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4228 return (jobjectArray) JNIHandles::make_local(dest());
a61af66fc99e Initial load
duke
parents:
diff changeset
4229 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4230 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4231
a61af66fc99e Initial load
duke
parents:
diff changeset
4232 JVM_ENTRY(jintArray, JVM_GetThreadStateValues(JNIEnv* env,
a61af66fc99e Initial load
duke
parents:
diff changeset
4233 jint javaThreadState))
a61af66fc99e Initial load
duke
parents:
diff changeset
4234 {
a61af66fc99e Initial load
duke
parents:
diff changeset
4235 // If new thread states are added in future JDK and VM versions,
a61af66fc99e Initial load
duke
parents:
diff changeset
4236 // this should check if the JDK version is compatible with thread
a61af66fc99e Initial load
duke
parents:
diff changeset
4237 // states supported by the VM. Return NULL if not compatible.
a61af66fc99e Initial load
duke
parents:
diff changeset
4238 //
a61af66fc99e Initial load
duke
parents:
diff changeset
4239 // This function must map the VM java_lang_Thread::ThreadStatus
a61af66fc99e Initial load
duke
parents:
diff changeset
4240 // to the Java thread state that the JDK supports.
a61af66fc99e Initial load
duke
parents:
diff changeset
4241 //
a61af66fc99e Initial load
duke
parents:
diff changeset
4242
a61af66fc99e Initial load
duke
parents:
diff changeset
4243 typeArrayHandle values_h;
a61af66fc99e Initial load
duke
parents:
diff changeset
4244 switch (javaThreadState) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4245 case JAVA_THREAD_STATE_NEW : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4246 typeArrayOop r = oopFactory::new_typeArray(T_INT, 1, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4247 values_h = typeArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4248 values_h->int_at_put(0, java_lang_Thread::NEW);
a61af66fc99e Initial load
duke
parents:
diff changeset
4249 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4250 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4251 case JAVA_THREAD_STATE_RUNNABLE : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4252 typeArrayOop r = oopFactory::new_typeArray(T_INT, 1, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4253 values_h = typeArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4254 values_h->int_at_put(0, java_lang_Thread::RUNNABLE);
a61af66fc99e Initial load
duke
parents:
diff changeset
4255 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4256 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4257 case JAVA_THREAD_STATE_BLOCKED : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4258 typeArrayOop r = oopFactory::new_typeArray(T_INT, 1, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4259 values_h = typeArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4260 values_h->int_at_put(0, java_lang_Thread::BLOCKED_ON_MONITOR_ENTER);
a61af66fc99e Initial load
duke
parents:
diff changeset
4261 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4262 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4263 case JAVA_THREAD_STATE_WAITING : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4264 typeArrayOop r = oopFactory::new_typeArray(T_INT, 2, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4265 values_h = typeArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4266 values_h->int_at_put(0, java_lang_Thread::IN_OBJECT_WAIT);
a61af66fc99e Initial load
duke
parents:
diff changeset
4267 values_h->int_at_put(1, java_lang_Thread::PARKED);
a61af66fc99e Initial load
duke
parents:
diff changeset
4268 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4269 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4270 case JAVA_THREAD_STATE_TIMED_WAITING : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4271 typeArrayOop r = oopFactory::new_typeArray(T_INT, 3, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4272 values_h = typeArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4273 values_h->int_at_put(0, java_lang_Thread::SLEEPING);
a61af66fc99e Initial load
duke
parents:
diff changeset
4274 values_h->int_at_put(1, java_lang_Thread::IN_OBJECT_WAIT_TIMED);
a61af66fc99e Initial load
duke
parents:
diff changeset
4275 values_h->int_at_put(2, java_lang_Thread::PARKED_TIMED);
a61af66fc99e Initial load
duke
parents:
diff changeset
4276 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4277 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4278 case JAVA_THREAD_STATE_TERMINATED : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4279 typeArrayOop r = oopFactory::new_typeArray(T_INT, 1, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4280 values_h = typeArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4281 values_h->int_at_put(0, java_lang_Thread::TERMINATED);
a61af66fc99e Initial load
duke
parents:
diff changeset
4282 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4283 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4284 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
4285 // Unknown state - probably incompatible JDK version
a61af66fc99e Initial load
duke
parents:
diff changeset
4286 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
4287 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4288
a61af66fc99e Initial load
duke
parents:
diff changeset
4289 return (jintArray) JNIHandles::make_local(env, values_h());
a61af66fc99e Initial load
duke
parents:
diff changeset
4290 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4291 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4292
a61af66fc99e Initial load
duke
parents:
diff changeset
4293
a61af66fc99e Initial load
duke
parents:
diff changeset
4294 JVM_ENTRY(jobjectArray, JVM_GetThreadStateNames(JNIEnv* env,
a61af66fc99e Initial load
duke
parents:
diff changeset
4295 jint javaThreadState,
a61af66fc99e Initial load
duke
parents:
diff changeset
4296 jintArray values))
a61af66fc99e Initial load
duke
parents:
diff changeset
4297 {
a61af66fc99e Initial load
duke
parents:
diff changeset
4298 // If new thread states are added in future JDK and VM versions,
a61af66fc99e Initial load
duke
parents:
diff changeset
4299 // this should check if the JDK version is compatible with thread
a61af66fc99e Initial load
duke
parents:
diff changeset
4300 // states supported by the VM. Return NULL if not compatible.
a61af66fc99e Initial load
duke
parents:
diff changeset
4301 //
a61af66fc99e Initial load
duke
parents:
diff changeset
4302 // This function must map the VM java_lang_Thread::ThreadStatus
a61af66fc99e Initial load
duke
parents:
diff changeset
4303 // to the Java thread state that the JDK supports.
a61af66fc99e Initial load
duke
parents:
diff changeset
4304 //
a61af66fc99e Initial load
duke
parents:
diff changeset
4305
a61af66fc99e Initial load
duke
parents:
diff changeset
4306 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
4307
a61af66fc99e Initial load
duke
parents:
diff changeset
4308 // Check if threads is null
a61af66fc99e Initial load
duke
parents:
diff changeset
4309 if (values == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4310 THROW_(vmSymbols::java_lang_NullPointerException(), 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
4311 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4312
a61af66fc99e Initial load
duke
parents:
diff changeset
4313 typeArrayOop v = typeArrayOop(JNIHandles::resolve_non_null(values));
a61af66fc99e Initial load
duke
parents:
diff changeset
4314 typeArrayHandle values_h(THREAD, v);
a61af66fc99e Initial load
duke
parents:
diff changeset
4315
a61af66fc99e Initial load
duke
parents:
diff changeset
4316 objArrayHandle names_h;
a61af66fc99e Initial load
duke
parents:
diff changeset
4317 switch (javaThreadState) {
a61af66fc99e Initial load
duke
parents:
diff changeset
4318 case JAVA_THREAD_STATE_NEW : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4319 assert(values_h->length() == 1 &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4320 values_h->int_at(0) == java_lang_Thread::NEW,
a61af66fc99e Initial load
duke
parents:
diff changeset
4321 "Invalid threadStatus value");
a61af66fc99e Initial load
duke
parents:
diff changeset
4322
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4323 objArrayOop r = oopFactory::new_objArray(SystemDictionary::String_klass(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4324 1, /* only 1 substate */
a61af66fc99e Initial load
duke
parents:
diff changeset
4325 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4326 names_h = objArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4327 Handle name = java_lang_String::create_from_str("NEW", CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4328 names_h->obj_at_put(0, name());
a61af66fc99e Initial load
duke
parents:
diff changeset
4329 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4330 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4331 case JAVA_THREAD_STATE_RUNNABLE : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4332 assert(values_h->length() == 1 &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4333 values_h->int_at(0) == java_lang_Thread::RUNNABLE,
a61af66fc99e Initial load
duke
parents:
diff changeset
4334 "Invalid threadStatus value");
a61af66fc99e Initial load
duke
parents:
diff changeset
4335
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4336 objArrayOop r = oopFactory::new_objArray(SystemDictionary::String_klass(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4337 1, /* only 1 substate */
a61af66fc99e Initial load
duke
parents:
diff changeset
4338 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4339 names_h = objArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4340 Handle name = java_lang_String::create_from_str("RUNNABLE", CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4341 names_h->obj_at_put(0, name());
a61af66fc99e Initial load
duke
parents:
diff changeset
4342 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4343 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4344 case JAVA_THREAD_STATE_BLOCKED : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4345 assert(values_h->length() == 1 &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4346 values_h->int_at(0) == java_lang_Thread::BLOCKED_ON_MONITOR_ENTER,
a61af66fc99e Initial load
duke
parents:
diff changeset
4347 "Invalid threadStatus value");
a61af66fc99e Initial load
duke
parents:
diff changeset
4348
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4349 objArrayOop r = oopFactory::new_objArray(SystemDictionary::String_klass(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4350 1, /* only 1 substate */
a61af66fc99e Initial load
duke
parents:
diff changeset
4351 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4352 names_h = objArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4353 Handle name = java_lang_String::create_from_str("BLOCKED", CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4354 names_h->obj_at_put(0, name());
a61af66fc99e Initial load
duke
parents:
diff changeset
4355 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4356 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4357 case JAVA_THREAD_STATE_WAITING : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4358 assert(values_h->length() == 2 &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4359 values_h->int_at(0) == java_lang_Thread::IN_OBJECT_WAIT &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4360 values_h->int_at(1) == java_lang_Thread::PARKED,
a61af66fc99e Initial load
duke
parents:
diff changeset
4361 "Invalid threadStatus value");
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4362 objArrayOop r = oopFactory::new_objArray(SystemDictionary::String_klass(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4363 2, /* number of substates */
a61af66fc99e Initial load
duke
parents:
diff changeset
4364 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4365 names_h = objArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4366 Handle name0 = java_lang_String::create_from_str("WAITING.OBJECT_WAIT",
a61af66fc99e Initial load
duke
parents:
diff changeset
4367 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4368 Handle name1 = java_lang_String::create_from_str("WAITING.PARKED",
a61af66fc99e Initial load
duke
parents:
diff changeset
4369 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4370 names_h->obj_at_put(0, name0());
a61af66fc99e Initial load
duke
parents:
diff changeset
4371 names_h->obj_at_put(1, name1());
a61af66fc99e Initial load
duke
parents:
diff changeset
4372 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4373 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4374 case JAVA_THREAD_STATE_TIMED_WAITING : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4375 assert(values_h->length() == 3 &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4376 values_h->int_at(0) == java_lang_Thread::SLEEPING &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4377 values_h->int_at(1) == java_lang_Thread::IN_OBJECT_WAIT_TIMED &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4378 values_h->int_at(2) == java_lang_Thread::PARKED_TIMED,
a61af66fc99e Initial load
duke
parents:
diff changeset
4379 "Invalid threadStatus value");
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4380 objArrayOop r = oopFactory::new_objArray(SystemDictionary::String_klass(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4381 3, /* number of substates */
a61af66fc99e Initial load
duke
parents:
diff changeset
4382 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4383 names_h = objArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4384 Handle name0 = java_lang_String::create_from_str("TIMED_WAITING.SLEEPING",
a61af66fc99e Initial load
duke
parents:
diff changeset
4385 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4386 Handle name1 = java_lang_String::create_from_str("TIMED_WAITING.OBJECT_WAIT",
a61af66fc99e Initial load
duke
parents:
diff changeset
4387 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4388 Handle name2 = java_lang_String::create_from_str("TIMED_WAITING.PARKED",
a61af66fc99e Initial load
duke
parents:
diff changeset
4389 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4390 names_h->obj_at_put(0, name0());
a61af66fc99e Initial load
duke
parents:
diff changeset
4391 names_h->obj_at_put(1, name1());
a61af66fc99e Initial load
duke
parents:
diff changeset
4392 names_h->obj_at_put(2, name2());
a61af66fc99e Initial load
duke
parents:
diff changeset
4393 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4394 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4395 case JAVA_THREAD_STATE_TERMINATED : {
a61af66fc99e Initial load
duke
parents:
diff changeset
4396 assert(values_h->length() == 1 &&
a61af66fc99e Initial load
duke
parents:
diff changeset
4397 values_h->int_at(0) == java_lang_Thread::TERMINATED,
a61af66fc99e Initial load
duke
parents:
diff changeset
4398 "Invalid threadStatus value");
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 1059
diff changeset
4399 objArrayOop r = oopFactory::new_objArray(SystemDictionary::String_klass(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4400 1, /* only 1 substate */
a61af66fc99e Initial load
duke
parents:
diff changeset
4401 CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4402 names_h = objArrayHandle(THREAD, r);
a61af66fc99e Initial load
duke
parents:
diff changeset
4403 Handle name = java_lang_String::create_from_str("TERMINATED", CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
4404 names_h->obj_at_put(0, name());
a61af66fc99e Initial load
duke
parents:
diff changeset
4405 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
4406 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4407 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
4408 // Unknown state - probably incompatible JDK version
a61af66fc99e Initial load
duke
parents:
diff changeset
4409 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
4410 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4411 return (jobjectArray) JNIHandles::make_local(env, names_h());
a61af66fc99e Initial load
duke
parents:
diff changeset
4412 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4413 JVM_END
a61af66fc99e Initial load
duke
parents:
diff changeset
4414
a61af66fc99e Initial load
duke
parents:
diff changeset
4415 JVM_ENTRY(void, JVM_GetVersionInfo(JNIEnv* env, jvm_version_info* info, size_t info_size))
a61af66fc99e Initial load
duke
parents:
diff changeset
4416 {
a61af66fc99e Initial load
duke
parents:
diff changeset
4417 memset(info, 0, sizeof(info_size));
a61af66fc99e Initial load
duke
parents:
diff changeset
4418
a61af66fc99e Initial load
duke
parents:
diff changeset
4419 info->jvm_version = Abstract_VM_Version::jvm_version();
a61af66fc99e Initial load
duke
parents:
diff changeset
4420 info->update_version = 0; /* 0 in HotSpot Express VM */
a61af66fc99e Initial load
duke
parents:
diff changeset
4421 info->special_update_version = 0; /* 0 in HotSpot Express VM */
a61af66fc99e Initial load
duke
parents:
diff changeset
4422
a61af66fc99e Initial load
duke
parents:
diff changeset
4423 // when we add a new capability in the jvm_version_info struct, we should also
a61af66fc99e Initial load
duke
parents:
diff changeset
4424 // consider to expose this new capability in the sun.rt.jvmCapabilities jvmstat
a61af66fc99e Initial load
duke
parents:
diff changeset
4425 // counter defined in runtimeService.cpp.
a61af66fc99e Initial load
duke
parents:
diff changeset
4426 info->is_attachable = AttachListener::is_attach_supported();
a61af66fc99e Initial load
duke
parents:
diff changeset
4427 #ifdef KERNEL
a61af66fc99e Initial load
duke
parents:
diff changeset
4428 info->is_kernel_jvm = 1; // true;
a61af66fc99e Initial load
duke
parents:
diff changeset
4429 #else // KERNEL
a61af66fc99e Initial load
duke
parents:
diff changeset
4430 info->is_kernel_jvm = 0; // false;
a61af66fc99e Initial load
duke
parents:
diff changeset
4431 #endif // KERNEL
a61af66fc99e Initial load
duke
parents:
diff changeset
4432 }
a61af66fc99e Initial load
duke
parents:
diff changeset
4433 JVM_END