annotate src/share/vm/prims/jniCheck.cpp @ 22877:d68158e12cea

8043224: -Xcheck:jni improvements to exception checking and excessive local refs Summary: Warning when not checking exceptions from function that require so, also when local refs expand beyond capacity. Reviewed-by: dsimms
author poonam
date Wed, 11 Mar 2015 13:36:57 -0700
parents 29a5c2fd2d2e
children 9904bb920313
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
2 * Copyright (c) 2001, 2015, 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: 1142
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1142
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: 1142
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/systemDictionary.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #include "classfile/vmSymbols.hpp"
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
28 #include "memory/guardedMemory.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "oops/instanceKlass.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "oops/oop.inline.hpp"
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1989
diff changeset
31 #include "oops/symbol.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "prims/jni.h"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
33 #include "prims/jniCheck.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
34 #include "prims/jvm_misc.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
35 #include "runtime/fieldDescriptor.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
36 #include "runtime/handles.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
37 #include "runtime/interfaceSupport.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
38 #include "runtime/jfieldIDWorkaround.hpp"
20197
ce8f6bb717c9 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 17937
diff changeset
39 #include "runtime/thread.inline.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
40 #ifdef TARGET_ARCH_x86
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
41 # include "jniTypes_x86.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
42 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
43 #ifdef TARGET_ARCH_sparc
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
44 # include "jniTypes_sparc.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
45 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
46 #ifdef TARGET_ARCH_zero
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
47 # include "jniTypes_zero.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
48 #endif
2192
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2177
diff changeset
49 #ifdef TARGET_ARCH_arm
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2177
diff changeset
50 # include "jniTypes_arm.hpp"
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2177
diff changeset
51 #endif
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2177
diff changeset
52 #ifdef TARGET_ARCH_ppc
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2177
diff changeset
53 # include "jniTypes_ppc.hpp"
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2177
diff changeset
54 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
55
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
56 // Complain every extra number of unplanned local refs
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
57 #define CHECK_JNI_LOCAL_REF_CAP_WARN_THRESHOLD 32
0
a61af66fc99e Initial load
duke
parents:
diff changeset
58
a61af66fc99e Initial load
duke
parents:
diff changeset
59 // Heap objects are allowed to be directly referenced only in VM code,
a61af66fc99e Initial load
duke
parents:
diff changeset
60 // not in native code.
a61af66fc99e Initial load
duke
parents:
diff changeset
61
a61af66fc99e Initial load
duke
parents:
diff changeset
62 #define ASSERT_OOPS_ALLOWED \
a61af66fc99e Initial load
duke
parents:
diff changeset
63 assert(JavaThread::current()->thread_state() == _thread_in_vm, \
a61af66fc99e Initial load
duke
parents:
diff changeset
64 "jniCheck examining oops in bad state.")
a61af66fc99e Initial load
duke
parents:
diff changeset
65
a61af66fc99e Initial load
duke
parents:
diff changeset
66
a61af66fc99e Initial load
duke
parents:
diff changeset
67 // Execute the given block of source code with the thread in VM state.
a61af66fc99e Initial load
duke
parents:
diff changeset
68 // To do this, transition from the NATIVE state to the VM state, execute
a61af66fc99e Initial load
duke
parents:
diff changeset
69 // the code, and transtition back. The ThreadInVMfromNative constructor
a61af66fc99e Initial load
duke
parents:
diff changeset
70 // performs the transition to VM state, its destructor restores the
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // NATIVE state.
a61af66fc99e Initial load
duke
parents:
diff changeset
72
a61af66fc99e Initial load
duke
parents:
diff changeset
73 #define IN_VM(source_code) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
74 { \
a61af66fc99e Initial load
duke
parents:
diff changeset
75 ThreadInVMfromNative __tiv(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
76 source_code \
a61af66fc99e Initial load
duke
parents:
diff changeset
77 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
78 }
a61af66fc99e Initial load
duke
parents:
diff changeset
79
a61af66fc99e Initial load
duke
parents:
diff changeset
80
a61af66fc99e Initial load
duke
parents:
diff changeset
81 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
82 * DECLARATIONS
a61af66fc99e Initial load
duke
parents:
diff changeset
83 */
a61af66fc99e Initial load
duke
parents:
diff changeset
84
a61af66fc99e Initial load
duke
parents:
diff changeset
85 static struct JNINativeInterface_ * unchecked_jni_NativeInterface;
a61af66fc99e Initial load
duke
parents:
diff changeset
86
a61af66fc99e Initial load
duke
parents:
diff changeset
87
a61af66fc99e Initial load
duke
parents:
diff changeset
88 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
89 * MACRO DEFINITIONS
a61af66fc99e Initial load
duke
parents:
diff changeset
90 */
a61af66fc99e Initial load
duke
parents:
diff changeset
91
a61af66fc99e Initial load
duke
parents:
diff changeset
92 // All JNI checked functions here use JNI_ENTRY_CHECKED() instead of the
a61af66fc99e Initial load
duke
parents:
diff changeset
93 // QUICK_ENTRY or LEAF variants found in jni.cpp. This allows handles
a61af66fc99e Initial load
duke
parents:
diff changeset
94 // to be created if a fatal error should occur.
a61af66fc99e Initial load
duke
parents:
diff changeset
95
a61af66fc99e Initial load
duke
parents:
diff changeset
96 // Check for thread not attached to VM; need to catch this before
a61af66fc99e Initial load
duke
parents:
diff changeset
97 // assertions in the wrapper routines might fire
a61af66fc99e Initial load
duke
parents:
diff changeset
98
a61af66fc99e Initial load
duke
parents:
diff changeset
99 // Check for env being the one value appropriate for this thread.
a61af66fc99e Initial load
duke
parents:
diff changeset
100
a61af66fc99e Initial load
duke
parents:
diff changeset
101 #define JNI_ENTRY_CHECKED(result_type, header) \
a61af66fc99e Initial load
duke
parents:
diff changeset
102 extern "C" { \
a61af66fc99e Initial load
duke
parents:
diff changeset
103 result_type JNICALL header { \
a61af66fc99e Initial load
duke
parents:
diff changeset
104 JavaThread* thr = (JavaThread*)ThreadLocalStorage::get_thread_slow();\
a61af66fc99e Initial load
duke
parents:
diff changeset
105 if (thr == NULL || !thr->is_Java_thread()) { \
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 17467
diff changeset
106 tty->print_cr("%s", fatal_using_jnienv_in_nonjava); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
107 os::abort(true); \
a61af66fc99e Initial load
duke
parents:
diff changeset
108 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
109 JNIEnv* xenv = thr->jni_environment(); \
a61af66fc99e Initial load
duke
parents:
diff changeset
110 if (env != xenv) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
111 NativeReportJNIFatalError(thr, warn_wrong_jnienv); \
a61af66fc99e Initial load
duke
parents:
diff changeset
112 } \
4045
a6eef545f1a2 7103224: collision between __LEAF define in interfaceSupport.hpp and /usr/include/sys/cdefs.h with gcc
never
parents: 2376
diff changeset
113 VM_ENTRY_BASE(result_type, header, thr)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
114
a61af66fc99e Initial load
duke
parents:
diff changeset
115
a61af66fc99e Initial load
duke
parents:
diff changeset
116 #define UNCHECKED() (unchecked_jni_NativeInterface)
a61af66fc99e Initial load
duke
parents:
diff changeset
117
a61af66fc99e Initial load
duke
parents:
diff changeset
118 static const char * warn_wrong_jnienv = "Using JNIEnv in the wrong thread";
a61af66fc99e Initial load
duke
parents:
diff changeset
119 static const char * warn_bad_class_descriptor = "JNI FindClass received a bad class descriptor \"%s\". A correct class descriptor " \
a61af66fc99e Initial load
duke
parents:
diff changeset
120 "has no leading \"L\" or trailing \";\". Incorrect descriptors will not be accepted in future releases.";
a61af66fc99e Initial load
duke
parents:
diff changeset
121 static const char * fatal_using_jnienv_in_nonjava = "FATAL ERROR in native method: Using JNIEnv in non-Java thread";
a61af66fc99e Initial load
duke
parents:
diff changeset
122 static const char * warn_other_function_in_critical = "Warning: Calling other JNI functions in the scope of " \
a61af66fc99e Initial load
duke
parents:
diff changeset
123 "Get/ReleasePrimitiveArrayCritical or Get/ReleaseStringCritical";
a61af66fc99e Initial load
duke
parents:
diff changeset
124 static const char * fatal_bad_ref_to_jni = "Bad global or local ref passed to JNI";
a61af66fc99e Initial load
duke
parents:
diff changeset
125 static const char * fatal_received_null_class = "JNI received a null class";
a61af66fc99e Initial load
duke
parents:
diff changeset
126 static const char * fatal_class_not_a_class = "JNI received a class argument that is not a class";
a61af66fc99e Initial load
duke
parents:
diff changeset
127 static const char * fatal_class_not_a_throwable_class = "JNI Throw or ThrowNew received a class argument that is not a Throwable or Throwable subclass";
a61af66fc99e Initial load
duke
parents:
diff changeset
128 static const char * fatal_wrong_class_or_method = "Wrong object class or methodID passed to JNI call";
917
1760a1cbed36 6862945: 4/3 conversion of jmethodID to methodOop in JVMTI is too expensive
dcubed
parents: 470
diff changeset
129 static const char * fatal_non_weak_method = "non-weak methodID passed to JNI call";
0
a61af66fc99e Initial load
duke
parents:
diff changeset
130 static const char * fatal_unknown_array_object = "Unknown array object passed to JNI array operations";
a61af66fc99e Initial load
duke
parents:
diff changeset
131 static const char * fatal_object_array_expected = "Object array expected but not received for JNI array operation";
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
132 static const char * fatal_prim_type_array_expected = "Primitive type array expected but not received for JNI array operation";
0
a61af66fc99e Initial load
duke
parents:
diff changeset
133 static const char * fatal_non_array = "Non-array passed to JNI array operations";
a61af66fc99e Initial load
duke
parents:
diff changeset
134 static const char * fatal_element_type_mismatch = "Array element type mismatch in JNI";
a61af66fc99e Initial load
duke
parents:
diff changeset
135 static const char * fatal_should_be_static = "Non-static field ID passed to JNI";
a61af66fc99e Initial load
duke
parents:
diff changeset
136 static const char * fatal_wrong_static_field = "Wrong static field ID passed to JNI";
a61af66fc99e Initial load
duke
parents:
diff changeset
137 static const char * fatal_static_field_not_found = "Static field not found in JNI get/set field operations";
a61af66fc99e Initial load
duke
parents:
diff changeset
138 static const char * fatal_static_field_mismatch = "Field type (static) mismatch in JNI get/set field operations";
a61af66fc99e Initial load
duke
parents:
diff changeset
139 static const char * fatal_should_be_nonstatic = "Static field ID passed to JNI";
a61af66fc99e Initial load
duke
parents:
diff changeset
140 static const char * fatal_null_object = "Null object passed to JNI";
a61af66fc99e Initial load
duke
parents:
diff changeset
141 static const char * fatal_wrong_field = "Wrong field ID passed to JNI";
a61af66fc99e Initial load
duke
parents:
diff changeset
142 static const char * fatal_instance_field_not_found = "Instance field not found in JNI get/set field operations";
a61af66fc99e Initial load
duke
parents:
diff changeset
143 static const char * fatal_instance_field_mismatch = "Field type (instance) mismatch in JNI get/set field operations";
a61af66fc99e Initial load
duke
parents:
diff changeset
144 static const char * fatal_non_string = "JNI string operation received a non-string";
a61af66fc99e Initial load
duke
parents:
diff changeset
145
a61af66fc99e Initial load
duke
parents:
diff changeset
146
a61af66fc99e Initial load
duke
parents:
diff changeset
147 // When in VM state:
a61af66fc99e Initial load
duke
parents:
diff changeset
148 static void ReportJNIWarning(JavaThread* thr, const char *msg) {
a61af66fc99e Initial load
duke
parents:
diff changeset
149 tty->print_cr("WARNING in native method: %s", msg);
a61af66fc99e Initial load
duke
parents:
diff changeset
150 thr->print_stack();
a61af66fc99e Initial load
duke
parents:
diff changeset
151 }
a61af66fc99e Initial load
duke
parents:
diff changeset
152
a61af66fc99e Initial load
duke
parents:
diff changeset
153 // When in NATIVE state:
a61af66fc99e Initial load
duke
parents:
diff changeset
154 static void NativeReportJNIFatalError(JavaThread* thr, const char *msg) {
a61af66fc99e Initial load
duke
parents:
diff changeset
155 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
156 ReportJNIFatalError(thr, msg);
a61af66fc99e Initial load
duke
parents:
diff changeset
157 )
a61af66fc99e Initial load
duke
parents:
diff changeset
158 }
a61af66fc99e Initial load
duke
parents:
diff changeset
159
a61af66fc99e Initial load
duke
parents:
diff changeset
160 static void NativeReportJNIWarning(JavaThread* thr, const char *msg) {
a61af66fc99e Initial load
duke
parents:
diff changeset
161 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
162 ReportJNIWarning(thr, msg);
a61af66fc99e Initial load
duke
parents:
diff changeset
163 )
a61af66fc99e Initial load
duke
parents:
diff changeset
164 }
a61af66fc99e Initial load
duke
parents:
diff changeset
165
a61af66fc99e Initial load
duke
parents:
diff changeset
166
a61af66fc99e Initial load
duke
parents:
diff changeset
167
a61af66fc99e Initial load
duke
parents:
diff changeset
168
a61af66fc99e Initial load
duke
parents:
diff changeset
169 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
170 * SUPPORT FUNCTIONS
a61af66fc99e Initial load
duke
parents:
diff changeset
171 */
a61af66fc99e Initial load
duke
parents:
diff changeset
172
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
173 /**
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
174 * Check whether or not a programmer has actually checked for exceptions. According
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
175 * to the JNI Specification ("jni/spec/design.html#java_exceptions"):
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
176 *
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
177 * There are two cases where the programmer needs to check for exceptions without
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
178 * being able to first check an error code:
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
179 *
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
180 * - The JNI functions that invoke a Java method return the result of the Java method.
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
181 * The programmer must call ExceptionOccurred() to check for possible exceptions
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
182 * that occurred during the execution of the Java method.
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
183 *
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
184 * - Some of the JNI array access functions do not return an error code, but may
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
185 * throw an ArrayIndexOutOfBoundsException or ArrayStoreException.
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
186 *
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
187 * In all other cases, a non-error return value guarantees that no exceptions have been thrown.
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
188 */
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
189 static inline void
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
190 check_pending_exception(JavaThread* thr) {
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
191 if (thr->has_pending_exception()) {
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
192 NativeReportJNIWarning(thr, "JNI call made with exception pending");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
193 }
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
194 if (thr->is_pending_jni_exception_check()) {
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
195 IN_VM(
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
196 tty->print_cr("WARNING in native method: JNI call made without checking exceptions when required to from %s",
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
197 thr->get_pending_jni_exception_check());
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
198 thr->print_stack();
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
199 )
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
200 thr->clear_pending_jni_exception_check(); // Just complain once
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
201 }
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
202 }
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
203
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
204
0
a61af66fc99e Initial load
duke
parents:
diff changeset
205 static inline void
a61af66fc99e Initial load
duke
parents:
diff changeset
206 functionEnterCritical(JavaThread* thr)
a61af66fc99e Initial load
duke
parents:
diff changeset
207 {
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
208 check_pending_exception(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
209 }
a61af66fc99e Initial load
duke
parents:
diff changeset
210
a61af66fc99e Initial load
duke
parents:
diff changeset
211 static inline void
a61af66fc99e Initial load
duke
parents:
diff changeset
212 functionEnterCriticalExceptionAllowed(JavaThread* thr)
a61af66fc99e Initial load
duke
parents:
diff changeset
213 {
a61af66fc99e Initial load
duke
parents:
diff changeset
214 }
a61af66fc99e Initial load
duke
parents:
diff changeset
215
a61af66fc99e Initial load
duke
parents:
diff changeset
216 static inline void
a61af66fc99e Initial load
duke
parents:
diff changeset
217 functionEnter(JavaThread* thr)
a61af66fc99e Initial load
duke
parents:
diff changeset
218 {
a61af66fc99e Initial load
duke
parents:
diff changeset
219 if (thr->in_critical()) {
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 17467
diff changeset
220 tty->print_cr("%s", warn_other_function_in_critical);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
221 }
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
222 check_pending_exception(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
223 }
a61af66fc99e Initial load
duke
parents:
diff changeset
224
a61af66fc99e Initial load
duke
parents:
diff changeset
225 static inline void
a61af66fc99e Initial load
duke
parents:
diff changeset
226 functionEnterExceptionAllowed(JavaThread* thr)
a61af66fc99e Initial load
duke
parents:
diff changeset
227 {
a61af66fc99e Initial load
duke
parents:
diff changeset
228 if (thr->in_critical()) {
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 17467
diff changeset
229 tty->print_cr("%s", warn_other_function_in_critical);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
230 }
a61af66fc99e Initial load
duke
parents:
diff changeset
231 }
a61af66fc99e Initial load
duke
parents:
diff changeset
232
a61af66fc99e Initial load
duke
parents:
diff changeset
233 static inline void
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
234 functionExit(JavaThread* thr)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
235 {
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
236 JNIHandleBlock* handles = thr->active_handles();
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
237 size_t planned_capacity = handles->get_planned_capacity();
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
238 size_t live_handles = handles->get_number_of_live_handles();
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
239 if (live_handles > planned_capacity) {
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
240 IN_VM(
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
241 tty->print_cr("WARNING: JNI local refs: %zu, exceeds capacity: %zu",
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
242 live_handles, planned_capacity);
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
243 thr->print_stack();
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
244 )
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
245 // Complain just the once, reset to current + warn threshold
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
246 handles->set_planned_capacity(live_handles + CHECK_JNI_LOCAL_REF_CAP_WARN_THRESHOLD);
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
247 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
248 }
a61af66fc99e Initial load
duke
parents:
diff changeset
249
a61af66fc99e Initial load
duke
parents:
diff changeset
250 static inline void
a61af66fc99e Initial load
duke
parents:
diff changeset
251 checkStaticFieldID(JavaThread* thr, jfieldID fid, jclass cls, int ftype)
a61af66fc99e Initial load
duke
parents:
diff changeset
252 {
a61af66fc99e Initial load
duke
parents:
diff changeset
253 fieldDescriptor fd;
a61af66fc99e Initial load
duke
parents:
diff changeset
254
a61af66fc99e Initial load
duke
parents:
diff changeset
255 /* make sure it is a static field */
a61af66fc99e Initial load
duke
parents:
diff changeset
256 if (!jfieldIDWorkaround::is_static_jfieldID(fid))
a61af66fc99e Initial load
duke
parents:
diff changeset
257 ReportJNIFatalError(thr, fatal_should_be_static);
a61af66fc99e Initial load
duke
parents:
diff changeset
258
a61af66fc99e Initial load
duke
parents:
diff changeset
259 /* validate the class being passed */
a61af66fc99e Initial load
duke
parents:
diff changeset
260 ASSERT_OOPS_ALLOWED;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
261 Klass* k_oop = jniCheck::validate_class(thr, cls, false);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
262
a61af66fc99e Initial load
duke
parents:
diff changeset
263 /* check for proper subclass hierarchy */
a61af66fc99e Initial load
duke
parents:
diff changeset
264 JNIid* id = jfieldIDWorkaround::from_static_jfieldID(fid);
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
265 Klass* f_oop = id->holder();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
266 if (!InstanceKlass::cast(k_oop)->is_subtype_of(f_oop))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
267 ReportJNIFatalError(thr, fatal_wrong_static_field);
a61af66fc99e Initial load
duke
parents:
diff changeset
268
a61af66fc99e Initial load
duke
parents:
diff changeset
269 /* check for proper field type */
2376
c7f3d0b4570f 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 2192
diff changeset
270 if (!id->find_local_field(&fd))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
271 ReportJNIFatalError(thr, fatal_static_field_not_found);
a61af66fc99e Initial load
duke
parents:
diff changeset
272 if ((fd.field_type() != ftype) &&
a61af66fc99e Initial load
duke
parents:
diff changeset
273 !(fd.field_type() == T_ARRAY && ftype == T_OBJECT)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
274 ReportJNIFatalError(thr, fatal_static_field_mismatch);
a61af66fc99e Initial load
duke
parents:
diff changeset
275 }
a61af66fc99e Initial load
duke
parents:
diff changeset
276 }
a61af66fc99e Initial load
duke
parents:
diff changeset
277
a61af66fc99e Initial load
duke
parents:
diff changeset
278 static inline void
a61af66fc99e Initial load
duke
parents:
diff changeset
279 checkInstanceFieldID(JavaThread* thr, jfieldID fid, jobject obj, int ftype)
a61af66fc99e Initial load
duke
parents:
diff changeset
280 {
a61af66fc99e Initial load
duke
parents:
diff changeset
281 fieldDescriptor fd;
a61af66fc99e Initial load
duke
parents:
diff changeset
282
a61af66fc99e Initial load
duke
parents:
diff changeset
283 /* make sure it is an instance field */
a61af66fc99e Initial load
duke
parents:
diff changeset
284 if (jfieldIDWorkaround::is_static_jfieldID(fid))
a61af66fc99e Initial load
duke
parents:
diff changeset
285 ReportJNIFatalError(thr, fatal_should_be_nonstatic);
a61af66fc99e Initial load
duke
parents:
diff changeset
286
a61af66fc99e Initial load
duke
parents:
diff changeset
287 /* validate the object being passed and then get its class */
a61af66fc99e Initial load
duke
parents:
diff changeset
288 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
289 oop oopObj = jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
290 if (!oopObj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
291 ReportJNIFatalError(thr, fatal_null_object);
a61af66fc99e Initial load
duke
parents:
diff changeset
292 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
293 Klass* k_oop = oopObj->klass();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
294
a61af66fc99e Initial load
duke
parents:
diff changeset
295 if (!jfieldIDWorkaround::is_valid_jfieldID(k_oop, fid)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
296 ReportJNIFatalError(thr, fatal_wrong_field);
a61af66fc99e Initial load
duke
parents:
diff changeset
297 }
a61af66fc99e Initial load
duke
parents:
diff changeset
298
a61af66fc99e Initial load
duke
parents:
diff changeset
299 /* make sure the field exists */
a61af66fc99e Initial load
duke
parents:
diff changeset
300 int offset = jfieldIDWorkaround::from_instance_jfieldID(k_oop, fid);
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
301 if (!InstanceKlass::cast(k_oop)->contains_field_offset(offset))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
302 ReportJNIFatalError(thr, fatal_wrong_field);
a61af66fc99e Initial load
duke
parents:
diff changeset
303
a61af66fc99e Initial load
duke
parents:
diff changeset
304 /* check for proper field type */
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
305 if (!InstanceKlass::cast(k_oop)->find_field_from_offset(offset,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
306 false, &fd))
a61af66fc99e Initial load
duke
parents:
diff changeset
307 ReportJNIFatalError(thr, fatal_instance_field_not_found);
a61af66fc99e Initial load
duke
parents:
diff changeset
308
a61af66fc99e Initial load
duke
parents:
diff changeset
309 if ((fd.field_type() != ftype) &&
a61af66fc99e Initial load
duke
parents:
diff changeset
310 !(fd.field_type() == T_ARRAY && ftype == T_OBJECT)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
311 ReportJNIFatalError(thr, fatal_instance_field_mismatch);
a61af66fc99e Initial load
duke
parents:
diff changeset
312 }
a61af66fc99e Initial load
duke
parents:
diff changeset
313 }
a61af66fc99e Initial load
duke
parents:
diff changeset
314
a61af66fc99e Initial load
duke
parents:
diff changeset
315 static inline void
a61af66fc99e Initial load
duke
parents:
diff changeset
316 checkString(JavaThread* thr, jstring js)
a61af66fc99e Initial load
duke
parents:
diff changeset
317 {
a61af66fc99e Initial load
duke
parents:
diff changeset
318 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
319 oop s = jniCheck::validate_object(thr, js);
a61af66fc99e Initial load
duke
parents:
diff changeset
320 if (!s || !java_lang_String::is_instance(s))
a61af66fc99e Initial load
duke
parents:
diff changeset
321 ReportJNIFatalError(thr, fatal_non_string);
a61af66fc99e Initial load
duke
parents:
diff changeset
322 }
a61af66fc99e Initial load
duke
parents:
diff changeset
323
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
324 static inline arrayOop
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
325 check_is_array(JavaThread* thr, jarray jArray)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
326 {
a61af66fc99e Initial load
duke
parents:
diff changeset
327 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
328 arrayOop aOop;
a61af66fc99e Initial load
duke
parents:
diff changeset
329
a61af66fc99e Initial load
duke
parents:
diff changeset
330 aOop = (arrayOop)jniCheck::validate_object(thr, jArray);
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
331 if (aOop == NULL || !aOop->is_array()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
332 ReportJNIFatalError(thr, fatal_non_array);
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
333 }
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
334 return aOop;
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
335 }
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
336
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
337 static inline arrayOop
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
338 check_is_primitive_array(JavaThread* thr, jarray jArray) {
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
339 arrayOop aOop = check_is_array(thr, jArray);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
340
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
341 if (!aOop->is_typeArray()) {
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
342 ReportJNIFatalError(thr, fatal_prim_type_array_expected);
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
343 }
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
344 return aOop;
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
345 }
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
346
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
347 static inline void
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
348 check_primitive_array_type(JavaThread* thr, jarray jArray, BasicType elementType)
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
349 {
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
350 BasicType array_type;
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
351 arrayOop aOop;
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
352
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
353 aOop = check_is_primitive_array(thr, jArray);
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
354 array_type = TypeArrayKlass::cast(aOop->klass())->element_type();
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
355 if (array_type != elementType) {
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
356 ReportJNIFatalError(thr, fatal_element_type_mismatch);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
357 }
a61af66fc99e Initial load
duke
parents:
diff changeset
358 }
a61af66fc99e Initial load
duke
parents:
diff changeset
359
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
360 static inline void
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
361 check_is_obj_array(JavaThread* thr, jarray jArray) {
11150
c29568b733d2 8020697: jniCheck.cpp:check_is_obj_array asserts on TypeArrayKlass::cast(aOop->klass())
dholmes
parents: 11145
diff changeset
362 arrayOop aOop = check_is_array(thr, jArray);
c29568b733d2 8020697: jniCheck.cpp:check_is_obj_array asserts on TypeArrayKlass::cast(aOop->klass())
dholmes
parents: 11145
diff changeset
363 if (!aOop->is_objArray()) {
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
364 ReportJNIFatalError(thr, fatal_object_array_expected);
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
365 }
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
366 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
367
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
368 /*
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
369 * Copy and wrap array elements for bounds checking.
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
370 * Remember the original elements (GuardedMemory::get_tag())
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
371 */
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
372 static void* check_jni_wrap_copy_array(JavaThread* thr, jarray array,
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
373 void* orig_elements) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
374 void* result;
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
375 IN_VM(
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
376 oop a = JNIHandles::resolve_non_null(array);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
377 size_t len = arrayOop(a)->length() <<
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
378 TypeArrayKlass::cast(a->klass())->log2_element_size();
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
379 result = GuardedMemory::wrap_copy(orig_elements, len, orig_elements);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
380 )
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
381 return result;
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
382 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
383
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
384 static void* check_wrapped_array(JavaThread* thr, const char* fn_name,
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
385 void* obj, void* carray, size_t* rsz) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
386 if (carray == NULL) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
387 tty->print_cr("%s: elements vector NULL" PTR_FORMAT, fn_name, p2i(obj));
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
388 NativeReportJNIFatalError(thr, "Elements vector NULL");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
389 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
390 GuardedMemory guarded(carray);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
391 void* orig_result = guarded.get_tag();
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
392 if (!guarded.verify_guards()) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
393 tty->print_cr("ReleasePrimitiveArrayCritical: release array failed bounds "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
394 "check, incorrect pointer returned ? array: " PTR_FORMAT " carray: "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
395 PTR_FORMAT, p2i(obj), p2i(carray));
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
396 guarded.print_on(tty);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
397 NativeReportJNIFatalError(thr, "ReleasePrimitiveArrayCritical: "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
398 "failed bounds check");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
399 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
400 if (orig_result == NULL) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
401 tty->print_cr("ReleasePrimitiveArrayCritical: unrecognized elements. array: "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
402 PTR_FORMAT " carray: " PTR_FORMAT, p2i(obj), p2i(carray));
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
403 guarded.print_on(tty);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
404 NativeReportJNIFatalError(thr, "ReleasePrimitiveArrayCritical: "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
405 "unrecognized elements");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
406 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
407 if (rsz != NULL) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
408 *rsz = guarded.get_user_size();
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
409 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
410 return orig_result;
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
411 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
412
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
413 static void* check_wrapped_array_release(JavaThread* thr, const char* fn_name,
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
414 void* obj, void* carray, jint mode) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
415 size_t sz;
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
416 void* orig_result = check_wrapped_array(thr, fn_name, obj, carray, &sz);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
417 switch (mode) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
418 case 0:
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
419 memcpy(orig_result, carray, sz);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
420 GuardedMemory::free_copy(carray);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
421 break;
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
422 case JNI_COMMIT:
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
423 memcpy(orig_result, carray, sz);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
424 break;
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
425 case JNI_ABORT:
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
426 GuardedMemory::free_copy(carray);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
427 break;
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
428 default:
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
429 tty->print_cr("%s: Unrecognized mode %i releasing array "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
430 PTR_FORMAT " elements " PTR_FORMAT, fn_name, mode, p2i(obj), p2i(carray));
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
431 NativeReportJNIFatalError(thr, "Unrecognized array release mode");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
432 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
433 return orig_result;
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
434 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
435
0
a61af66fc99e Initial load
duke
parents:
diff changeset
436 oop jniCheck::validate_handle(JavaThread* thr, jobject obj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
437 if (JNIHandles::is_frame_handle(thr, obj) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
438 JNIHandles::is_local_handle(thr, obj) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
439 JNIHandles::is_global_handle(obj) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
440 JNIHandles::is_weak_global_handle(obj)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
441 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
442 return JNIHandles::resolve_external_guard(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
443 }
a61af66fc99e Initial load
duke
parents:
diff changeset
444 ReportJNIFatalError(thr, fatal_bad_ref_to_jni);
a61af66fc99e Initial load
duke
parents:
diff changeset
445 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
446 }
a61af66fc99e Initial load
duke
parents:
diff changeset
447
a61af66fc99e Initial load
duke
parents:
diff changeset
448
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
449 Method* jniCheck::validate_jmethod_id(JavaThread* thr, jmethodID method_id) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
450 ASSERT_OOPS_ALLOWED;
917
1760a1cbed36 6862945: 4/3 conversion of jmethodID to methodOop in JVMTI is too expensive
dcubed
parents: 470
diff changeset
451 // do the fast jmethodID check first
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
452 Method* moop = Method::checked_resolve_jmethod_id(method_id);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
453 if (moop == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
454 ReportJNIFatalError(thr, fatal_wrong_class_or_method);
a61af66fc99e Initial load
duke
parents:
diff changeset
455 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
456 // jmethodIDs are supposed to be weak handles in the class loader data,
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
457 // but that can be expensive so check it last
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
458 else if (!Method::is_method_id(method_id)) {
917
1760a1cbed36 6862945: 4/3 conversion of jmethodID to methodOop in JVMTI is too expensive
dcubed
parents: 470
diff changeset
459 ReportJNIFatalError(thr, fatal_non_weak_method);
1760a1cbed36 6862945: 4/3 conversion of jmethodID to methodOop in JVMTI is too expensive
dcubed
parents: 470
diff changeset
460 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
461 return moop;
a61af66fc99e Initial load
duke
parents:
diff changeset
462 }
a61af66fc99e Initial load
duke
parents:
diff changeset
463
a61af66fc99e Initial load
duke
parents:
diff changeset
464
a61af66fc99e Initial load
duke
parents:
diff changeset
465 oop jniCheck::validate_object(JavaThread* thr, jobject obj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
466 if (!obj)
a61af66fc99e Initial load
duke
parents:
diff changeset
467 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
468 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
469 oop oopObj = jniCheck::validate_handle(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
470 if (!oopObj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
471 ReportJNIFatalError(thr, fatal_bad_ref_to_jni);
a61af66fc99e Initial load
duke
parents:
diff changeset
472 }
a61af66fc99e Initial load
duke
parents:
diff changeset
473 return oopObj;
a61af66fc99e Initial load
duke
parents:
diff changeset
474 }
a61af66fc99e Initial load
duke
parents:
diff changeset
475
a61af66fc99e Initial load
duke
parents:
diff changeset
476 // Warn if a class descriptor is in decorated form; class descriptors
a61af66fc99e Initial load
duke
parents:
diff changeset
477 // passed to JNI findClass should not be decorated unless they are
a61af66fc99e Initial load
duke
parents:
diff changeset
478 // array descriptors.
a61af66fc99e Initial load
duke
parents:
diff changeset
479 void jniCheck::validate_class_descriptor(JavaThread* thr, const char* name) {
a61af66fc99e Initial load
duke
parents:
diff changeset
480 if (name == NULL) return; // implementation accepts NULL so just return
a61af66fc99e Initial load
duke
parents:
diff changeset
481
a61af66fc99e Initial load
duke
parents:
diff changeset
482 size_t len = strlen(name);
a61af66fc99e Initial load
duke
parents:
diff changeset
483
a61af66fc99e Initial load
duke
parents:
diff changeset
484 if (len >= 2 &&
a61af66fc99e Initial load
duke
parents:
diff changeset
485 name[0] == JVM_SIGNATURE_CLASS && // 'L'
a61af66fc99e Initial load
duke
parents:
diff changeset
486 name[len-1] == JVM_SIGNATURE_ENDCLASS ) { // ';'
a61af66fc99e Initial load
duke
parents:
diff changeset
487 char msg[JVM_MAXPATHLEN];
a61af66fc99e Initial load
duke
parents:
diff changeset
488 jio_snprintf(msg, JVM_MAXPATHLEN, warn_bad_class_descriptor, name);
a61af66fc99e Initial load
duke
parents:
diff changeset
489 ReportJNIWarning(thr, msg);
a61af66fc99e Initial load
duke
parents:
diff changeset
490 }
a61af66fc99e Initial load
duke
parents:
diff changeset
491 }
a61af66fc99e Initial load
duke
parents:
diff changeset
492
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
493 Klass* jniCheck::validate_class(JavaThread* thr, jclass clazz, bool allow_primitive) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
494 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
495 oop mirror = jniCheck::validate_handle(thr, clazz);
a61af66fc99e Initial load
duke
parents:
diff changeset
496 if (!mirror) {
a61af66fc99e Initial load
duke
parents:
diff changeset
497 ReportJNIFatalError(thr, fatal_received_null_class);
a61af66fc99e Initial load
duke
parents:
diff changeset
498 }
a61af66fc99e Initial load
duke
parents:
diff changeset
499
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 917
diff changeset
500 if (mirror->klass() != SystemDictionary::Class_klass()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
501 ReportJNIFatalError(thr, fatal_class_not_a_class);
a61af66fc99e Initial load
duke
parents:
diff changeset
502 }
a61af66fc99e Initial load
duke
parents:
diff changeset
503
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
504 Klass* k = java_lang_Class::as_Klass(mirror);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
505 // Make allowances for primitive classes ...
a61af66fc99e Initial load
duke
parents:
diff changeset
506 if (!(k != NULL || allow_primitive && java_lang_Class::is_primitive(mirror))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
507 ReportJNIFatalError(thr, fatal_class_not_a_class);
a61af66fc99e Initial load
duke
parents:
diff changeset
508 }
a61af66fc99e Initial load
duke
parents:
diff changeset
509 return k;
a61af66fc99e Initial load
duke
parents:
diff changeset
510 }
a61af66fc99e Initial load
duke
parents:
diff changeset
511
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
512 void jniCheck::validate_throwable_klass(JavaThread* thr, Klass* klass) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
513 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
514 assert(klass != NULL, "klass argument must have a value");
a61af66fc99e Initial load
duke
parents:
diff changeset
515
6983
070d523b96a7 8001471: Klass::cast() does nothing
hseigel
parents: 6831
diff changeset
516 if (!klass->oop_is_instance() ||
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
517 !InstanceKlass::cast(klass)->is_subclass_of(SystemDictionary::Throwable_klass())) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
518 ReportJNIFatalError(thr, fatal_class_not_a_throwable_class);
a61af66fc99e Initial load
duke
parents:
diff changeset
519 }
a61af66fc99e Initial load
duke
parents:
diff changeset
520 }
a61af66fc99e Initial load
duke
parents:
diff changeset
521
a61af66fc99e Initial load
duke
parents:
diff changeset
522 void jniCheck::validate_call_object(JavaThread* thr, jobject obj, jmethodID method_id) {
a61af66fc99e Initial load
duke
parents:
diff changeset
523 /* validate the object being passed */
a61af66fc99e Initial load
duke
parents:
diff changeset
524 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
525 jniCheck::validate_jmethod_id(thr, method_id);
a61af66fc99e Initial load
duke
parents:
diff changeset
526 jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
527 }
a61af66fc99e Initial load
duke
parents:
diff changeset
528
a61af66fc99e Initial load
duke
parents:
diff changeset
529 void jniCheck::validate_call_class(JavaThread* thr, jclass clazz, jmethodID method_id) {
a61af66fc99e Initial load
duke
parents:
diff changeset
530 /* validate the class being passed */
a61af66fc99e Initial load
duke
parents:
diff changeset
531 ASSERT_OOPS_ALLOWED;
a61af66fc99e Initial load
duke
parents:
diff changeset
532 jniCheck::validate_jmethod_id(thr, method_id);
a61af66fc99e Initial load
duke
parents:
diff changeset
533 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
534 }
a61af66fc99e Initial load
duke
parents:
diff changeset
535
a61af66fc99e Initial load
duke
parents:
diff changeset
536
a61af66fc99e Initial load
duke
parents:
diff changeset
537 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
538 * IMPLEMENTATION OF FUNCTIONS IN CHECKED TABLE
a61af66fc99e Initial load
duke
parents:
diff changeset
539 */
a61af66fc99e Initial load
duke
parents:
diff changeset
540
a61af66fc99e Initial load
duke
parents:
diff changeset
541 JNI_ENTRY_CHECKED(jclass,
a61af66fc99e Initial load
duke
parents:
diff changeset
542 checked_jni_DefineClass(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
543 const char *name,
a61af66fc99e Initial load
duke
parents:
diff changeset
544 jobject loader,
a61af66fc99e Initial load
duke
parents:
diff changeset
545 const jbyte *buf,
a61af66fc99e Initial load
duke
parents:
diff changeset
546 jsize len))
a61af66fc99e Initial load
duke
parents:
diff changeset
547 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
548 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
549 jniCheck::validate_object(thr, loader);
a61af66fc99e Initial load
duke
parents:
diff changeset
550 )
a61af66fc99e Initial load
duke
parents:
diff changeset
551 jclass result = UNCHECKED()->DefineClass(env, name, loader, buf, len);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
552 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
553 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
554 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
555
a61af66fc99e Initial load
duke
parents:
diff changeset
556 JNI_ENTRY_CHECKED(jclass,
a61af66fc99e Initial load
duke
parents:
diff changeset
557 checked_jni_FindClass(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
558 const char *name))
a61af66fc99e Initial load
duke
parents:
diff changeset
559 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
560 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
561 jniCheck::validate_class_descriptor(thr, name);
a61af66fc99e Initial load
duke
parents:
diff changeset
562 )
a61af66fc99e Initial load
duke
parents:
diff changeset
563 jclass result = UNCHECKED()->FindClass(env, name);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
564 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
565 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
566 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
567
a61af66fc99e Initial load
duke
parents:
diff changeset
568 JNI_ENTRY_CHECKED(jmethodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
569 checked_jni_FromReflectedMethod(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
570 jobject method))
a61af66fc99e Initial load
duke
parents:
diff changeset
571 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
572 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
573 jniCheck::validate_object(thr, method);
a61af66fc99e Initial load
duke
parents:
diff changeset
574 )
a61af66fc99e Initial load
duke
parents:
diff changeset
575 jmethodID result = UNCHECKED()->FromReflectedMethod(env, method);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
576 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
577 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
578 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
579
a61af66fc99e Initial load
duke
parents:
diff changeset
580 JNI_ENTRY_CHECKED(jfieldID,
a61af66fc99e Initial load
duke
parents:
diff changeset
581 checked_jni_FromReflectedField(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
582 jobject field))
a61af66fc99e Initial load
duke
parents:
diff changeset
583 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
584 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
585 jniCheck::validate_object(thr, field);
a61af66fc99e Initial load
duke
parents:
diff changeset
586 )
a61af66fc99e Initial load
duke
parents:
diff changeset
587 jfieldID result = UNCHECKED()->FromReflectedField(env, field);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
588 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
589 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
590 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
591
a61af66fc99e Initial load
duke
parents:
diff changeset
592 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
593 checked_jni_ToReflectedMethod(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
594 jclass cls,
a61af66fc99e Initial load
duke
parents:
diff changeset
595 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
596 jboolean isStatic))
a61af66fc99e Initial load
duke
parents:
diff changeset
597 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
598 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
599 jniCheck::validate_class(thr, cls, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
600 jniCheck::validate_jmethod_id(thr, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
601 )
a61af66fc99e Initial load
duke
parents:
diff changeset
602 jobject result = UNCHECKED()->ToReflectedMethod(env, cls, methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
603 isStatic);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
604 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
605 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
606 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
607
a61af66fc99e Initial load
duke
parents:
diff changeset
608 JNI_ENTRY_CHECKED(jclass,
a61af66fc99e Initial load
duke
parents:
diff changeset
609 checked_jni_GetSuperclass(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
610 jclass sub))
a61af66fc99e Initial load
duke
parents:
diff changeset
611 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
612 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
613 jniCheck::validate_class(thr, sub, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
614 )
a61af66fc99e Initial load
duke
parents:
diff changeset
615 jclass result = UNCHECKED()->GetSuperclass(env, sub);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
616 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
617 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
618 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
619
a61af66fc99e Initial load
duke
parents:
diff changeset
620 JNI_ENTRY_CHECKED(jboolean,
a61af66fc99e Initial load
duke
parents:
diff changeset
621 checked_jni_IsAssignableFrom(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
622 jclass sub,
a61af66fc99e Initial load
duke
parents:
diff changeset
623 jclass sup))
a61af66fc99e Initial load
duke
parents:
diff changeset
624 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
625 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
626 jniCheck::validate_class(thr, sub, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
627 jniCheck::validate_class(thr, sup, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
628 )
a61af66fc99e Initial load
duke
parents:
diff changeset
629 jboolean result = UNCHECKED()->IsAssignableFrom(env, sub, sup);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
630 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
631 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
632 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
633
a61af66fc99e Initial load
duke
parents:
diff changeset
634 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
635 checked_jni_ToReflectedField(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
636 jclass cls,
a61af66fc99e Initial load
duke
parents:
diff changeset
637 jfieldID fieldID,
a61af66fc99e Initial load
duke
parents:
diff changeset
638 jboolean isStatic))
a61af66fc99e Initial load
duke
parents:
diff changeset
639 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
640 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
641 jniCheck::validate_class(thr, cls, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
642 )
a61af66fc99e Initial load
duke
parents:
diff changeset
643 jobject result = UNCHECKED()->ToReflectedField(env, cls, fieldID,
a61af66fc99e Initial load
duke
parents:
diff changeset
644 isStatic);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
645 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
646 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
647 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
648
a61af66fc99e Initial load
duke
parents:
diff changeset
649 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
650 checked_jni_Throw(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
651 jthrowable obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
652 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
653 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
654 oop oopObj = jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
655 if (oopObj == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
656 // Unchecked Throw tolerates a NULL obj, so just warn
a61af66fc99e Initial load
duke
parents:
diff changeset
657 ReportJNIWarning(thr, "JNI Throw called with NULL throwable");
a61af66fc99e Initial load
duke
parents:
diff changeset
658 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
659 jniCheck::validate_throwable_klass(thr, oopObj->klass());
a61af66fc99e Initial load
duke
parents:
diff changeset
660 }
a61af66fc99e Initial load
duke
parents:
diff changeset
661 )
a61af66fc99e Initial load
duke
parents:
diff changeset
662 jint result = UNCHECKED()->Throw(env, obj);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
663 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
664 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
665 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
666
a61af66fc99e Initial load
duke
parents:
diff changeset
667 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
668 checked_jni_ThrowNew(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
669 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
670 const char *msg))
a61af66fc99e Initial load
duke
parents:
diff changeset
671 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
672 IN_VM(
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
673 Klass* k = jniCheck::validate_class(thr, clazz, false);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
674 assert(k != NULL, "validate_class shouldn't return NULL Klass*");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
675 jniCheck::validate_throwable_klass(thr, k);
a61af66fc99e Initial load
duke
parents:
diff changeset
676 )
a61af66fc99e Initial load
duke
parents:
diff changeset
677 jint result = UNCHECKED()->ThrowNew(env, clazz, msg);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
678 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
679 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
680 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
681
a61af66fc99e Initial load
duke
parents:
diff changeset
682 JNI_ENTRY_CHECKED(jthrowable,
a61af66fc99e Initial load
duke
parents:
diff changeset
683 checked_jni_ExceptionOccurred(JNIEnv *env))
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
684 thr->clear_pending_jni_exception_check();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
685 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
686 jthrowable result = UNCHECKED()->ExceptionOccurred(env);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
687 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
688 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
689 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
690
a61af66fc99e Initial load
duke
parents:
diff changeset
691 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
692 checked_jni_ExceptionDescribe(JNIEnv *env))
a61af66fc99e Initial load
duke
parents:
diff changeset
693 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
694 UNCHECKED()->ExceptionDescribe(env);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
695 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
696 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
697
a61af66fc99e Initial load
duke
parents:
diff changeset
698 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
699 checked_jni_ExceptionClear(JNIEnv *env))
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
700 thr->clear_pending_jni_exception_check();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
701 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
702 UNCHECKED()->ExceptionClear(env);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
703 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
704 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
705
a61af66fc99e Initial load
duke
parents:
diff changeset
706 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
707 checked_jni_FatalError(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
708 const char *msg))
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
709 thr->clear_pending_jni_exception_check();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
710 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
711 UNCHECKED()->FatalError(env, msg);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
712 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
713 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
714
a61af66fc99e Initial load
duke
parents:
diff changeset
715 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
716 checked_jni_PushLocalFrame(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
717 jint capacity))
a61af66fc99e Initial load
duke
parents:
diff changeset
718 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
719 if (capacity < 0)
a61af66fc99e Initial load
duke
parents:
diff changeset
720 NativeReportJNIFatalError(thr, "negative capacity");
a61af66fc99e Initial load
duke
parents:
diff changeset
721 jint result = UNCHECKED()->PushLocalFrame(env, capacity);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
722 if (result == JNI_OK) {
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
723 thr->active_handles()->set_planned_capacity(capacity + CHECK_JNI_LOCAL_REF_CAP_WARN_THRESHOLD);
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
724 }
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
725 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
726 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
727 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
728
a61af66fc99e Initial load
duke
parents:
diff changeset
729 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
730 checked_jni_PopLocalFrame(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
731 jobject result))
a61af66fc99e Initial load
duke
parents:
diff changeset
732 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
733 jobject res = UNCHECKED()->PopLocalFrame(env, result);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
734 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
735 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
736 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
737
a61af66fc99e Initial load
duke
parents:
diff changeset
738 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
739 checked_jni_NewGlobalRef(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
740 jobject lobj))
a61af66fc99e Initial load
duke
parents:
diff changeset
741 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
742 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
743 if (lobj != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
744 jniCheck::validate_handle(thr, lobj);
a61af66fc99e Initial load
duke
parents:
diff changeset
745 }
a61af66fc99e Initial load
duke
parents:
diff changeset
746 )
a61af66fc99e Initial load
duke
parents:
diff changeset
747 jobject result = UNCHECKED()->NewGlobalRef(env,lobj);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
748 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
749 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
750 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
751
a61af66fc99e Initial load
duke
parents:
diff changeset
752 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
753 checked_jni_DeleteGlobalRef(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
754 jobject gref))
a61af66fc99e Initial load
duke
parents:
diff changeset
755 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
756 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
757 jniCheck::validate_object(thr, gref);
a61af66fc99e Initial load
duke
parents:
diff changeset
758 if (gref && !JNIHandles::is_global_handle(gref)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
759 ReportJNIFatalError(thr,
a61af66fc99e Initial load
duke
parents:
diff changeset
760 "Invalid global JNI handle passed to DeleteGlobalRef");
a61af66fc99e Initial load
duke
parents:
diff changeset
761 }
a61af66fc99e Initial load
duke
parents:
diff changeset
762 )
a61af66fc99e Initial load
duke
parents:
diff changeset
763 UNCHECKED()->DeleteGlobalRef(env,gref);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
764 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
765 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
766
a61af66fc99e Initial load
duke
parents:
diff changeset
767 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
768 checked_jni_DeleteLocalRef(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
769 jobject obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
770 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
771 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
772 jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
773 if (obj && !(JNIHandles::is_local_handle(thr, obj) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
774 JNIHandles::is_frame_handle(thr, obj)))
a61af66fc99e Initial load
duke
parents:
diff changeset
775 ReportJNIFatalError(thr,
a61af66fc99e Initial load
duke
parents:
diff changeset
776 "Invalid local JNI handle passed to DeleteLocalRef");
a61af66fc99e Initial load
duke
parents:
diff changeset
777 )
a61af66fc99e Initial load
duke
parents:
diff changeset
778 UNCHECKED()->DeleteLocalRef(env, obj);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
779 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
780 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
781
a61af66fc99e Initial load
duke
parents:
diff changeset
782 JNI_ENTRY_CHECKED(jboolean,
a61af66fc99e Initial load
duke
parents:
diff changeset
783 checked_jni_IsSameObject(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
784 jobject obj1,
a61af66fc99e Initial load
duke
parents:
diff changeset
785 jobject obj2))
a61af66fc99e Initial load
duke
parents:
diff changeset
786 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
787 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
788 /* This JNI function can be used to compare weak global references
a61af66fc99e Initial load
duke
parents:
diff changeset
789 * to NULL objects. If the handles are valid, but contain NULL,
a61af66fc99e Initial load
duke
parents:
diff changeset
790 * then don't attempt to validate the object.
a61af66fc99e Initial load
duke
parents:
diff changeset
791 */
a61af66fc99e Initial load
duke
parents:
diff changeset
792 if (obj1 != NULL && jniCheck::validate_handle(thr, obj1) != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
793 jniCheck::validate_object(thr, obj1);
a61af66fc99e Initial load
duke
parents:
diff changeset
794 }
a61af66fc99e Initial load
duke
parents:
diff changeset
795 if (obj2 != NULL && jniCheck::validate_handle(thr, obj2) != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
796 jniCheck::validate_object(thr, obj2);
a61af66fc99e Initial load
duke
parents:
diff changeset
797 }
a61af66fc99e Initial load
duke
parents:
diff changeset
798 )
a61af66fc99e Initial load
duke
parents:
diff changeset
799 jboolean result = UNCHECKED()->IsSameObject(env,obj1,obj2);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
800 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
801 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
802 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
803
a61af66fc99e Initial load
duke
parents:
diff changeset
804 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
805 checked_jni_NewLocalRef(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
806 jobject ref))
a61af66fc99e Initial load
duke
parents:
diff changeset
807 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
808 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
809 if (ref != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
810 jniCheck::validate_handle(thr, ref);
a61af66fc99e Initial load
duke
parents:
diff changeset
811 }
a61af66fc99e Initial load
duke
parents:
diff changeset
812 )
a61af66fc99e Initial load
duke
parents:
diff changeset
813 jobject result = UNCHECKED()->NewLocalRef(env, ref);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
814 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
815 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
816 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
817
a61af66fc99e Initial load
duke
parents:
diff changeset
818 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
819 checked_jni_EnsureLocalCapacity(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
820 jint capacity))
a61af66fc99e Initial load
duke
parents:
diff changeset
821 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
822 if (capacity < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
823 NativeReportJNIFatalError(thr, "negative capacity");
a61af66fc99e Initial load
duke
parents:
diff changeset
824 }
a61af66fc99e Initial load
duke
parents:
diff changeset
825 jint result = UNCHECKED()->EnsureLocalCapacity(env, capacity);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
826 if (result == JNI_OK) {
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
827 thr->active_handles()->set_planned_capacity(capacity + CHECK_JNI_LOCAL_REF_CAP_WARN_THRESHOLD);
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
828 }
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
829 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
830 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
831 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
832
a61af66fc99e Initial load
duke
parents:
diff changeset
833 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
834 checked_jni_AllocObject(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
835 jclass clazz))
a61af66fc99e Initial load
duke
parents:
diff changeset
836 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
837 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
838 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
839 )
a61af66fc99e Initial load
duke
parents:
diff changeset
840 jobject result = UNCHECKED()->AllocObject(env,clazz);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
841 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
842 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
843 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
844
a61af66fc99e Initial load
duke
parents:
diff changeset
845 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
846 checked_jni_NewObject(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
847 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
848 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
849 ...))
a61af66fc99e Initial load
duke
parents:
diff changeset
850 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
851 va_list args;
a61af66fc99e Initial load
duke
parents:
diff changeset
852 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
853 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
854 jniCheck::validate_jmethod_id(thr, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
855 )
a61af66fc99e Initial load
duke
parents:
diff changeset
856 va_start(args, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
857 jobject result = UNCHECKED()->NewObjectV(env,clazz,methodID,args);
a61af66fc99e Initial load
duke
parents:
diff changeset
858 va_end(args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
859 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
860 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
861 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
862
a61af66fc99e Initial load
duke
parents:
diff changeset
863 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
864 checked_jni_NewObjectV(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
865 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
866 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
867 va_list args))
a61af66fc99e Initial load
duke
parents:
diff changeset
868 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
869 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
870 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
871 jniCheck::validate_jmethod_id(thr, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
872 )
a61af66fc99e Initial load
duke
parents:
diff changeset
873 jobject result = UNCHECKED()->NewObjectV(env,clazz,methodID,args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
874 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
875 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
876 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
877
a61af66fc99e Initial load
duke
parents:
diff changeset
878 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
879 checked_jni_NewObjectA(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
880 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
881 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
882 const jvalue *args))
a61af66fc99e Initial load
duke
parents:
diff changeset
883 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
884 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
885 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
886 jniCheck::validate_jmethod_id(thr, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
887 )
a61af66fc99e Initial load
duke
parents:
diff changeset
888 jobject result = UNCHECKED()->NewObjectA(env,clazz,methodID,args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
889 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
890 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
891 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
892
a61af66fc99e Initial load
duke
parents:
diff changeset
893 JNI_ENTRY_CHECKED(jclass,
a61af66fc99e Initial load
duke
parents:
diff changeset
894 checked_jni_GetObjectClass(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
895 jobject obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
896 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
897 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
898 jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
899 )
a61af66fc99e Initial load
duke
parents:
diff changeset
900 jclass result = UNCHECKED()->GetObjectClass(env,obj);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
901 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
902 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
903 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
904
a61af66fc99e Initial load
duke
parents:
diff changeset
905 JNI_ENTRY_CHECKED(jboolean,
a61af66fc99e Initial load
duke
parents:
diff changeset
906 checked_jni_IsInstanceOf(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
907 jobject obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
908 jclass clazz))
a61af66fc99e Initial load
duke
parents:
diff changeset
909 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
910 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
911 jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
912 jniCheck::validate_class(thr, clazz, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
913 )
a61af66fc99e Initial load
duke
parents:
diff changeset
914 jboolean result = UNCHECKED()->IsInstanceOf(env,obj,clazz);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
915 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
916 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
917 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
918
a61af66fc99e Initial load
duke
parents:
diff changeset
919 JNI_ENTRY_CHECKED(jmethodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
920 checked_jni_GetMethodID(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
921 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
922 const char *name,
a61af66fc99e Initial load
duke
parents:
diff changeset
923 const char *sig))
a61af66fc99e Initial load
duke
parents:
diff changeset
924 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
925 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
926 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
927 )
a61af66fc99e Initial load
duke
parents:
diff changeset
928 jmethodID result = UNCHECKED()->GetMethodID(env,clazz,name,sig);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
929 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
930 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
931 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
932
a61af66fc99e Initial load
duke
parents:
diff changeset
933 #define WRAPPER_CallMethod(ResultType, Result) \
a61af66fc99e Initial load
duke
parents:
diff changeset
934 JNI_ENTRY_CHECKED(ResultType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
935 checked_jni_Call##Result##Method(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
936 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
937 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
938 ...)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
939 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
940 va_list args; \
a61af66fc99e Initial load
duke
parents:
diff changeset
941 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
942 jniCheck::validate_call_object(thr, obj, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
943 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
944 va_start(args,methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
945 ResultType result =UNCHECKED()->Call##Result##MethodV(env, obj, methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
946 args); \
a61af66fc99e Initial load
duke
parents:
diff changeset
947 va_end(args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
948 thr->set_pending_jni_exception_check("Call"#Result"Method"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
949 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
950 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
951 JNI_END \
a61af66fc99e Initial load
duke
parents:
diff changeset
952 \
a61af66fc99e Initial load
duke
parents:
diff changeset
953 JNI_ENTRY_CHECKED(ResultType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
954 checked_jni_Call##Result##MethodV(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
955 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
956 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
957 va_list args)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
958 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
959 IN_VM(\
a61af66fc99e Initial load
duke
parents:
diff changeset
960 jniCheck::validate_call_object(thr, obj, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
961 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
962 ResultType result = UNCHECKED()->Call##Result##MethodV(env, obj, methodID,\
a61af66fc99e Initial load
duke
parents:
diff changeset
963 args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
964 thr->set_pending_jni_exception_check("Call"#Result"MethodV"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
965 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
966 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
967 JNI_END \
a61af66fc99e Initial load
duke
parents:
diff changeset
968 \
a61af66fc99e Initial load
duke
parents:
diff changeset
969 JNI_ENTRY_CHECKED(ResultType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
970 checked_jni_Call##Result##MethodA(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
971 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
972 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
973 const jvalue * args)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
974 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
975 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
976 jniCheck::validate_call_object(thr, obj, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
977 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
978 ResultType result = UNCHECKED()->Call##Result##MethodA(env, obj, methodID,\
a61af66fc99e Initial load
duke
parents:
diff changeset
979 args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
980 thr->set_pending_jni_exception_check("Call"#Result"MethodA"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
981 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
982 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
983 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
984
a61af66fc99e Initial load
duke
parents:
diff changeset
985 WRAPPER_CallMethod(jobject,Object)
a61af66fc99e Initial load
duke
parents:
diff changeset
986 WRAPPER_CallMethod(jboolean,Boolean)
a61af66fc99e Initial load
duke
parents:
diff changeset
987 WRAPPER_CallMethod(jbyte,Byte)
a61af66fc99e Initial load
duke
parents:
diff changeset
988 WRAPPER_CallMethod(jshort,Short)
a61af66fc99e Initial load
duke
parents:
diff changeset
989 WRAPPER_CallMethod(jchar,Char)
a61af66fc99e Initial load
duke
parents:
diff changeset
990 WRAPPER_CallMethod(jint,Int)
a61af66fc99e Initial load
duke
parents:
diff changeset
991 WRAPPER_CallMethod(jlong,Long)
a61af66fc99e Initial load
duke
parents:
diff changeset
992 WRAPPER_CallMethod(jfloat,Float)
a61af66fc99e Initial load
duke
parents:
diff changeset
993 WRAPPER_CallMethod(jdouble,Double)
a61af66fc99e Initial load
duke
parents:
diff changeset
994
a61af66fc99e Initial load
duke
parents:
diff changeset
995 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
996 checked_jni_CallVoidMethod(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
997 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
998 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
999 ...))
a61af66fc99e Initial load
duke
parents:
diff changeset
1000 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1001 va_list args;
a61af66fc99e Initial load
duke
parents:
diff changeset
1002 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1003 jniCheck::validate_call_object(thr, obj, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1004 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1005 va_start(args,methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1006 UNCHECKED()->CallVoidMethodV(env,obj,methodID,args);
a61af66fc99e Initial load
duke
parents:
diff changeset
1007 va_end(args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1008 thr->set_pending_jni_exception_check("CallVoidMethod");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1009 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1010 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1011
a61af66fc99e Initial load
duke
parents:
diff changeset
1012 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1013 checked_jni_CallVoidMethodV(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1014 jobject obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
1015 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1016 va_list args))
a61af66fc99e Initial load
duke
parents:
diff changeset
1017 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1018 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1019 jniCheck::validate_call_object(thr, obj, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1020 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1021 UNCHECKED()->CallVoidMethodV(env,obj,methodID,args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1022 thr->set_pending_jni_exception_check("CallVoidMethodV");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1023 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1024 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1025
a61af66fc99e Initial load
duke
parents:
diff changeset
1026 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1027 checked_jni_CallVoidMethodA(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1028 jobject obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
1029 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1030 const jvalue * args))
a61af66fc99e Initial load
duke
parents:
diff changeset
1031 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1032 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1033 jniCheck::validate_call_object(thr, obj, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1034 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1035 UNCHECKED()->CallVoidMethodA(env,obj,methodID,args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1036 thr->set_pending_jni_exception_check("CallVoidMethodA");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1037 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1038 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1039
a61af66fc99e Initial load
duke
parents:
diff changeset
1040 #define WRAPPER_CallNonvirtualMethod(ResultType, Result) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1041 JNI_ENTRY_CHECKED(ResultType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1042 checked_jni_CallNonvirtual##Result##Method(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1043 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1044 jclass clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1045 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1046 ...)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1047 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1048 va_list args; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1049 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1050 jniCheck::validate_call_object(thr, obj, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1051 jniCheck::validate_call_class(thr, clazz, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1052 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1053 va_start(args,methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1054 ResultType result = UNCHECKED()->CallNonvirtual##Result##MethodV(env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1055 obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1056 clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1057 methodID,\
a61af66fc99e Initial load
duke
parents:
diff changeset
1058 args); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1059 va_end(args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1060 thr->set_pending_jni_exception_check("CallNonvirtual"#Result"Method"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1061 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1062 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1063 JNI_END \
a61af66fc99e Initial load
duke
parents:
diff changeset
1064 \
a61af66fc99e Initial load
duke
parents:
diff changeset
1065 JNI_ENTRY_CHECKED(ResultType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1066 checked_jni_CallNonvirtual##Result##MethodV(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1067 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1068 jclass clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1069 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1070 va_list args)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1071 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1072 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1073 jniCheck::validate_call_object(thr, obj, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1074 jniCheck::validate_call_class(thr, clazz, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1075 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1076 ResultType result = UNCHECKED()->CallNonvirtual##Result##MethodV(env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1077 obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1078 clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1079 methodID,\
a61af66fc99e Initial load
duke
parents:
diff changeset
1080 args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1081 thr->set_pending_jni_exception_check("CallNonvirtual"#Result"MethodV"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1082 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1083 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1084 JNI_END \
a61af66fc99e Initial load
duke
parents:
diff changeset
1085 \
a61af66fc99e Initial load
duke
parents:
diff changeset
1086 JNI_ENTRY_CHECKED(ResultType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1087 checked_jni_CallNonvirtual##Result##MethodA(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1088 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1089 jclass clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1090 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1091 const jvalue * args)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1092 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1093 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1094 jniCheck::validate_call_object(thr, obj, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1095 jniCheck::validate_call_class(thr, clazz, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1096 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1097 ResultType result = UNCHECKED()->CallNonvirtual##Result##MethodA(env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1098 obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1099 clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1100 methodID,\
a61af66fc99e Initial load
duke
parents:
diff changeset
1101 args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1102 thr->set_pending_jni_exception_check("CallNonvirtual"#Result"MethodA"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1103 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1104 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1105 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1106
a61af66fc99e Initial load
duke
parents:
diff changeset
1107 WRAPPER_CallNonvirtualMethod(jobject,Object)
a61af66fc99e Initial load
duke
parents:
diff changeset
1108 WRAPPER_CallNonvirtualMethod(jboolean,Boolean)
a61af66fc99e Initial load
duke
parents:
diff changeset
1109 WRAPPER_CallNonvirtualMethod(jbyte,Byte)
a61af66fc99e Initial load
duke
parents:
diff changeset
1110 WRAPPER_CallNonvirtualMethod(jshort,Short)
a61af66fc99e Initial load
duke
parents:
diff changeset
1111 WRAPPER_CallNonvirtualMethod(jchar,Char)
a61af66fc99e Initial load
duke
parents:
diff changeset
1112 WRAPPER_CallNonvirtualMethod(jint,Int)
a61af66fc99e Initial load
duke
parents:
diff changeset
1113 WRAPPER_CallNonvirtualMethod(jlong,Long)
a61af66fc99e Initial load
duke
parents:
diff changeset
1114 WRAPPER_CallNonvirtualMethod(jfloat,Float)
a61af66fc99e Initial load
duke
parents:
diff changeset
1115 WRAPPER_CallNonvirtualMethod(jdouble,Double)
a61af66fc99e Initial load
duke
parents:
diff changeset
1116
a61af66fc99e Initial load
duke
parents:
diff changeset
1117 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1118 checked_jni_CallNonvirtualVoidMethod(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1119 jobject obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
1120 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
1121 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1122 ...))
a61af66fc99e Initial load
duke
parents:
diff changeset
1123 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1124 va_list args;
a61af66fc99e Initial load
duke
parents:
diff changeset
1125 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1126 jniCheck::validate_call_object(thr, obj, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1127 jniCheck::validate_call_class(thr, clazz, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1128 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1129 va_start(args,methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1130 UNCHECKED()->CallNonvirtualVoidMethodV(env,obj,clazz,methodID,args);
a61af66fc99e Initial load
duke
parents:
diff changeset
1131 va_end(args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1132 thr->set_pending_jni_exception_check("CallNonvirtualVoidMethod");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1133 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1134 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1135
a61af66fc99e Initial load
duke
parents:
diff changeset
1136 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1137 checked_jni_CallNonvirtualVoidMethodV(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1138 jobject obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
1139 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
1140 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1141 va_list args))
a61af66fc99e Initial load
duke
parents:
diff changeset
1142 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1143 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1144 jniCheck::validate_call_object(thr, obj, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1145 jniCheck::validate_call_class(thr, clazz, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1146 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1147 UNCHECKED()->CallNonvirtualVoidMethodV(env,obj,clazz,methodID,args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1148 thr->set_pending_jni_exception_check("CallNonvirtualVoidMethodV");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1149 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1150 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1151
a61af66fc99e Initial load
duke
parents:
diff changeset
1152 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1153 checked_jni_CallNonvirtualVoidMethodA(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1154 jobject obj,
a61af66fc99e Initial load
duke
parents:
diff changeset
1155 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
1156 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1157 const jvalue * args))
a61af66fc99e Initial load
duke
parents:
diff changeset
1158 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1159 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1160 jniCheck::validate_call_object(thr, obj, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1161 jniCheck::validate_call_class(thr, clazz, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1162 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1163 UNCHECKED()->CallNonvirtualVoidMethodA(env,obj,clazz,methodID,args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1164 thr->set_pending_jni_exception_check("CallNonvirtualVoidMethodA");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1165 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1166 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1167
a61af66fc99e Initial load
duke
parents:
diff changeset
1168 JNI_ENTRY_CHECKED(jfieldID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1169 checked_jni_GetFieldID(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1170 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
1171 const char *name,
a61af66fc99e Initial load
duke
parents:
diff changeset
1172 const char *sig))
a61af66fc99e Initial load
duke
parents:
diff changeset
1173 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1174 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1175 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
1176 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1177 jfieldID result = UNCHECKED()->GetFieldID(env,clazz,name,sig);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1178 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1179 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1180 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1181
a61af66fc99e Initial load
duke
parents:
diff changeset
1182 #define WRAPPER_GetField(ReturnType,Result,FieldType) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1183 JNI_ENTRY_CHECKED(ReturnType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1184 checked_jni_Get##Result##Field(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1185 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1186 jfieldID fieldID)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1187 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1188 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1189 checkInstanceFieldID(thr, fieldID, obj, FieldType); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1190 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1191 ReturnType result = UNCHECKED()->Get##Result##Field(env,obj,fieldID); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1192 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1193 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1194 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1195
a61af66fc99e Initial load
duke
parents:
diff changeset
1196 WRAPPER_GetField(jobject, Object, T_OBJECT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1197 WRAPPER_GetField(jboolean, Boolean, T_BOOLEAN)
a61af66fc99e Initial load
duke
parents:
diff changeset
1198 WRAPPER_GetField(jbyte, Byte, T_BYTE)
a61af66fc99e Initial load
duke
parents:
diff changeset
1199 WRAPPER_GetField(jshort, Short, T_SHORT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1200 WRAPPER_GetField(jchar, Char, T_CHAR)
a61af66fc99e Initial load
duke
parents:
diff changeset
1201 WRAPPER_GetField(jint, Int, T_INT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1202 WRAPPER_GetField(jlong, Long, T_LONG)
a61af66fc99e Initial load
duke
parents:
diff changeset
1203 WRAPPER_GetField(jfloat, Float, T_FLOAT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1204 WRAPPER_GetField(jdouble, Double, T_DOUBLE)
a61af66fc99e Initial load
duke
parents:
diff changeset
1205
a61af66fc99e Initial load
duke
parents:
diff changeset
1206 #define WRAPPER_SetField(ValueType,Result,FieldType) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1207 JNI_ENTRY_CHECKED(void, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1208 checked_jni_Set##Result##Field(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1209 jobject obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1210 jfieldID fieldID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1211 ValueType val)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1212 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1213 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1214 checkInstanceFieldID(thr, fieldID, obj, FieldType); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1215 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1216 UNCHECKED()->Set##Result##Field(env,obj,fieldID,val); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1217 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1218 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1219
a61af66fc99e Initial load
duke
parents:
diff changeset
1220 WRAPPER_SetField(jobject, Object, T_OBJECT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1221 WRAPPER_SetField(jboolean, Boolean, T_BOOLEAN)
a61af66fc99e Initial load
duke
parents:
diff changeset
1222 WRAPPER_SetField(jbyte, Byte, T_BYTE)
a61af66fc99e Initial load
duke
parents:
diff changeset
1223 WRAPPER_SetField(jshort, Short, T_SHORT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1224 WRAPPER_SetField(jchar, Char, T_CHAR)
a61af66fc99e Initial load
duke
parents:
diff changeset
1225 WRAPPER_SetField(jint, Int, T_INT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1226 WRAPPER_SetField(jlong, Long, T_LONG)
a61af66fc99e Initial load
duke
parents:
diff changeset
1227 WRAPPER_SetField(jfloat, Float, T_FLOAT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1228 WRAPPER_SetField(jdouble, Double, T_DOUBLE)
a61af66fc99e Initial load
duke
parents:
diff changeset
1229
a61af66fc99e Initial load
duke
parents:
diff changeset
1230
a61af66fc99e Initial load
duke
parents:
diff changeset
1231 JNI_ENTRY_CHECKED(jmethodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1232 checked_jni_GetStaticMethodID(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1233 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
1234 const char *name,
a61af66fc99e Initial load
duke
parents:
diff changeset
1235 const char *sig))
a61af66fc99e Initial load
duke
parents:
diff changeset
1236 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1237 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1238 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
1239 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1240 jmethodID result = UNCHECKED()->GetStaticMethodID(env,clazz,name,sig);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1241 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1242 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1243 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1244
a61af66fc99e Initial load
duke
parents:
diff changeset
1245 #define WRAPPER_CallStaticMethod(ReturnType,Result) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1246 JNI_ENTRY_CHECKED(ReturnType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1247 checked_jni_CallStatic##Result##Method(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1248 jclass clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1249 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1250 ...)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1251 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1252 va_list args; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1253 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1254 jniCheck::validate_jmethod_id(thr, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1255 jniCheck::validate_class(thr, clazz, false); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1256 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1257 va_start(args,methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1258 ReturnType result = UNCHECKED()->CallStatic##Result##MethodV(env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1259 clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1260 methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1261 args); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1262 va_end(args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1263 thr->set_pending_jni_exception_check("CallStatic"#Result"Method"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1264 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1265 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1266 JNI_END \
a61af66fc99e Initial load
duke
parents:
diff changeset
1267 \
a61af66fc99e Initial load
duke
parents:
diff changeset
1268 JNI_ENTRY_CHECKED(ReturnType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1269 checked_jni_CallStatic##Result##MethodV(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1270 jclass clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1271 jmethodID methodID,\
a61af66fc99e Initial load
duke
parents:
diff changeset
1272 va_list args)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1273 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1274 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1275 jniCheck::validate_jmethod_id(thr, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1276 jniCheck::validate_class(thr, clazz, false); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1277 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1278 ReturnType result = UNCHECKED()->CallStatic##Result##MethodV(env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1279 clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1280 methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1281 args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1282 thr->set_pending_jni_exception_check("CallStatic"#Result"MethodV"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1283 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1284 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1285 JNI_END \
a61af66fc99e Initial load
duke
parents:
diff changeset
1286 \
a61af66fc99e Initial load
duke
parents:
diff changeset
1287 JNI_ENTRY_CHECKED(ReturnType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1288 checked_jni_CallStatic##Result##MethodA(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1289 jclass clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1290 jmethodID methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1291 const jvalue *args)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1292 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1293 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1294 jniCheck::validate_jmethod_id(thr, methodID); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1295 jniCheck::validate_class(thr, clazz, false); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1296 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1297 ReturnType result = UNCHECKED()->CallStatic##Result##MethodA(env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1298 clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1299 methodID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1300 args); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1301 thr->set_pending_jni_exception_check("CallStatic"#Result"MethodA"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1302 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1303 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1304 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1305
a61af66fc99e Initial load
duke
parents:
diff changeset
1306 WRAPPER_CallStaticMethod(jobject,Object)
a61af66fc99e Initial load
duke
parents:
diff changeset
1307 WRAPPER_CallStaticMethod(jboolean,Boolean)
a61af66fc99e Initial load
duke
parents:
diff changeset
1308 WRAPPER_CallStaticMethod(jbyte,Byte)
a61af66fc99e Initial load
duke
parents:
diff changeset
1309 WRAPPER_CallStaticMethod(jshort,Short)
a61af66fc99e Initial load
duke
parents:
diff changeset
1310 WRAPPER_CallStaticMethod(jchar,Char)
a61af66fc99e Initial load
duke
parents:
diff changeset
1311 WRAPPER_CallStaticMethod(jint,Int)
a61af66fc99e Initial load
duke
parents:
diff changeset
1312 WRAPPER_CallStaticMethod(jlong,Long)
a61af66fc99e Initial load
duke
parents:
diff changeset
1313 WRAPPER_CallStaticMethod(jfloat,Float)
a61af66fc99e Initial load
duke
parents:
diff changeset
1314 WRAPPER_CallStaticMethod(jdouble,Double)
a61af66fc99e Initial load
duke
parents:
diff changeset
1315
a61af66fc99e Initial load
duke
parents:
diff changeset
1316 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1317 checked_jni_CallStaticVoidMethod(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1318 jclass cls,
a61af66fc99e Initial load
duke
parents:
diff changeset
1319 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1320 ...))
a61af66fc99e Initial load
duke
parents:
diff changeset
1321 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1322 va_list args;
a61af66fc99e Initial load
duke
parents:
diff changeset
1323 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1324 jniCheck::validate_jmethod_id(thr, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1325 jniCheck::validate_class(thr, cls, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
1326 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1327 va_start(args,methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1328 UNCHECKED()->CallStaticVoidMethodV(env,cls,methodID,args);
a61af66fc99e Initial load
duke
parents:
diff changeset
1329 va_end(args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1330 thr->set_pending_jni_exception_check("CallStaticVoidMethod");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1331 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1332 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1333
a61af66fc99e Initial load
duke
parents:
diff changeset
1334 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1335 checked_jni_CallStaticVoidMethodV(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1336 jclass cls,
a61af66fc99e Initial load
duke
parents:
diff changeset
1337 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1338 va_list args))
a61af66fc99e Initial load
duke
parents:
diff changeset
1339 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1340 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1341 jniCheck::validate_jmethod_id(thr, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1342 jniCheck::validate_class(thr, cls, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
1343 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1344 UNCHECKED()->CallStaticVoidMethodV(env,cls,methodID,args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1345 thr->set_pending_jni_exception_check("CallStaticVoidMethodV");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1346 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1347 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1348
a61af66fc99e Initial load
duke
parents:
diff changeset
1349 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1350 checked_jni_CallStaticVoidMethodA(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1351 jclass cls,
a61af66fc99e Initial load
duke
parents:
diff changeset
1352 jmethodID methodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1353 const jvalue * args))
a61af66fc99e Initial load
duke
parents:
diff changeset
1354 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1355 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1356 jniCheck::validate_jmethod_id(thr, methodID);
a61af66fc99e Initial load
duke
parents:
diff changeset
1357 jniCheck::validate_class(thr, cls, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
1358 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1359 UNCHECKED()->CallStaticVoidMethodA(env,cls,methodID,args);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1360 thr->set_pending_jni_exception_check("CallStaticVoidMethodA");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1361 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1362 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1363
a61af66fc99e Initial load
duke
parents:
diff changeset
1364 JNI_ENTRY_CHECKED(jfieldID,
a61af66fc99e Initial load
duke
parents:
diff changeset
1365 checked_jni_GetStaticFieldID(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1366 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
1367 const char *name,
a61af66fc99e Initial load
duke
parents:
diff changeset
1368 const char *sig))
a61af66fc99e Initial load
duke
parents:
diff changeset
1369 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1370 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1371 jniCheck::validate_class(thr, clazz, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
1372 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1373 jfieldID result = UNCHECKED()->GetStaticFieldID(env,clazz,name,sig);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1374 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1375 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1376 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1377
a61af66fc99e Initial load
duke
parents:
diff changeset
1378 #define WRAPPER_GetStaticField(ReturnType,Result,FieldType) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1379 JNI_ENTRY_CHECKED(ReturnType, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1380 checked_jni_GetStatic##Result##Field(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1381 jclass clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1382 jfieldID fieldID)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1383 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1384 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1385 jniCheck::validate_class(thr, clazz, false); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1386 checkStaticFieldID(thr, fieldID, clazz, FieldType); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1387 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1388 ReturnType result = UNCHECKED()->GetStatic##Result##Field(env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1389 clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1390 fieldID); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1391 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1392 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1393 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1394
a61af66fc99e Initial load
duke
parents:
diff changeset
1395 WRAPPER_GetStaticField(jobject, Object, T_OBJECT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1396 WRAPPER_GetStaticField(jboolean, Boolean, T_BOOLEAN)
a61af66fc99e Initial load
duke
parents:
diff changeset
1397 WRAPPER_GetStaticField(jbyte, Byte, T_BYTE)
a61af66fc99e Initial load
duke
parents:
diff changeset
1398 WRAPPER_GetStaticField(jshort, Short, T_SHORT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1399 WRAPPER_GetStaticField(jchar, Char, T_CHAR)
a61af66fc99e Initial load
duke
parents:
diff changeset
1400 WRAPPER_GetStaticField(jint, Int, T_INT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1401 WRAPPER_GetStaticField(jlong, Long, T_LONG)
a61af66fc99e Initial load
duke
parents:
diff changeset
1402 WRAPPER_GetStaticField(jfloat, Float, T_FLOAT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1403 WRAPPER_GetStaticField(jdouble, Double, T_DOUBLE)
a61af66fc99e Initial load
duke
parents:
diff changeset
1404
a61af66fc99e Initial load
duke
parents:
diff changeset
1405 #define WRAPPER_SetStaticField(ValueType,Result,FieldType) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1406 JNI_ENTRY_CHECKED(void, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1407 checked_jni_SetStatic##Result##Field(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1408 jclass clazz, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1409 jfieldID fieldID, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1410 ValueType value)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1411 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1412 IN_VM( \
a61af66fc99e Initial load
duke
parents:
diff changeset
1413 jniCheck::validate_class(thr, clazz, false); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1414 checkStaticFieldID(thr, fieldID, clazz, FieldType); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1415 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1416 UNCHECKED()->SetStatic##Result##Field(env,clazz,fieldID,value); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1417 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1418 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1419
a61af66fc99e Initial load
duke
parents:
diff changeset
1420 WRAPPER_SetStaticField(jobject, Object, T_OBJECT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1421 WRAPPER_SetStaticField(jboolean, Boolean, T_BOOLEAN)
a61af66fc99e Initial load
duke
parents:
diff changeset
1422 WRAPPER_SetStaticField(jbyte, Byte, T_BYTE)
a61af66fc99e Initial load
duke
parents:
diff changeset
1423 WRAPPER_SetStaticField(jshort, Short, T_SHORT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1424 WRAPPER_SetStaticField(jchar, Char, T_CHAR)
a61af66fc99e Initial load
duke
parents:
diff changeset
1425 WRAPPER_SetStaticField(jint, Int, T_INT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1426 WRAPPER_SetStaticField(jlong, Long, T_LONG)
a61af66fc99e Initial load
duke
parents:
diff changeset
1427 WRAPPER_SetStaticField(jfloat, Float, T_FLOAT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1428 WRAPPER_SetStaticField(jdouble, Double, T_DOUBLE)
a61af66fc99e Initial load
duke
parents:
diff changeset
1429
a61af66fc99e Initial load
duke
parents:
diff changeset
1430
a61af66fc99e Initial load
duke
parents:
diff changeset
1431 JNI_ENTRY_CHECKED(jstring,
a61af66fc99e Initial load
duke
parents:
diff changeset
1432 checked_jni_NewString(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1433 const jchar *unicode,
a61af66fc99e Initial load
duke
parents:
diff changeset
1434 jsize len))
a61af66fc99e Initial load
duke
parents:
diff changeset
1435 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1436 jstring result = UNCHECKED()->NewString(env,unicode,len);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1437 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1438 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1439 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1440
a61af66fc99e Initial load
duke
parents:
diff changeset
1441 JNI_ENTRY_CHECKED(jsize,
a61af66fc99e Initial load
duke
parents:
diff changeset
1442 checked_jni_GetStringLength(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1443 jstring str))
a61af66fc99e Initial load
duke
parents:
diff changeset
1444 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1445 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1446 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1447 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1448 jsize result = UNCHECKED()->GetStringLength(env,str);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1449 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1450 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1451 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1452
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1453 // Arbitrary (but well-known) tag
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1454 const void* STRING_TAG = (void*)0x47114711;
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1455
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1456 JNI_ENTRY_CHECKED(const jchar *,
a61af66fc99e Initial load
duke
parents:
diff changeset
1457 checked_jni_GetStringChars(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1458 jstring str,
a61af66fc99e Initial load
duke
parents:
diff changeset
1459 jboolean *isCopy))
a61af66fc99e Initial load
duke
parents:
diff changeset
1460 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1461 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1462 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1463 )
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1464 jchar* new_result = NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1465 const jchar *result = UNCHECKED()->GetStringChars(env,str,isCopy);
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1466 assert (isCopy == NULL || *isCopy == JNI_TRUE, "GetStringChars didn't return a copy as expected");
12819
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1467 if (result != NULL) {
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1468 size_t len = UNCHECKED()->GetStringLength(env,str) + 1; // + 1 for NULL termination
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1469 len *= sizeof(jchar);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1470 new_result = (jchar*) GuardedMemory::wrap_copy(result, len, STRING_TAG);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1471 if (new_result == NULL) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1472 vm_exit_out_of_memory(len, OOM_MALLOC_ERROR, "checked_jni_GetStringChars");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1473 }
12819
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1474 // Avoiding call to UNCHECKED()->ReleaseStringChars() since that will fire unexpected dtrace probes
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1475 // Note that the dtrace arguments for the allocated memory will not match up with this solution.
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1476 FreeHeap((char*)result);
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1477 }
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1478 functionExit(thr);
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1479 return new_result;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1480 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1481
a61af66fc99e Initial load
duke
parents:
diff changeset
1482 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1483 checked_jni_ReleaseStringChars(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1484 jstring str,
a61af66fc99e Initial load
duke
parents:
diff changeset
1485 const jchar *chars))
a61af66fc99e Initial load
duke
parents:
diff changeset
1486 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1487 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1488 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1489 )
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1490 if (chars == NULL) {
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1491 // still do the unchecked call to allow dtrace probes
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1492 UNCHECKED()->ReleaseStringChars(env,str,chars);
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1493 }
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1494 else {
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1495 GuardedMemory guarded((void*)chars);
20319
29a5c2fd2d2e 8046662: Check JNI ReleaseStringChars / ReleaseStringUTFChars verify_guards test inverted
dsimms
parents: 20318
diff changeset
1496 if (!guarded.verify_guards()) {
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1497 tty->print_cr("ReleaseStringChars: release chars failed bounds check. "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1498 "string: " PTR_FORMAT " chars: " PTR_FORMAT, p2i(str), p2i(chars));
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1499 guarded.print_on(tty);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1500 NativeReportJNIFatalError(thr, "ReleaseStringChars: "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1501 "release chars failed bounds check.");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1502 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1503 if (guarded.get_tag() != STRING_TAG) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1504 tty->print_cr("ReleaseStringChars: called on something not allocated "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1505 "by GetStringChars. string: " PTR_FORMAT " chars: " PTR_FORMAT,
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1506 p2i(str), p2i(chars));
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1507 NativeReportJNIFatalError(thr, "ReleaseStringChars called on something "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1508 "not allocated by GetStringChars");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1509 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1510 UNCHECKED()->ReleaseStringChars(env, str,
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1511 (const jchar*) guarded.release_for_freeing());
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1512 }
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1513 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1514 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1515
a61af66fc99e Initial load
duke
parents:
diff changeset
1516 JNI_ENTRY_CHECKED(jstring,
a61af66fc99e Initial load
duke
parents:
diff changeset
1517 checked_jni_NewStringUTF(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1518 const char *utf))
a61af66fc99e Initial load
duke
parents:
diff changeset
1519 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1520 jstring result = UNCHECKED()->NewStringUTF(env,utf);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1521 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1522 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1523 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1524
a61af66fc99e Initial load
duke
parents:
diff changeset
1525 JNI_ENTRY_CHECKED(jsize,
a61af66fc99e Initial load
duke
parents:
diff changeset
1526 checked_jni_GetStringUTFLength(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1527 jstring str))
a61af66fc99e Initial load
duke
parents:
diff changeset
1528 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1529 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1530 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1531 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1532 jsize result = UNCHECKED()->GetStringUTFLength(env,str);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1533 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1534 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1535 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1536
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1537 // Arbitrary (but well-known) tag - different than GetStringChars
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1538 const void* STRING_UTF_TAG = (void*) 0x48124812;
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1539
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1540 JNI_ENTRY_CHECKED(const char *,
a61af66fc99e Initial load
duke
parents:
diff changeset
1541 checked_jni_GetStringUTFChars(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1542 jstring str,
a61af66fc99e Initial load
duke
parents:
diff changeset
1543 jboolean *isCopy))
a61af66fc99e Initial load
duke
parents:
diff changeset
1544 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1545 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1546 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1547 )
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1548 char* new_result = NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1549 const char *result = UNCHECKED()->GetStringUTFChars(env,str,isCopy);
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1550 assert (isCopy == NULL || *isCopy == JNI_TRUE, "GetStringUTFChars didn't return a copy as expected");
12819
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1551 if (result != NULL) {
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1552 size_t len = strlen(result) + 1; // + 1 for NULL termination
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1553 new_result = (char*) GuardedMemory::wrap_copy(result, len, STRING_UTF_TAG);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1554 if (new_result == NULL) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1555 vm_exit_out_of_memory(len, OOM_MALLOC_ERROR, "checked_jni_GetStringUTFChars");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1556 }
12819
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1557 // Avoiding call to UNCHECKED()->ReleaseStringUTFChars() since that will fire unexpected dtrace probes
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1558 // Note that the dtrace arguments for the allocated memory will not match up with this solution.
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1559 FreeHeap((char*)result, mtInternal);
f9be370a7d54 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 11150
diff changeset
1560 }
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1561 functionExit(thr);
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1562 return new_result;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1563 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1564
a61af66fc99e Initial load
duke
parents:
diff changeset
1565 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1566 checked_jni_ReleaseStringUTFChars(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1567 jstring str,
a61af66fc99e Initial load
duke
parents:
diff changeset
1568 const char* chars))
a61af66fc99e Initial load
duke
parents:
diff changeset
1569 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1570 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1571 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1572 )
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1573 if (chars == NULL) {
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1574 // still do the unchecked call to allow dtrace probes
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1575 UNCHECKED()->ReleaseStringUTFChars(env,str,chars);
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1576 }
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1577 else {
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1578 GuardedMemory guarded((void*)chars);
20319
29a5c2fd2d2e 8046662: Check JNI ReleaseStringChars / ReleaseStringUTFChars verify_guards test inverted
dsimms
parents: 20318
diff changeset
1579 if (!guarded.verify_guards()) {
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1580 tty->print_cr("ReleaseStringUTFChars: release chars failed bounds check. "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1581 "string: " PTR_FORMAT " chars: " PTR_FORMAT, p2i(str), p2i(chars));
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1582 guarded.print_on(tty);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1583 NativeReportJNIFatalError(thr, "ReleaseStringUTFChars: "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1584 "release chars failed bounds check.");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1585 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1586 if (guarded.get_tag() != STRING_UTF_TAG) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1587 tty->print_cr("ReleaseStringUTFChars: called on something not "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1588 "allocated by GetStringUTFChars. string: " PTR_FORMAT " chars: "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1589 PTR_FORMAT, p2i(str), p2i(chars));
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1590 NativeReportJNIFatalError(thr, "ReleaseStringUTFChars "
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1591 "called on something not allocated by GetStringUTFChars");
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1592 }
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1593 UNCHECKED()->ReleaseStringUTFChars(env, str,
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1594 (const char*) guarded.release_for_freeing());
1989
017cd8bce8a8 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 1972
diff changeset
1595 }
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1596 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1597 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1598
a61af66fc99e Initial load
duke
parents:
diff changeset
1599 JNI_ENTRY_CHECKED(jsize,
a61af66fc99e Initial load
duke
parents:
diff changeset
1600 checked_jni_GetArrayLength(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1601 jarray array))
a61af66fc99e Initial load
duke
parents:
diff changeset
1602 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1603 IN_VM(
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1604 check_is_array(thr, array);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1605 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1606 jsize result = UNCHECKED()->GetArrayLength(env,array);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1607 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1608 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1609 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1610
a61af66fc99e Initial load
duke
parents:
diff changeset
1611 JNI_ENTRY_CHECKED(jobjectArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
1612 checked_jni_NewObjectArray(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1613 jsize len,
a61af66fc99e Initial load
duke
parents:
diff changeset
1614 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
1615 jobject init))
a61af66fc99e Initial load
duke
parents:
diff changeset
1616 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1617 jobjectArray result = UNCHECKED()->NewObjectArray(env,len,clazz,init);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1618 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1619 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1620 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1621
a61af66fc99e Initial load
duke
parents:
diff changeset
1622 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
1623 checked_jni_GetObjectArrayElement(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1624 jobjectArray array,
a61af66fc99e Initial load
duke
parents:
diff changeset
1625 jsize index))
a61af66fc99e Initial load
duke
parents:
diff changeset
1626 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1627 IN_VM(
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1628 check_is_obj_array(thr, array);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1629 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1630 jobject result = UNCHECKED()->GetObjectArrayElement(env,array,index);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1631 thr->set_pending_jni_exception_check("GetObjectArrayElement");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1632 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1633 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1634 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1635
a61af66fc99e Initial load
duke
parents:
diff changeset
1636 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1637 checked_jni_SetObjectArrayElement(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1638 jobjectArray array,
a61af66fc99e Initial load
duke
parents:
diff changeset
1639 jsize index,
a61af66fc99e Initial load
duke
parents:
diff changeset
1640 jobject val))
a61af66fc99e Initial load
duke
parents:
diff changeset
1641 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1642 IN_VM(
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1643 check_is_obj_array(thr, array);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1644 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1645 UNCHECKED()->SetObjectArrayElement(env,array,index,val);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1646 thr->set_pending_jni_exception_check("SetObjectArrayElement");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1647 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1648 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1649
a61af66fc99e Initial load
duke
parents:
diff changeset
1650 #define WRAPPER_NewScalarArray(Return, Result) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1651 JNI_ENTRY_CHECKED(Return, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1652 checked_jni_New##Result##Array(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1653 jsize len)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1654 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1655 Return result = UNCHECKED()->New##Result##Array(env,len); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1656 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1657 return (Return) result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1658 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1659
a61af66fc99e Initial load
duke
parents:
diff changeset
1660 WRAPPER_NewScalarArray(jbooleanArray, Boolean)
a61af66fc99e Initial load
duke
parents:
diff changeset
1661 WRAPPER_NewScalarArray(jbyteArray, Byte)
a61af66fc99e Initial load
duke
parents:
diff changeset
1662 WRAPPER_NewScalarArray(jshortArray, Short)
a61af66fc99e Initial load
duke
parents:
diff changeset
1663 WRAPPER_NewScalarArray(jcharArray, Char)
a61af66fc99e Initial load
duke
parents:
diff changeset
1664 WRAPPER_NewScalarArray(jintArray, Int)
a61af66fc99e Initial load
duke
parents:
diff changeset
1665 WRAPPER_NewScalarArray(jlongArray, Long)
a61af66fc99e Initial load
duke
parents:
diff changeset
1666 WRAPPER_NewScalarArray(jfloatArray, Float)
a61af66fc99e Initial load
duke
parents:
diff changeset
1667 WRAPPER_NewScalarArray(jdoubleArray, Double)
a61af66fc99e Initial load
duke
parents:
diff changeset
1668
a61af66fc99e Initial load
duke
parents:
diff changeset
1669 #define WRAPPER_GetScalarArrayElements(ElementTag,ElementType,Result) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1670 JNI_ENTRY_CHECKED(ElementType *, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1671 checked_jni_Get##Result##ArrayElements(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1672 ElementType##Array array, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1673 jboolean *isCopy)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1674 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1675 IN_VM( \
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1676 check_primitive_array_type(thr, array, ElementTag); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1677 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1678 ElementType *result = UNCHECKED()->Get##Result##ArrayElements(env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1679 array, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1680 isCopy); \
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1681 if (result != NULL) { \
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1682 result = (ElementType *) check_jni_wrap_copy_array(thr, array, result); \
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1683 } \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1684 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1685 return result; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1686 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1687
a61af66fc99e Initial load
duke
parents:
diff changeset
1688 WRAPPER_GetScalarArrayElements(T_BOOLEAN, jboolean, Boolean)
a61af66fc99e Initial load
duke
parents:
diff changeset
1689 WRAPPER_GetScalarArrayElements(T_BYTE, jbyte, Byte)
a61af66fc99e Initial load
duke
parents:
diff changeset
1690 WRAPPER_GetScalarArrayElements(T_SHORT, jshort, Short)
a61af66fc99e Initial load
duke
parents:
diff changeset
1691 WRAPPER_GetScalarArrayElements(T_CHAR, jchar, Char)
a61af66fc99e Initial load
duke
parents:
diff changeset
1692 WRAPPER_GetScalarArrayElements(T_INT, jint, Int)
a61af66fc99e Initial load
duke
parents:
diff changeset
1693 WRAPPER_GetScalarArrayElements(T_LONG, jlong, Long)
a61af66fc99e Initial load
duke
parents:
diff changeset
1694 WRAPPER_GetScalarArrayElements(T_FLOAT, jfloat, Float)
a61af66fc99e Initial load
duke
parents:
diff changeset
1695 WRAPPER_GetScalarArrayElements(T_DOUBLE, jdouble, Double)
a61af66fc99e Initial load
duke
parents:
diff changeset
1696
a61af66fc99e Initial load
duke
parents:
diff changeset
1697 #define WRAPPER_ReleaseScalarArrayElements(ElementTag,ElementType,Result,Tag) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1698 JNI_ENTRY_CHECKED(void, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1699 checked_jni_Release##Result##ArrayElements(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1700 ElementType##Array array, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1701 ElementType *elems, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1702 jint mode)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1703 functionEnterExceptionAllowed(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1704 IN_VM( \
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1705 check_primitive_array_type(thr, array, ElementTag); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1706 ASSERT_OOPS_ALLOWED; \
a61af66fc99e Initial load
duke
parents:
diff changeset
1707 typeArrayOop a = typeArrayOop(JNIHandles::resolve_non_null(array)); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1708 ) \
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1709 ElementType* orig_result = (ElementType *) check_wrapped_array_release( \
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1710 thr, "checked_jni_Release"#Result"ArrayElements", array, elems, mode); \
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1711 UNCHECKED()->Release##Result##ArrayElements(env, array, orig_result, mode); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1712 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1713 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1714
a61af66fc99e Initial load
duke
parents:
diff changeset
1715 WRAPPER_ReleaseScalarArrayElements(T_BOOLEAN,jboolean, Boolean, bool)
a61af66fc99e Initial load
duke
parents:
diff changeset
1716 WRAPPER_ReleaseScalarArrayElements(T_BYTE, jbyte, Byte, byte)
a61af66fc99e Initial load
duke
parents:
diff changeset
1717 WRAPPER_ReleaseScalarArrayElements(T_SHORT, jshort, Short, short)
a61af66fc99e Initial load
duke
parents:
diff changeset
1718 WRAPPER_ReleaseScalarArrayElements(T_CHAR, jchar, Char, char)
a61af66fc99e Initial load
duke
parents:
diff changeset
1719 WRAPPER_ReleaseScalarArrayElements(T_INT, jint, Int, int)
a61af66fc99e Initial load
duke
parents:
diff changeset
1720 WRAPPER_ReleaseScalarArrayElements(T_LONG, jlong, Long, long)
a61af66fc99e Initial load
duke
parents:
diff changeset
1721 WRAPPER_ReleaseScalarArrayElements(T_FLOAT, jfloat, Float, float)
a61af66fc99e Initial load
duke
parents:
diff changeset
1722 WRAPPER_ReleaseScalarArrayElements(T_DOUBLE, jdouble, Double, double)
a61af66fc99e Initial load
duke
parents:
diff changeset
1723
a61af66fc99e Initial load
duke
parents:
diff changeset
1724 #define WRAPPER_GetScalarArrayRegion(ElementTag,ElementType,Result) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1725 JNI_ENTRY_CHECKED(void, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1726 checked_jni_Get##Result##ArrayRegion(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1727 ElementType##Array array, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1728 jsize start, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1729 jsize len, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1730 ElementType *buf)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1731 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1732 IN_VM( \
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1733 check_primitive_array_type(thr, array, ElementTag); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1734 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1735 UNCHECKED()->Get##Result##ArrayRegion(env,array,start,len,buf); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1736 thr->set_pending_jni_exception_check("Get"#Result"ArrayRegion"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1737 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1738 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1739
a61af66fc99e Initial load
duke
parents:
diff changeset
1740 WRAPPER_GetScalarArrayRegion(T_BOOLEAN, jboolean, Boolean)
a61af66fc99e Initial load
duke
parents:
diff changeset
1741 WRAPPER_GetScalarArrayRegion(T_BYTE, jbyte, Byte)
a61af66fc99e Initial load
duke
parents:
diff changeset
1742 WRAPPER_GetScalarArrayRegion(T_SHORT, jshort, Short)
a61af66fc99e Initial load
duke
parents:
diff changeset
1743 WRAPPER_GetScalarArrayRegion(T_CHAR, jchar, Char)
a61af66fc99e Initial load
duke
parents:
diff changeset
1744 WRAPPER_GetScalarArrayRegion(T_INT, jint, Int)
a61af66fc99e Initial load
duke
parents:
diff changeset
1745 WRAPPER_GetScalarArrayRegion(T_LONG, jlong, Long)
a61af66fc99e Initial load
duke
parents:
diff changeset
1746 WRAPPER_GetScalarArrayRegion(T_FLOAT, jfloat, Float)
a61af66fc99e Initial load
duke
parents:
diff changeset
1747 WRAPPER_GetScalarArrayRegion(T_DOUBLE, jdouble, Double)
a61af66fc99e Initial load
duke
parents:
diff changeset
1748
a61af66fc99e Initial load
duke
parents:
diff changeset
1749 #define WRAPPER_SetScalarArrayRegion(ElementTag,ElementType,Result) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1750 JNI_ENTRY_CHECKED(void, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1751 checked_jni_Set##Result##ArrayRegion(JNIEnv *env, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1752 ElementType##Array array, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1753 jsize start, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1754 jsize len, \
a61af66fc99e Initial load
duke
parents:
diff changeset
1755 const ElementType *buf)) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1756 functionEnter(thr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
1757 IN_VM( \
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1758 check_primitive_array_type(thr, array, ElementTag); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1759 ) \
a61af66fc99e Initial load
duke
parents:
diff changeset
1760 UNCHECKED()->Set##Result##ArrayRegion(env,array,start,len,buf); \
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1761 thr->set_pending_jni_exception_check("Set"#Result"ArrayRegion"); \
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1762 functionExit(thr); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1763 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1764
a61af66fc99e Initial load
duke
parents:
diff changeset
1765 WRAPPER_SetScalarArrayRegion(T_BOOLEAN, jboolean, Boolean)
a61af66fc99e Initial load
duke
parents:
diff changeset
1766 WRAPPER_SetScalarArrayRegion(T_BYTE, jbyte, Byte)
a61af66fc99e Initial load
duke
parents:
diff changeset
1767 WRAPPER_SetScalarArrayRegion(T_SHORT, jshort, Short)
a61af66fc99e Initial load
duke
parents:
diff changeset
1768 WRAPPER_SetScalarArrayRegion(T_CHAR, jchar, Char)
a61af66fc99e Initial load
duke
parents:
diff changeset
1769 WRAPPER_SetScalarArrayRegion(T_INT, jint, Int)
a61af66fc99e Initial load
duke
parents:
diff changeset
1770 WRAPPER_SetScalarArrayRegion(T_LONG, jlong, Long)
a61af66fc99e Initial load
duke
parents:
diff changeset
1771 WRAPPER_SetScalarArrayRegion(T_FLOAT, jfloat, Float)
a61af66fc99e Initial load
duke
parents:
diff changeset
1772 WRAPPER_SetScalarArrayRegion(T_DOUBLE, jdouble, Double)
a61af66fc99e Initial load
duke
parents:
diff changeset
1773
a61af66fc99e Initial load
duke
parents:
diff changeset
1774 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
1775 checked_jni_RegisterNatives(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1776 jclass clazz,
a61af66fc99e Initial load
duke
parents:
diff changeset
1777 const JNINativeMethod *methods,
a61af66fc99e Initial load
duke
parents:
diff changeset
1778 jint nMethods))
a61af66fc99e Initial load
duke
parents:
diff changeset
1779 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1780 jint result = UNCHECKED()->RegisterNatives(env,clazz,methods,nMethods);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1781 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1782 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1783 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1784
a61af66fc99e Initial load
duke
parents:
diff changeset
1785 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
1786 checked_jni_UnregisterNatives(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1787 jclass clazz))
a61af66fc99e Initial load
duke
parents:
diff changeset
1788 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1789 jint result = UNCHECKED()->UnregisterNatives(env,clazz);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1790 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1791 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1792 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1793
a61af66fc99e Initial load
duke
parents:
diff changeset
1794 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
1795 checked_jni_MonitorEnter(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1796 jobject obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
1797 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1798 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1799 jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
1800 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1801 jint result = UNCHECKED()->MonitorEnter(env,obj);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1802 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1803 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1804 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1805
a61af66fc99e Initial load
duke
parents:
diff changeset
1806 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
1807 checked_jni_MonitorExit(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1808 jobject obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
1809 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1810 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1811 jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
1812 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1813 jint result = UNCHECKED()->MonitorExit(env,obj);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1814 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1815 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1816 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1817
a61af66fc99e Initial load
duke
parents:
diff changeset
1818 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
1819 checked_jni_GetJavaVM(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1820 JavaVM **vm))
a61af66fc99e Initial load
duke
parents:
diff changeset
1821 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1822 jint result = UNCHECKED()->GetJavaVM(env,vm);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1823 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1824 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1825 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1826
a61af66fc99e Initial load
duke
parents:
diff changeset
1827 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1828 checked_jni_GetStringRegion(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1829 jstring str,
a61af66fc99e Initial load
duke
parents:
diff changeset
1830 jsize start,
a61af66fc99e Initial load
duke
parents:
diff changeset
1831 jsize len,
a61af66fc99e Initial load
duke
parents:
diff changeset
1832 jchar *buf))
a61af66fc99e Initial load
duke
parents:
diff changeset
1833 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1834 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1835 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1836 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1837 UNCHECKED()->GetStringRegion(env, str, start, len, buf);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1838 thr->set_pending_jni_exception_check("GetStringRegion");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1839 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1840 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1841
a61af66fc99e Initial load
duke
parents:
diff changeset
1842 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1843 checked_jni_GetStringUTFRegion(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1844 jstring str,
a61af66fc99e Initial load
duke
parents:
diff changeset
1845 jsize start,
a61af66fc99e Initial load
duke
parents:
diff changeset
1846 jsize len,
a61af66fc99e Initial load
duke
parents:
diff changeset
1847 char *buf))
a61af66fc99e Initial load
duke
parents:
diff changeset
1848 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1849 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1850 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1851 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1852 UNCHECKED()->GetStringUTFRegion(env, str, start, len, buf);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1853 thr->set_pending_jni_exception_check("GetStringUTFRegion");
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1854 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1855 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1856
a61af66fc99e Initial load
duke
parents:
diff changeset
1857 JNI_ENTRY_CHECKED(void *,
a61af66fc99e Initial load
duke
parents:
diff changeset
1858 checked_jni_GetPrimitiveArrayCritical(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1859 jarray array,
a61af66fc99e Initial load
duke
parents:
diff changeset
1860 jboolean *isCopy))
a61af66fc99e Initial load
duke
parents:
diff changeset
1861 functionEnterCritical(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1862 IN_VM(
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1863 check_is_primitive_array(thr, array);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1864 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1865 void *result = UNCHECKED()->GetPrimitiveArrayCritical(env, array, isCopy);
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1866 if (result != NULL) {
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1867 result = check_jni_wrap_copy_array(thr, array, result);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1868 }
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1869 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1870 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1871 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1872
a61af66fc99e Initial load
duke
parents:
diff changeset
1873 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1874 checked_jni_ReleasePrimitiveArrayCritical(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1875 jarray array,
a61af66fc99e Initial load
duke
parents:
diff changeset
1876 void *carray,
a61af66fc99e Initial load
duke
parents:
diff changeset
1877 jint mode))
a61af66fc99e Initial load
duke
parents:
diff changeset
1878 functionEnterCriticalExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1879 IN_VM(
11145
39deebbc90b3 6671508: JNI GetPrimitiveArrayCritical should not be callable on object arrays
mgerdin
parents: 6983
diff changeset
1880 check_is_primitive_array(thr, array);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1881 )
20318
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1882 // Check the element array...
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1883 void* orig_result = check_wrapped_array_release(thr, "ReleasePrimitiveArrayCritical", array, carray, mode);
fa62fb12cdca 6311046: -Xcheck:jni should support checking of GetPrimitiveArrayCritical.
dsimms
parents: 20197
diff changeset
1884 UNCHECKED()->ReleasePrimitiveArrayCritical(env, array, orig_result, mode);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1885 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1886 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1887
a61af66fc99e Initial load
duke
parents:
diff changeset
1888 JNI_ENTRY_CHECKED(const jchar*,
a61af66fc99e Initial load
duke
parents:
diff changeset
1889 checked_jni_GetStringCritical(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1890 jstring string,
a61af66fc99e Initial load
duke
parents:
diff changeset
1891 jboolean *isCopy))
a61af66fc99e Initial load
duke
parents:
diff changeset
1892 functionEnterCritical(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1893 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1894 checkString(thr, string);
a61af66fc99e Initial load
duke
parents:
diff changeset
1895 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1896 const jchar *result = UNCHECKED()->GetStringCritical(env, string, isCopy);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1897 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1898 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1899 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1900
a61af66fc99e Initial load
duke
parents:
diff changeset
1901 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1902 checked_jni_ReleaseStringCritical(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1903 jstring str,
a61af66fc99e Initial load
duke
parents:
diff changeset
1904 const jchar *chars))
a61af66fc99e Initial load
duke
parents:
diff changeset
1905 functionEnterCriticalExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1906 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1907 checkString(thr, str);
a61af66fc99e Initial load
duke
parents:
diff changeset
1908 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1909 /* The Hotspot JNI code does not use the parameters, so just check the
a61af66fc99e Initial load
duke
parents:
diff changeset
1910 * string parameter as a minor sanity check
a61af66fc99e Initial load
duke
parents:
diff changeset
1911 */
a61af66fc99e Initial load
duke
parents:
diff changeset
1912 UNCHECKED()->ReleaseStringCritical(env, str, chars);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1913 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1914 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1915
a61af66fc99e Initial load
duke
parents:
diff changeset
1916 JNI_ENTRY_CHECKED(jweak,
a61af66fc99e Initial load
duke
parents:
diff changeset
1917 checked_jni_NewWeakGlobalRef(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1918 jobject obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
1919 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1920 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1921 if (obj != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1922 jniCheck::validate_handle(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
1923 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1924 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1925 jweak result = UNCHECKED()->NewWeakGlobalRef(env, obj);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1926 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1927 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1928 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1929
a61af66fc99e Initial load
duke
parents:
diff changeset
1930 JNI_ENTRY_CHECKED(void,
a61af66fc99e Initial load
duke
parents:
diff changeset
1931 checked_jni_DeleteWeakGlobalRef(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1932 jweak ref))
a61af66fc99e Initial load
duke
parents:
diff changeset
1933 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1934 UNCHECKED()->DeleteWeakGlobalRef(env, ref);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1935 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1936 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1937
a61af66fc99e Initial load
duke
parents:
diff changeset
1938 JNI_ENTRY_CHECKED(jboolean,
a61af66fc99e Initial load
duke
parents:
diff changeset
1939 checked_jni_ExceptionCheck(JNIEnv *env))
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1940 thr->clear_pending_jni_exception_check();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1941 functionEnterExceptionAllowed(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1942 jboolean result = UNCHECKED()->ExceptionCheck(env);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1943 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1944 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1945 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1946
a61af66fc99e Initial load
duke
parents:
diff changeset
1947 JNI_ENTRY_CHECKED(jobject,
a61af66fc99e Initial load
duke
parents:
diff changeset
1948 checked_jni_NewDirectByteBuffer(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1949 void *address,
a61af66fc99e Initial load
duke
parents:
diff changeset
1950 jlong capacity))
a61af66fc99e Initial load
duke
parents:
diff changeset
1951 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1952 jobject result = UNCHECKED()->NewDirectByteBuffer(env, address, capacity);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1953 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1954 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1955 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1956
a61af66fc99e Initial load
duke
parents:
diff changeset
1957 JNI_ENTRY_CHECKED(void *,
a61af66fc99e Initial load
duke
parents:
diff changeset
1958 checked_jni_GetDirectBufferAddress(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1959 jobject buf))
a61af66fc99e Initial load
duke
parents:
diff changeset
1960 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1961 void* result = UNCHECKED()->GetDirectBufferAddress(env, buf);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1962 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1963 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1964 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1965
a61af66fc99e Initial load
duke
parents:
diff changeset
1966 JNI_ENTRY_CHECKED(jlong,
a61af66fc99e Initial load
duke
parents:
diff changeset
1967 checked_jni_GetDirectBufferCapacity(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1968 jobject buf))
a61af66fc99e Initial load
duke
parents:
diff changeset
1969 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1970 jlong result = UNCHECKED()->GetDirectBufferCapacity(env, buf);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1971 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1972 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1973 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1974
a61af66fc99e Initial load
duke
parents:
diff changeset
1975 JNI_ENTRY_CHECKED(jobjectRefType,
a61af66fc99e Initial load
duke
parents:
diff changeset
1976 checked_jni_GetObjectRefType(JNIEnv *env,
a61af66fc99e Initial load
duke
parents:
diff changeset
1977 jobject obj))
a61af66fc99e Initial load
duke
parents:
diff changeset
1978 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1979 /* validate the object being passed */
a61af66fc99e Initial load
duke
parents:
diff changeset
1980 IN_VM(
a61af66fc99e Initial load
duke
parents:
diff changeset
1981 jniCheck::validate_object(thr, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
1982 )
a61af66fc99e Initial load
duke
parents:
diff changeset
1983 jobjectRefType result = UNCHECKED()->GetObjectRefType(env, obj);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1984 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1985 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1986 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1987
a61af66fc99e Initial load
duke
parents:
diff changeset
1988
a61af66fc99e Initial load
duke
parents:
diff changeset
1989 JNI_ENTRY_CHECKED(jint,
a61af66fc99e Initial load
duke
parents:
diff changeset
1990 checked_jni_GetVersion(JNIEnv *env))
a61af66fc99e Initial load
duke
parents:
diff changeset
1991 functionEnter(thr);
a61af66fc99e Initial load
duke
parents:
diff changeset
1992 jint result = UNCHECKED()->GetVersion(env);
22877
d68158e12cea 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
poonam
parents: 20319
diff changeset
1993 functionExit(thr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1994 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
1995 JNI_END
a61af66fc99e Initial load
duke
parents:
diff changeset
1996
a61af66fc99e Initial load
duke
parents:
diff changeset
1997
a61af66fc99e Initial load
duke
parents:
diff changeset
1998
a61af66fc99e Initial load
duke
parents:
diff changeset
1999 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
2000 * Structure containing all checked jni functions
a61af66fc99e Initial load
duke
parents:
diff changeset
2001 */
a61af66fc99e Initial load
duke
parents:
diff changeset
2002 struct JNINativeInterface_ checked_jni_NativeInterface = {
a61af66fc99e Initial load
duke
parents:
diff changeset
2003 NULL,
a61af66fc99e Initial load
duke
parents:
diff changeset
2004 NULL,
a61af66fc99e Initial load
duke
parents:
diff changeset
2005 NULL,
a61af66fc99e Initial load
duke
parents:
diff changeset
2006
a61af66fc99e Initial load
duke
parents:
diff changeset
2007 NULL,
a61af66fc99e Initial load
duke
parents:
diff changeset
2008
a61af66fc99e Initial load
duke
parents:
diff changeset
2009 checked_jni_GetVersion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2010
a61af66fc99e Initial load
duke
parents:
diff changeset
2011 checked_jni_DefineClass,
a61af66fc99e Initial load
duke
parents:
diff changeset
2012 checked_jni_FindClass,
a61af66fc99e Initial load
duke
parents:
diff changeset
2013
a61af66fc99e Initial load
duke
parents:
diff changeset
2014 checked_jni_FromReflectedMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2015 checked_jni_FromReflectedField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2016
a61af66fc99e Initial load
duke
parents:
diff changeset
2017 checked_jni_ToReflectedMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2018
a61af66fc99e Initial load
duke
parents:
diff changeset
2019 checked_jni_GetSuperclass,
a61af66fc99e Initial load
duke
parents:
diff changeset
2020 checked_jni_IsAssignableFrom,
a61af66fc99e Initial load
duke
parents:
diff changeset
2021
a61af66fc99e Initial load
duke
parents:
diff changeset
2022 checked_jni_ToReflectedField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2023
a61af66fc99e Initial load
duke
parents:
diff changeset
2024 checked_jni_Throw,
a61af66fc99e Initial load
duke
parents:
diff changeset
2025 checked_jni_ThrowNew,
a61af66fc99e Initial load
duke
parents:
diff changeset
2026 checked_jni_ExceptionOccurred,
a61af66fc99e Initial load
duke
parents:
diff changeset
2027 checked_jni_ExceptionDescribe,
a61af66fc99e Initial load
duke
parents:
diff changeset
2028 checked_jni_ExceptionClear,
a61af66fc99e Initial load
duke
parents:
diff changeset
2029 checked_jni_FatalError,
a61af66fc99e Initial load
duke
parents:
diff changeset
2030
a61af66fc99e Initial load
duke
parents:
diff changeset
2031 checked_jni_PushLocalFrame,
a61af66fc99e Initial load
duke
parents:
diff changeset
2032 checked_jni_PopLocalFrame,
a61af66fc99e Initial load
duke
parents:
diff changeset
2033
a61af66fc99e Initial load
duke
parents:
diff changeset
2034 checked_jni_NewGlobalRef,
a61af66fc99e Initial load
duke
parents:
diff changeset
2035 checked_jni_DeleteGlobalRef,
a61af66fc99e Initial load
duke
parents:
diff changeset
2036 checked_jni_DeleteLocalRef,
a61af66fc99e Initial load
duke
parents:
diff changeset
2037 checked_jni_IsSameObject,
a61af66fc99e Initial load
duke
parents:
diff changeset
2038
a61af66fc99e Initial load
duke
parents:
diff changeset
2039 checked_jni_NewLocalRef,
a61af66fc99e Initial load
duke
parents:
diff changeset
2040 checked_jni_EnsureLocalCapacity,
a61af66fc99e Initial load
duke
parents:
diff changeset
2041
a61af66fc99e Initial load
duke
parents:
diff changeset
2042 checked_jni_AllocObject,
a61af66fc99e Initial load
duke
parents:
diff changeset
2043 checked_jni_NewObject,
a61af66fc99e Initial load
duke
parents:
diff changeset
2044 checked_jni_NewObjectV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2045 checked_jni_NewObjectA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2046
a61af66fc99e Initial load
duke
parents:
diff changeset
2047 checked_jni_GetObjectClass,
a61af66fc99e Initial load
duke
parents:
diff changeset
2048 checked_jni_IsInstanceOf,
a61af66fc99e Initial load
duke
parents:
diff changeset
2049
a61af66fc99e Initial load
duke
parents:
diff changeset
2050 checked_jni_GetMethodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
2051
a61af66fc99e Initial load
duke
parents:
diff changeset
2052 checked_jni_CallObjectMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2053 checked_jni_CallObjectMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2054 checked_jni_CallObjectMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2055 checked_jni_CallBooleanMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2056 checked_jni_CallBooleanMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2057 checked_jni_CallBooleanMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2058 checked_jni_CallByteMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2059 checked_jni_CallByteMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2060 checked_jni_CallByteMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2061 checked_jni_CallCharMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2062 checked_jni_CallCharMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2063 checked_jni_CallCharMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2064 checked_jni_CallShortMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2065 checked_jni_CallShortMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2066 checked_jni_CallShortMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2067 checked_jni_CallIntMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2068 checked_jni_CallIntMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2069 checked_jni_CallIntMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2070 checked_jni_CallLongMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2071 checked_jni_CallLongMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2072 checked_jni_CallLongMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2073 checked_jni_CallFloatMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2074 checked_jni_CallFloatMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2075 checked_jni_CallFloatMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2076 checked_jni_CallDoubleMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2077 checked_jni_CallDoubleMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2078 checked_jni_CallDoubleMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2079 checked_jni_CallVoidMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2080 checked_jni_CallVoidMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2081 checked_jni_CallVoidMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2082
a61af66fc99e Initial load
duke
parents:
diff changeset
2083 checked_jni_CallNonvirtualObjectMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2084 checked_jni_CallNonvirtualObjectMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2085 checked_jni_CallNonvirtualObjectMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2086 checked_jni_CallNonvirtualBooleanMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2087 checked_jni_CallNonvirtualBooleanMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2088 checked_jni_CallNonvirtualBooleanMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2089 checked_jni_CallNonvirtualByteMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2090 checked_jni_CallNonvirtualByteMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2091 checked_jni_CallNonvirtualByteMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2092 checked_jni_CallNonvirtualCharMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2093 checked_jni_CallNonvirtualCharMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2094 checked_jni_CallNonvirtualCharMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2095 checked_jni_CallNonvirtualShortMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2096 checked_jni_CallNonvirtualShortMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2097 checked_jni_CallNonvirtualShortMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2098 checked_jni_CallNonvirtualIntMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2099 checked_jni_CallNonvirtualIntMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2100 checked_jni_CallNonvirtualIntMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2101 checked_jni_CallNonvirtualLongMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2102 checked_jni_CallNonvirtualLongMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2103 checked_jni_CallNonvirtualLongMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2104 checked_jni_CallNonvirtualFloatMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2105 checked_jni_CallNonvirtualFloatMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2106 checked_jni_CallNonvirtualFloatMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2107 checked_jni_CallNonvirtualDoubleMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2108 checked_jni_CallNonvirtualDoubleMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2109 checked_jni_CallNonvirtualDoubleMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2110 checked_jni_CallNonvirtualVoidMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2111 checked_jni_CallNonvirtualVoidMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2112 checked_jni_CallNonvirtualVoidMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2113
a61af66fc99e Initial load
duke
parents:
diff changeset
2114 checked_jni_GetFieldID,
a61af66fc99e Initial load
duke
parents:
diff changeset
2115
a61af66fc99e Initial load
duke
parents:
diff changeset
2116 checked_jni_GetObjectField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2117 checked_jni_GetBooleanField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2118 checked_jni_GetByteField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2119 checked_jni_GetCharField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2120 checked_jni_GetShortField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2121 checked_jni_GetIntField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2122 checked_jni_GetLongField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2123 checked_jni_GetFloatField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2124 checked_jni_GetDoubleField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2125
a61af66fc99e Initial load
duke
parents:
diff changeset
2126 checked_jni_SetObjectField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2127 checked_jni_SetBooleanField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2128 checked_jni_SetByteField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2129 checked_jni_SetCharField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2130 checked_jni_SetShortField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2131 checked_jni_SetIntField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2132 checked_jni_SetLongField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2133 checked_jni_SetFloatField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2134 checked_jni_SetDoubleField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2135
a61af66fc99e Initial load
duke
parents:
diff changeset
2136 checked_jni_GetStaticMethodID,
a61af66fc99e Initial load
duke
parents:
diff changeset
2137
a61af66fc99e Initial load
duke
parents:
diff changeset
2138 checked_jni_CallStaticObjectMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2139 checked_jni_CallStaticObjectMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2140 checked_jni_CallStaticObjectMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2141 checked_jni_CallStaticBooleanMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2142 checked_jni_CallStaticBooleanMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2143 checked_jni_CallStaticBooleanMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2144 checked_jni_CallStaticByteMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2145 checked_jni_CallStaticByteMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2146 checked_jni_CallStaticByteMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2147 checked_jni_CallStaticCharMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2148 checked_jni_CallStaticCharMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2149 checked_jni_CallStaticCharMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2150 checked_jni_CallStaticShortMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2151 checked_jni_CallStaticShortMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2152 checked_jni_CallStaticShortMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2153 checked_jni_CallStaticIntMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2154 checked_jni_CallStaticIntMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2155 checked_jni_CallStaticIntMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2156 checked_jni_CallStaticLongMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2157 checked_jni_CallStaticLongMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2158 checked_jni_CallStaticLongMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2159 checked_jni_CallStaticFloatMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2160 checked_jni_CallStaticFloatMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2161 checked_jni_CallStaticFloatMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2162 checked_jni_CallStaticDoubleMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2163 checked_jni_CallStaticDoubleMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2164 checked_jni_CallStaticDoubleMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2165 checked_jni_CallStaticVoidMethod,
a61af66fc99e Initial load
duke
parents:
diff changeset
2166 checked_jni_CallStaticVoidMethodV,
a61af66fc99e Initial load
duke
parents:
diff changeset
2167 checked_jni_CallStaticVoidMethodA,
a61af66fc99e Initial load
duke
parents:
diff changeset
2168
a61af66fc99e Initial load
duke
parents:
diff changeset
2169 checked_jni_GetStaticFieldID,
a61af66fc99e Initial load
duke
parents:
diff changeset
2170
a61af66fc99e Initial load
duke
parents:
diff changeset
2171 checked_jni_GetStaticObjectField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2172 checked_jni_GetStaticBooleanField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2173 checked_jni_GetStaticByteField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2174 checked_jni_GetStaticCharField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2175 checked_jni_GetStaticShortField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2176 checked_jni_GetStaticIntField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2177 checked_jni_GetStaticLongField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2178 checked_jni_GetStaticFloatField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2179 checked_jni_GetStaticDoubleField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2180
a61af66fc99e Initial load
duke
parents:
diff changeset
2181 checked_jni_SetStaticObjectField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2182 checked_jni_SetStaticBooleanField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2183 checked_jni_SetStaticByteField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2184 checked_jni_SetStaticCharField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2185 checked_jni_SetStaticShortField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2186 checked_jni_SetStaticIntField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2187 checked_jni_SetStaticLongField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2188 checked_jni_SetStaticFloatField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2189 checked_jni_SetStaticDoubleField,
a61af66fc99e Initial load
duke
parents:
diff changeset
2190
a61af66fc99e Initial load
duke
parents:
diff changeset
2191 checked_jni_NewString,
a61af66fc99e Initial load
duke
parents:
diff changeset
2192 checked_jni_GetStringLength,
a61af66fc99e Initial load
duke
parents:
diff changeset
2193 checked_jni_GetStringChars,
a61af66fc99e Initial load
duke
parents:
diff changeset
2194 checked_jni_ReleaseStringChars,
a61af66fc99e Initial load
duke
parents:
diff changeset
2195
a61af66fc99e Initial load
duke
parents:
diff changeset
2196 checked_jni_NewStringUTF,
a61af66fc99e Initial load
duke
parents:
diff changeset
2197 checked_jni_GetStringUTFLength,
a61af66fc99e Initial load
duke
parents:
diff changeset
2198 checked_jni_GetStringUTFChars,
a61af66fc99e Initial load
duke
parents:
diff changeset
2199 checked_jni_ReleaseStringUTFChars,
a61af66fc99e Initial load
duke
parents:
diff changeset
2200
a61af66fc99e Initial load
duke
parents:
diff changeset
2201 checked_jni_GetArrayLength,
a61af66fc99e Initial load
duke
parents:
diff changeset
2202
a61af66fc99e Initial load
duke
parents:
diff changeset
2203 checked_jni_NewObjectArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2204 checked_jni_GetObjectArrayElement,
a61af66fc99e Initial load
duke
parents:
diff changeset
2205 checked_jni_SetObjectArrayElement,
a61af66fc99e Initial load
duke
parents:
diff changeset
2206
a61af66fc99e Initial load
duke
parents:
diff changeset
2207 checked_jni_NewBooleanArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2208 checked_jni_NewByteArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2209 checked_jni_NewCharArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2210 checked_jni_NewShortArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2211 checked_jni_NewIntArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2212 checked_jni_NewLongArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2213 checked_jni_NewFloatArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2214 checked_jni_NewDoubleArray,
a61af66fc99e Initial load
duke
parents:
diff changeset
2215
a61af66fc99e Initial load
duke
parents:
diff changeset
2216 checked_jni_GetBooleanArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2217 checked_jni_GetByteArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2218 checked_jni_GetCharArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2219 checked_jni_GetShortArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2220 checked_jni_GetIntArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2221 checked_jni_GetLongArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2222 checked_jni_GetFloatArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2223 checked_jni_GetDoubleArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2224
a61af66fc99e Initial load
duke
parents:
diff changeset
2225 checked_jni_ReleaseBooleanArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2226 checked_jni_ReleaseByteArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2227 checked_jni_ReleaseCharArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2228 checked_jni_ReleaseShortArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2229 checked_jni_ReleaseIntArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2230 checked_jni_ReleaseLongArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2231 checked_jni_ReleaseFloatArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2232 checked_jni_ReleaseDoubleArrayElements,
a61af66fc99e Initial load
duke
parents:
diff changeset
2233
a61af66fc99e Initial load
duke
parents:
diff changeset
2234 checked_jni_GetBooleanArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2235 checked_jni_GetByteArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2236 checked_jni_GetCharArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2237 checked_jni_GetShortArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2238 checked_jni_GetIntArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2239 checked_jni_GetLongArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2240 checked_jni_GetFloatArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2241 checked_jni_GetDoubleArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2242
a61af66fc99e Initial load
duke
parents:
diff changeset
2243 checked_jni_SetBooleanArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2244 checked_jni_SetByteArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2245 checked_jni_SetCharArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2246 checked_jni_SetShortArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2247 checked_jni_SetIntArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2248 checked_jni_SetLongArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2249 checked_jni_SetFloatArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2250 checked_jni_SetDoubleArrayRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2251
a61af66fc99e Initial load
duke
parents:
diff changeset
2252 checked_jni_RegisterNatives,
a61af66fc99e Initial load
duke
parents:
diff changeset
2253 checked_jni_UnregisterNatives,
a61af66fc99e Initial load
duke
parents:
diff changeset
2254
a61af66fc99e Initial load
duke
parents:
diff changeset
2255 checked_jni_MonitorEnter,
a61af66fc99e Initial load
duke
parents:
diff changeset
2256 checked_jni_MonitorExit,
a61af66fc99e Initial load
duke
parents:
diff changeset
2257
a61af66fc99e Initial load
duke
parents:
diff changeset
2258 checked_jni_GetJavaVM,
a61af66fc99e Initial load
duke
parents:
diff changeset
2259
a61af66fc99e Initial load
duke
parents:
diff changeset
2260 checked_jni_GetStringRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2261 checked_jni_GetStringUTFRegion,
a61af66fc99e Initial load
duke
parents:
diff changeset
2262
a61af66fc99e Initial load
duke
parents:
diff changeset
2263 checked_jni_GetPrimitiveArrayCritical,
a61af66fc99e Initial load
duke
parents:
diff changeset
2264 checked_jni_ReleasePrimitiveArrayCritical,
a61af66fc99e Initial load
duke
parents:
diff changeset
2265
a61af66fc99e Initial load
duke
parents:
diff changeset
2266 checked_jni_GetStringCritical,
a61af66fc99e Initial load
duke
parents:
diff changeset
2267 checked_jni_ReleaseStringCritical,
a61af66fc99e Initial load
duke
parents:
diff changeset
2268
a61af66fc99e Initial load
duke
parents:
diff changeset
2269 checked_jni_NewWeakGlobalRef,
a61af66fc99e Initial load
duke
parents:
diff changeset
2270 checked_jni_DeleteWeakGlobalRef,
a61af66fc99e Initial load
duke
parents:
diff changeset
2271
a61af66fc99e Initial load
duke
parents:
diff changeset
2272 checked_jni_ExceptionCheck,
a61af66fc99e Initial load
duke
parents:
diff changeset
2273
a61af66fc99e Initial load
duke
parents:
diff changeset
2274 checked_jni_NewDirectByteBuffer,
a61af66fc99e Initial load
duke
parents:
diff changeset
2275 checked_jni_GetDirectBufferAddress,
a61af66fc99e Initial load
duke
parents:
diff changeset
2276 checked_jni_GetDirectBufferCapacity,
a61af66fc99e Initial load
duke
parents:
diff changeset
2277
a61af66fc99e Initial load
duke
parents:
diff changeset
2278 // New 1.6 Features
a61af66fc99e Initial load
duke
parents:
diff changeset
2279
a61af66fc99e Initial load
duke
parents:
diff changeset
2280 checked_jni_GetObjectRefType
a61af66fc99e Initial load
duke
parents:
diff changeset
2281 };
a61af66fc99e Initial load
duke
parents:
diff changeset
2282
a61af66fc99e Initial load
duke
parents:
diff changeset
2283
a61af66fc99e Initial load
duke
parents:
diff changeset
2284 // Returns the function structure
a61af66fc99e Initial load
duke
parents:
diff changeset
2285 struct JNINativeInterface_* jni_functions_check() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2286
a61af66fc99e Initial load
duke
parents:
diff changeset
2287 unchecked_jni_NativeInterface = jni_functions_nocheck();
a61af66fc99e Initial load
duke
parents:
diff changeset
2288
a61af66fc99e Initial load
duke
parents:
diff changeset
2289 // make sure the last pointer in the checked table is not null, indicating
a61af66fc99e Initial load
duke
parents:
diff changeset
2290 // an addition to the JNINativeInterface_ structure without initializing
a61af66fc99e Initial load
duke
parents:
diff changeset
2291 // it in the checked table.
a61af66fc99e Initial load
duke
parents:
diff changeset
2292 debug_only(int *lastPtr = (int *)((char *)&checked_jni_NativeInterface + \
a61af66fc99e Initial load
duke
parents:
diff changeset
2293 sizeof(*unchecked_jni_NativeInterface) - sizeof(char *));)
a61af66fc99e Initial load
duke
parents:
diff changeset
2294 assert(*lastPtr != 0,
a61af66fc99e Initial load
duke
parents:
diff changeset
2295 "Mismatched JNINativeInterface tables, check for new entries");
a61af66fc99e Initial load
duke
parents:
diff changeset
2296
a61af66fc99e Initial load
duke
parents:
diff changeset
2297 // with -verbose:jni this message will print
a61af66fc99e Initial load
duke
parents:
diff changeset
2298 if (PrintJNIResolving) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2299 tty->print_cr("Checked JNI functions are being used to " \
a61af66fc99e Initial load
duke
parents:
diff changeset
2300 "validate JNI usage");
a61af66fc99e Initial load
duke
parents:
diff changeset
2301 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2302
a61af66fc99e Initial load
duke
parents:
diff changeset
2303 return &checked_jni_NativeInterface;
a61af66fc99e Initial load
duke
parents:
diff changeset
2304 }