annotate src/share/vm/runtime/reflection.cpp @ 6862:8a5ea0a9ccc4

7127708: G1: change task num types from int to uint in concurrent mark Summary: Change the type of various task num fields, parameters etc to unsigned and rename them to be more consistent with the other collectors. Code changes were also reviewed by Vitaly Davidovich. Reviewed-by: johnc Contributed-by: Kaushik Srenevasan <kaushik@twitter.com>
author johnc
date Sat, 06 Oct 2012 01:17:44 -0700
parents da91efe96a93
children d8ce2825b193
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2 * Copyright (c) 1997, 2012, 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: 1152
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1152
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: 1152
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/javaClasses.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #include "classfile/symbolTable.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "classfile/systemDictionary.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "classfile/verifier.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "classfile/vmSymbols.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 #include "interpreter/linkResolver.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "memory/oopFactory.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
33 #include "memory/resourceArea.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
34 #include "memory/universe.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
35 #include "oops/instanceKlass.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
36 #include "oops/objArrayKlass.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
37 #include "oops/objArrayOop.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
38 #include "prims/jvm.h"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
39 #include "runtime/arguments.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
40 #include "runtime/handles.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
41 #include "runtime/javaCalls.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
42 #include "runtime/reflection.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
43 #include "runtime/reflectionUtils.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
44 #include "runtime/signature.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
45 #include "runtime/vframe.hpp"
0
a61af66fc99e Initial load
duke
parents:
diff changeset
46
a61af66fc99e Initial load
duke
parents:
diff changeset
47 #define JAVA_1_5_VERSION 49
a61af66fc99e Initial load
duke
parents:
diff changeset
48
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
49 static void trace_class_resolution(Klass* to_class) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
50 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
51 int line_number = -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
52 const char * source_file = NULL;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
53 Klass* caller = NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
54 JavaThread* jthread = JavaThread::current();
a61af66fc99e Initial load
duke
parents:
diff changeset
55 if (jthread->has_last_Java_frame()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
56 vframeStream vfst(jthread);
a61af66fc99e Initial load
duke
parents:
diff changeset
57 // skip over any frames belonging to java.lang.Class
a61af66fc99e Initial load
duke
parents:
diff changeset
58 while (!vfst.at_end() &&
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
59 InstanceKlass::cast(vfst.method()->method_holder())->name() == vmSymbols::java_lang_Class()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
60 vfst.next();
a61af66fc99e Initial load
duke
parents:
diff changeset
61 }
a61af66fc99e Initial load
duke
parents:
diff changeset
62 if (!vfst.at_end()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
63 // this frame is a likely suspect
a61af66fc99e Initial load
duke
parents:
diff changeset
64 caller = vfst.method()->method_holder();
a61af66fc99e Initial load
duke
parents:
diff changeset
65 line_number = vfst.method()->line_number_from_bci(vfst.bci());
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
66 Symbol* s = InstanceKlass::cast(vfst.method()->method_holder())->source_file_name();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
67 if (s != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
68 source_file = s->as_C_string();
a61af66fc99e Initial load
duke
parents:
diff changeset
69 }
a61af66fc99e Initial load
duke
parents:
diff changeset
70 }
a61af66fc99e Initial load
duke
parents:
diff changeset
71 }
a61af66fc99e Initial load
duke
parents:
diff changeset
72 if (caller != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
73 const char * from = Klass::cast(caller)->external_name();
a61af66fc99e Initial load
duke
parents:
diff changeset
74 const char * to = Klass::cast(to_class)->external_name();
a61af66fc99e Initial load
duke
parents:
diff changeset
75 // print in a single call to reduce interleaving between threads
a61af66fc99e Initial load
duke
parents:
diff changeset
76 if (source_file != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
77 tty->print("RESOLVE %s %s %s:%d (reflection)\n", from, to, source_file, line_number);
a61af66fc99e Initial load
duke
parents:
diff changeset
78 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
79 tty->print("RESOLVE %s %s (reflection)\n", from, to);
a61af66fc99e Initial load
duke
parents:
diff changeset
80 }
a61af66fc99e Initial load
duke
parents:
diff changeset
81 }
a61af66fc99e Initial load
duke
parents:
diff changeset
82 }
a61af66fc99e Initial load
duke
parents:
diff changeset
83
a61af66fc99e Initial load
duke
parents:
diff changeset
84
a61af66fc99e Initial load
duke
parents:
diff changeset
85 oop Reflection::box(jvalue* value, BasicType type, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
86 if (type == T_VOID) {
a61af66fc99e Initial load
duke
parents:
diff changeset
87 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
88 }
a61af66fc99e Initial load
duke
parents:
diff changeset
89 if (type == T_OBJECT || type == T_ARRAY) {
a61af66fc99e Initial load
duke
parents:
diff changeset
90 // regular objects are not boxed
a61af66fc99e Initial load
duke
parents:
diff changeset
91 return (oop) value->l;
a61af66fc99e Initial load
duke
parents:
diff changeset
92 }
a61af66fc99e Initial load
duke
parents:
diff changeset
93 oop result = java_lang_boxing_object::create(type, value, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
94 if (result == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
95 THROW_(vmSymbols::java_lang_IllegalArgumentException(), result);
a61af66fc99e Initial load
duke
parents:
diff changeset
96 }
a61af66fc99e Initial load
duke
parents:
diff changeset
97 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
98 }
a61af66fc99e Initial load
duke
parents:
diff changeset
99
a61af66fc99e Initial load
duke
parents:
diff changeset
100
a61af66fc99e Initial load
duke
parents:
diff changeset
101 BasicType Reflection::unbox_for_primitive(oop box, jvalue* value, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
102 if (box == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
103 THROW_(vmSymbols::java_lang_IllegalArgumentException(), T_ILLEGAL);
a61af66fc99e Initial load
duke
parents:
diff changeset
104 }
a61af66fc99e Initial load
duke
parents:
diff changeset
105 return java_lang_boxing_object::get_value(box, value);
a61af66fc99e Initial load
duke
parents:
diff changeset
106 }
a61af66fc99e Initial load
duke
parents:
diff changeset
107
a61af66fc99e Initial load
duke
parents:
diff changeset
108 BasicType Reflection::unbox_for_regular_object(oop box, jvalue* value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
109 // Note: box is really the unboxed oop. It might even be a Short, etc.!
a61af66fc99e Initial load
duke
parents:
diff changeset
110 value->l = (jobject) box;
a61af66fc99e Initial load
duke
parents:
diff changeset
111 return T_OBJECT;
a61af66fc99e Initial load
duke
parents:
diff changeset
112 }
a61af66fc99e Initial load
duke
parents:
diff changeset
113
a61af66fc99e Initial load
duke
parents:
diff changeset
114
a61af66fc99e Initial load
duke
parents:
diff changeset
115 void Reflection::widen(jvalue* value, BasicType current_type, BasicType wide_type, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
116 assert(wide_type != current_type, "widen should not be called with identical types");
a61af66fc99e Initial load
duke
parents:
diff changeset
117 switch (wide_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
118 case T_BOOLEAN:
a61af66fc99e Initial load
duke
parents:
diff changeset
119 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
120 case T_CHAR:
a61af66fc99e Initial load
duke
parents:
diff changeset
121 break; // fail
a61af66fc99e Initial load
duke
parents:
diff changeset
122 case T_SHORT:
a61af66fc99e Initial load
duke
parents:
diff changeset
123 switch (current_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
124 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
125 value->s = (jshort) value->b;
a61af66fc99e Initial load
duke
parents:
diff changeset
126 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
127 }
a61af66fc99e Initial load
duke
parents:
diff changeset
128 break; // fail
a61af66fc99e Initial load
duke
parents:
diff changeset
129 case T_INT:
a61af66fc99e Initial load
duke
parents:
diff changeset
130 switch (current_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
131 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
132 value->i = (jint) value->b;
a61af66fc99e Initial load
duke
parents:
diff changeset
133 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
134 case T_CHAR:
a61af66fc99e Initial load
duke
parents:
diff changeset
135 value->i = (jint) value->c;
a61af66fc99e Initial load
duke
parents:
diff changeset
136 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
137 case T_SHORT:
a61af66fc99e Initial load
duke
parents:
diff changeset
138 value->i = (jint) value->s;
a61af66fc99e Initial load
duke
parents:
diff changeset
139 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
140 }
a61af66fc99e Initial load
duke
parents:
diff changeset
141 break; // fail
a61af66fc99e Initial load
duke
parents:
diff changeset
142 case T_LONG:
a61af66fc99e Initial load
duke
parents:
diff changeset
143 switch (current_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
144 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
145 value->j = (jlong) value->b;
a61af66fc99e Initial load
duke
parents:
diff changeset
146 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
147 case T_CHAR:
a61af66fc99e Initial load
duke
parents:
diff changeset
148 value->j = (jlong) value->c;
a61af66fc99e Initial load
duke
parents:
diff changeset
149 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
150 case T_SHORT:
a61af66fc99e Initial load
duke
parents:
diff changeset
151 value->j = (jlong) value->s;
a61af66fc99e Initial load
duke
parents:
diff changeset
152 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
153 case T_INT:
a61af66fc99e Initial load
duke
parents:
diff changeset
154 value->j = (jlong) value->i;
a61af66fc99e Initial load
duke
parents:
diff changeset
155 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
156 }
a61af66fc99e Initial load
duke
parents:
diff changeset
157 break; // fail
a61af66fc99e Initial load
duke
parents:
diff changeset
158 case T_FLOAT:
a61af66fc99e Initial load
duke
parents:
diff changeset
159 switch (current_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
160 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
161 value->f = (jfloat) value->b;
a61af66fc99e Initial load
duke
parents:
diff changeset
162 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
163 case T_CHAR:
a61af66fc99e Initial load
duke
parents:
diff changeset
164 value->f = (jfloat) value->c;
a61af66fc99e Initial load
duke
parents:
diff changeset
165 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
166 case T_SHORT:
a61af66fc99e Initial load
duke
parents:
diff changeset
167 value->f = (jfloat) value->s;
a61af66fc99e Initial load
duke
parents:
diff changeset
168 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
169 case T_INT:
a61af66fc99e Initial load
duke
parents:
diff changeset
170 value->f = (jfloat) value->i;
a61af66fc99e Initial load
duke
parents:
diff changeset
171 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
172 case T_LONG:
a61af66fc99e Initial load
duke
parents:
diff changeset
173 value->f = (jfloat) value->j;
a61af66fc99e Initial load
duke
parents:
diff changeset
174 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
175 }
a61af66fc99e Initial load
duke
parents:
diff changeset
176 break; // fail
a61af66fc99e Initial load
duke
parents:
diff changeset
177 case T_DOUBLE:
a61af66fc99e Initial load
duke
parents:
diff changeset
178 switch (current_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
179 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
180 value->d = (jdouble) value->b;
a61af66fc99e Initial load
duke
parents:
diff changeset
181 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
182 case T_CHAR:
a61af66fc99e Initial load
duke
parents:
diff changeset
183 value->d = (jdouble) value->c;
a61af66fc99e Initial load
duke
parents:
diff changeset
184 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
185 case T_SHORT:
a61af66fc99e Initial load
duke
parents:
diff changeset
186 value->d = (jdouble) value->s;
a61af66fc99e Initial load
duke
parents:
diff changeset
187 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
188 case T_INT:
a61af66fc99e Initial load
duke
parents:
diff changeset
189 value->d = (jdouble) value->i;
a61af66fc99e Initial load
duke
parents:
diff changeset
190 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
191 case T_FLOAT:
a61af66fc99e Initial load
duke
parents:
diff changeset
192 value->d = (jdouble) value->f;
a61af66fc99e Initial load
duke
parents:
diff changeset
193 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
194 case T_LONG:
a61af66fc99e Initial load
duke
parents:
diff changeset
195 value->d = (jdouble) value->j;
a61af66fc99e Initial load
duke
parents:
diff changeset
196 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
197 }
a61af66fc99e Initial load
duke
parents:
diff changeset
198 break; // fail
a61af66fc99e Initial load
duke
parents:
diff changeset
199 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
200 break; // fail
a61af66fc99e Initial load
duke
parents:
diff changeset
201 }
a61af66fc99e Initial load
duke
parents:
diff changeset
202 THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), "argument type mismatch");
a61af66fc99e Initial load
duke
parents:
diff changeset
203 }
a61af66fc99e Initial load
duke
parents:
diff changeset
204
a61af66fc99e Initial load
duke
parents:
diff changeset
205
a61af66fc99e Initial load
duke
parents:
diff changeset
206 BasicType Reflection::array_get(jvalue* value, arrayOop a, int index, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
207 if (!a->is_within_bounds(index)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
208 THROW_(vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), T_ILLEGAL);
a61af66fc99e Initial load
duke
parents:
diff changeset
209 }
a61af66fc99e Initial load
duke
parents:
diff changeset
210 if (a->is_objArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
211 value->l = (jobject) objArrayOop(a)->obj_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
212 return T_OBJECT;
a61af66fc99e Initial load
duke
parents:
diff changeset
213 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
214 assert(a->is_typeArray(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
215 BasicType type = typeArrayKlass::cast(a->klass())->element_type();
a61af66fc99e Initial load
duke
parents:
diff changeset
216 switch (type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
217 case T_BOOLEAN:
a61af66fc99e Initial load
duke
parents:
diff changeset
218 value->z = typeArrayOop(a)->bool_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
219 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
220 case T_CHAR:
a61af66fc99e Initial load
duke
parents:
diff changeset
221 value->c = typeArrayOop(a)->char_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
222 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
223 case T_FLOAT:
a61af66fc99e Initial load
duke
parents:
diff changeset
224 value->f = typeArrayOop(a)->float_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
225 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
226 case T_DOUBLE:
a61af66fc99e Initial load
duke
parents:
diff changeset
227 value->d = typeArrayOop(a)->double_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
228 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
229 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
230 value->b = typeArrayOop(a)->byte_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
231 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
232 case T_SHORT:
a61af66fc99e Initial load
duke
parents:
diff changeset
233 value->s = typeArrayOop(a)->short_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
234 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
235 case T_INT:
a61af66fc99e Initial load
duke
parents:
diff changeset
236 value->i = typeArrayOop(a)->int_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
237 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
238 case T_LONG:
a61af66fc99e Initial load
duke
parents:
diff changeset
239 value->j = typeArrayOop(a)->long_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
240 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
241 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
242 return T_ILLEGAL;
a61af66fc99e Initial load
duke
parents:
diff changeset
243 }
a61af66fc99e Initial load
duke
parents:
diff changeset
244 return type;
a61af66fc99e Initial load
duke
parents:
diff changeset
245 }
a61af66fc99e Initial load
duke
parents:
diff changeset
246 }
a61af66fc99e Initial load
duke
parents:
diff changeset
247
a61af66fc99e Initial load
duke
parents:
diff changeset
248
a61af66fc99e Initial load
duke
parents:
diff changeset
249 void Reflection::array_set(jvalue* value, arrayOop a, int index, BasicType value_type, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
250 if (!a->is_within_bounds(index)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
251 THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException());
a61af66fc99e Initial load
duke
parents:
diff changeset
252 }
a61af66fc99e Initial load
duke
parents:
diff changeset
253 if (a->is_objArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
254 if (value_type == T_OBJECT) {
a61af66fc99e Initial load
duke
parents:
diff changeset
255 oop obj = (oop) value->l;
a61af66fc99e Initial load
duke
parents:
diff changeset
256 if (obj != NULL) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
257 Klass* element_klass = objArrayKlass::cast(a->klass())->element_klass();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
258 if (!obj->is_a(element_klass)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
259 THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), "array element type mismatch");
a61af66fc99e Initial load
duke
parents:
diff changeset
260 }
a61af66fc99e Initial load
duke
parents:
diff changeset
261 }
a61af66fc99e Initial load
duke
parents:
diff changeset
262 objArrayOop(a)->obj_at_put(index, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
263 }
a61af66fc99e Initial load
duke
parents:
diff changeset
264 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
265 assert(a->is_typeArray(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
266 BasicType array_type = typeArrayKlass::cast(a->klass())->element_type();
a61af66fc99e Initial load
duke
parents:
diff changeset
267 if (array_type != value_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
268 // The widen operation can potentially throw an exception, but cannot block,
a61af66fc99e Initial load
duke
parents:
diff changeset
269 // so typeArrayOop a is safe if the call succeeds.
a61af66fc99e Initial load
duke
parents:
diff changeset
270 widen(value, value_type, array_type, CHECK);
a61af66fc99e Initial load
duke
parents:
diff changeset
271 }
a61af66fc99e Initial load
duke
parents:
diff changeset
272 switch (array_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
273 case T_BOOLEAN:
a61af66fc99e Initial load
duke
parents:
diff changeset
274 typeArrayOop(a)->bool_at_put(index, value->z);
a61af66fc99e Initial load
duke
parents:
diff changeset
275 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
276 case T_CHAR:
a61af66fc99e Initial load
duke
parents:
diff changeset
277 typeArrayOop(a)->char_at_put(index, value->c);
a61af66fc99e Initial load
duke
parents:
diff changeset
278 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
279 case T_FLOAT:
a61af66fc99e Initial load
duke
parents:
diff changeset
280 typeArrayOop(a)->float_at_put(index, value->f);
a61af66fc99e Initial load
duke
parents:
diff changeset
281 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
282 case T_DOUBLE:
a61af66fc99e Initial load
duke
parents:
diff changeset
283 typeArrayOop(a)->double_at_put(index, value->d);
a61af66fc99e Initial load
duke
parents:
diff changeset
284 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
285 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
286 typeArrayOop(a)->byte_at_put(index, value->b);
a61af66fc99e Initial load
duke
parents:
diff changeset
287 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
288 case T_SHORT:
a61af66fc99e Initial load
duke
parents:
diff changeset
289 typeArrayOop(a)->short_at_put(index, value->s);
a61af66fc99e Initial load
duke
parents:
diff changeset
290 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
291 case T_INT:
a61af66fc99e Initial load
duke
parents:
diff changeset
292 typeArrayOop(a)->int_at_put(index, value->i);
a61af66fc99e Initial load
duke
parents:
diff changeset
293 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
294 case T_LONG:
a61af66fc99e Initial load
duke
parents:
diff changeset
295 typeArrayOop(a)->long_at_put(index, value->j);
a61af66fc99e Initial load
duke
parents:
diff changeset
296 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
297 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
298 THROW(vmSymbols::java_lang_IllegalArgumentException());
a61af66fc99e Initial load
duke
parents:
diff changeset
299 }
a61af66fc99e Initial load
duke
parents:
diff changeset
300 }
a61af66fc99e Initial load
duke
parents:
diff changeset
301 }
a61af66fc99e Initial load
duke
parents:
diff changeset
302
a61af66fc99e Initial load
duke
parents:
diff changeset
303
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
304 Klass* Reflection::basic_type_mirror_to_arrayklass(oop basic_type_mirror, TRAPS) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
305 assert(java_lang_Class::is_primitive(basic_type_mirror), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
306 BasicType type = java_lang_Class::primitive_type(basic_type_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
307 if (type == T_VOID) {
a61af66fc99e Initial load
duke
parents:
diff changeset
308 THROW_0(vmSymbols::java_lang_IllegalArgumentException());
a61af66fc99e Initial load
duke
parents:
diff changeset
309 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
310 return Universe::typeArrayKlassObj(type);
a61af66fc99e Initial load
duke
parents:
diff changeset
311 }
a61af66fc99e Initial load
duke
parents:
diff changeset
312 }
a61af66fc99e Initial load
duke
parents:
diff changeset
313
a61af66fc99e Initial load
duke
parents:
diff changeset
314
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
315 oop Reflection:: basic_type_arrayklass_to_mirror(Klass* basic_type_arrayklass, TRAPS) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
316 BasicType type = typeArrayKlass::cast(basic_type_arrayklass)->element_type();
a61af66fc99e Initial load
duke
parents:
diff changeset
317 return Universe::java_mirror(type);
a61af66fc99e Initial load
duke
parents:
diff changeset
318 }
a61af66fc99e Initial load
duke
parents:
diff changeset
319
a61af66fc99e Initial load
duke
parents:
diff changeset
320
a61af66fc99e Initial load
duke
parents:
diff changeset
321 arrayOop Reflection::reflect_new_array(oop element_mirror, jint length, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
322 if (element_mirror == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
323 THROW_0(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
324 }
a61af66fc99e Initial load
duke
parents:
diff changeset
325 if (length < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
326 THROW_0(vmSymbols::java_lang_NegativeArraySizeException());
a61af66fc99e Initial load
duke
parents:
diff changeset
327 }
a61af66fc99e Initial load
duke
parents:
diff changeset
328 if (java_lang_Class::is_primitive(element_mirror)) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
329 Klass* tak = basic_type_mirror_to_arrayklass(element_mirror, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
330 return typeArrayKlass::cast(tak)->allocate(length, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
331 } else {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
332 Klass* k = java_lang_Class::as_Klass(element_mirror);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
333 if (Klass::cast(k)->oop_is_array() && arrayKlass::cast(k)->dimension() >= MAX_DIM) {
a61af66fc99e Initial load
duke
parents:
diff changeset
334 THROW_0(vmSymbols::java_lang_IllegalArgumentException());
a61af66fc99e Initial load
duke
parents:
diff changeset
335 }
a61af66fc99e Initial load
duke
parents:
diff changeset
336 return oopFactory::new_objArray(k, length, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
337 }
a61af66fc99e Initial load
duke
parents:
diff changeset
338 }
a61af66fc99e Initial load
duke
parents:
diff changeset
339
a61af66fc99e Initial load
duke
parents:
diff changeset
340
a61af66fc99e Initial load
duke
parents:
diff changeset
341 arrayOop Reflection::reflect_new_multi_array(oop element_mirror, typeArrayOop dim_array, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
342 assert(dim_array->is_typeArray(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
343 assert(typeArrayKlass::cast(dim_array->klass())->element_type() == T_INT, "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
344
a61af66fc99e Initial load
duke
parents:
diff changeset
345 if (element_mirror == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
346 THROW_0(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
347 }
a61af66fc99e Initial load
duke
parents:
diff changeset
348
a61af66fc99e Initial load
duke
parents:
diff changeset
349 int len = dim_array->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
350 if (len <= 0 || len > MAX_DIM) {
a61af66fc99e Initial load
duke
parents:
diff changeset
351 THROW_0(vmSymbols::java_lang_IllegalArgumentException());
a61af66fc99e Initial load
duke
parents:
diff changeset
352 }
a61af66fc99e Initial load
duke
parents:
diff changeset
353
a61af66fc99e Initial load
duke
parents:
diff changeset
354 jint dimensions[MAX_DIM]; // C array copy of intArrayOop
a61af66fc99e Initial load
duke
parents:
diff changeset
355 for (int i = 0; i < len; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
356 int d = dim_array->int_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
357 if (d < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
358 THROW_0(vmSymbols::java_lang_NegativeArraySizeException());
a61af66fc99e Initial load
duke
parents:
diff changeset
359 }
a61af66fc99e Initial load
duke
parents:
diff changeset
360 dimensions[i] = d;
a61af66fc99e Initial load
duke
parents:
diff changeset
361 }
a61af66fc99e Initial load
duke
parents:
diff changeset
362
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
363 Klass* klass;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
364 int dim = len;
a61af66fc99e Initial load
duke
parents:
diff changeset
365 if (java_lang_Class::is_primitive(element_mirror)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
366 klass = basic_type_mirror_to_arrayklass(element_mirror, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
367 } else {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
368 klass = java_lang_Class::as_Klass(element_mirror);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
369 if (Klass::cast(klass)->oop_is_array()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
370 int k_dim = arrayKlass::cast(klass)->dimension();
a61af66fc99e Initial load
duke
parents:
diff changeset
371 if (k_dim + len > MAX_DIM) {
a61af66fc99e Initial load
duke
parents:
diff changeset
372 THROW_0(vmSymbols::java_lang_IllegalArgumentException());
a61af66fc99e Initial load
duke
parents:
diff changeset
373 }
a61af66fc99e Initial load
duke
parents:
diff changeset
374 dim += k_dim;
a61af66fc99e Initial load
duke
parents:
diff changeset
375 }
a61af66fc99e Initial load
duke
parents:
diff changeset
376 }
a61af66fc99e Initial load
duke
parents:
diff changeset
377 klass = Klass::cast(klass)->array_klass(dim, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
378 oop obj = arrayKlass::cast(klass)->multi_allocate(len, dimensions, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
379 assert(obj->is_array(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
380 return arrayOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
381 }
a61af66fc99e Initial load
duke
parents:
diff changeset
382
a61af66fc99e Initial load
duke
parents:
diff changeset
383
a61af66fc99e Initial load
duke
parents:
diff changeset
384 oop Reflection::array_component_type(oop mirror, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
385 if (java_lang_Class::is_primitive(mirror)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
386 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
387 }
a61af66fc99e Initial load
duke
parents:
diff changeset
388
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
389 Klass* klass = java_lang_Class::as_Klass(mirror);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
390 if (!Klass::cast(klass)->oop_is_array()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
391 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
392 }
a61af66fc99e Initial load
duke
parents:
diff changeset
393
a61af66fc99e Initial load
duke
parents:
diff changeset
394 oop result = arrayKlass::cast(klass)->component_mirror();
a61af66fc99e Initial load
duke
parents:
diff changeset
395 #ifdef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
396 oop result2 = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
397 if (arrayKlass::cast(klass)->dimension() == 1) {
a61af66fc99e Initial load
duke
parents:
diff changeset
398 if (Klass::cast(klass)->oop_is_typeArray()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
399 result2 = basic_type_arrayklass_to_mirror(klass, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
400 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
401 result2 = Klass::cast(objArrayKlass::cast(klass)->element_klass())->java_mirror();
a61af66fc99e Initial load
duke
parents:
diff changeset
402 }
a61af66fc99e Initial load
duke
parents:
diff changeset
403 } else {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
404 Klass* lower_dim = arrayKlass::cast(klass)->lower_dimension();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
405 assert(Klass::cast(lower_dim)->oop_is_array(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
406 result2 = Klass::cast(lower_dim)->java_mirror();
a61af66fc99e Initial load
duke
parents:
diff changeset
407 }
a61af66fc99e Initial load
duke
parents:
diff changeset
408 assert(result == result2, "results must be consistent");
a61af66fc99e Initial load
duke
parents:
diff changeset
409 #endif //ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
410 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
411 }
a61af66fc99e Initial load
duke
parents:
diff changeset
412
a61af66fc99e Initial load
duke
parents:
diff changeset
413
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
414 bool Reflection::reflect_check_access(Klass* field_class, AccessFlags acc, Klass* target_class, bool is_method_invoke, TRAPS) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
415 // field_class : declaring class
a61af66fc99e Initial load
duke
parents:
diff changeset
416 // acc : declared field access
a61af66fc99e Initial load
duke
parents:
diff changeset
417 // target_class : for protected
a61af66fc99e Initial load
duke
parents:
diff changeset
418
a61af66fc99e Initial load
duke
parents:
diff changeset
419 // Check if field or method is accessible to client. Throw an
a61af66fc99e Initial load
duke
parents:
diff changeset
420 // IllegalAccessException and return false if not.
a61af66fc99e Initial load
duke
parents:
diff changeset
421
a61af66fc99e Initial load
duke
parents:
diff changeset
422 // The "client" is the class associated with the nearest real frame
a61af66fc99e Initial load
duke
parents:
diff changeset
423 // getCallerClass already skips Method.invoke frames, so pass 0 in
a61af66fc99e Initial load
duke
parents:
diff changeset
424 // that case (same as classic).
a61af66fc99e Initial load
duke
parents:
diff changeset
425 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
426 assert(THREAD->is_Java_thread(), "sanity check");
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
427 Klass* client_class = ((JavaThread *)THREAD)->security_get_caller_class(is_method_invoke ? 0 : 1);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
428
a61af66fc99e Initial load
duke
parents:
diff changeset
429 if (client_class != field_class) {
a61af66fc99e Initial load
duke
parents:
diff changeset
430 if (!verify_class_access(client_class, field_class, false)
a61af66fc99e Initial load
duke
parents:
diff changeset
431 || !verify_field_access(client_class,
a61af66fc99e Initial load
duke
parents:
diff changeset
432 field_class,
a61af66fc99e Initial load
duke
parents:
diff changeset
433 field_class,
a61af66fc99e Initial load
duke
parents:
diff changeset
434 acc,
a61af66fc99e Initial load
duke
parents:
diff changeset
435 false)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
436 THROW_(vmSymbols::java_lang_IllegalAccessException(), false);
a61af66fc99e Initial load
duke
parents:
diff changeset
437 }
a61af66fc99e Initial load
duke
parents:
diff changeset
438 }
a61af66fc99e Initial load
duke
parents:
diff changeset
439
a61af66fc99e Initial load
duke
parents:
diff changeset
440 // Additional test for protected members: JLS 6.6.2
a61af66fc99e Initial load
duke
parents:
diff changeset
441
a61af66fc99e Initial load
duke
parents:
diff changeset
442 if (acc.is_protected()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
443 if (target_class != client_class) {
a61af66fc99e Initial load
duke
parents:
diff changeset
444 if (!is_same_class_package(client_class, field_class)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
445 if (!Klass::cast(target_class)->is_subclass_of(client_class)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
446 THROW_(vmSymbols::java_lang_IllegalAccessException(), false);
a61af66fc99e Initial load
duke
parents:
diff changeset
447 }
a61af66fc99e Initial load
duke
parents:
diff changeset
448 }
a61af66fc99e Initial load
duke
parents:
diff changeset
449 }
a61af66fc99e Initial load
duke
parents:
diff changeset
450 }
a61af66fc99e Initial load
duke
parents:
diff changeset
451
a61af66fc99e Initial load
duke
parents:
diff changeset
452 // Passed all tests
a61af66fc99e Initial load
duke
parents:
diff changeset
453 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
454 }
a61af66fc99e Initial load
duke
parents:
diff changeset
455
a61af66fc99e Initial load
duke
parents:
diff changeset
456
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
457 bool Reflection::verify_class_access(Klass* current_class, Klass* new_class, bool classloader_only) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
458 // Verify that current_class can access new_class. If the classloader_only
a61af66fc99e Initial load
duke
parents:
diff changeset
459 // flag is set, we automatically allow any accesses in which current_class
a61af66fc99e Initial load
duke
parents:
diff changeset
460 // doesn't have a classloader.
a61af66fc99e Initial load
duke
parents:
diff changeset
461 if ((current_class == NULL) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
462 (current_class == new_class) ||
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
463 (InstanceKlass::cast(new_class)->is_public()) ||
0
a61af66fc99e Initial load
duke
parents:
diff changeset
464 is_same_class_package(current_class, new_class)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
465 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
466 }
a61af66fc99e Initial load
duke
parents:
diff changeset
467 // New (1.4) reflection implementation. Allow all accesses from
a61af66fc99e Initial load
duke
parents:
diff changeset
468 // sun/reflect/MagicAccessorImpl subclasses to succeed trivially.
a61af66fc99e Initial load
duke
parents:
diff changeset
469 if ( JDK_Version::is_gte_jdk14x_version()
a61af66fc99e Initial load
duke
parents:
diff changeset
470 && UseNewReflection
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 665
diff changeset
471 && Klass::cast(current_class)->is_subclass_of(SystemDictionary::reflect_MagicAccessorImpl_klass())) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
472 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
473 }
a61af66fc99e Initial load
duke
parents:
diff changeset
474
a61af66fc99e Initial load
duke
parents:
diff changeset
475 return can_relax_access_check_for(current_class, new_class, classloader_only);
a61af66fc99e Initial load
duke
parents:
diff changeset
476 }
a61af66fc99e Initial load
duke
parents:
diff changeset
477
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
478 static bool under_host_klass(InstanceKlass* ik, Klass* host_klass) {
431
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
479 DEBUG_ONLY(int inf_loop_check = 1000 * 1000 * 1000);
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
480 for (;;) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
481 Klass* hc = (Klass*) ik->host_klass();
431
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
482 if (hc == NULL) return false;
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
483 if (hc == host_klass) return true;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
484 ik = InstanceKlass::cast(hc);
431
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
485
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
486 // There's no way to make a host class loop short of patching memory.
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
487 // Therefore there cannot be a loop here unles there's another bug.
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
488 // Still, let's check for it.
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
489 assert(--inf_loop_check > 0, "no host_klass loop");
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
490 }
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
491 }
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
492
0
a61af66fc99e Initial load
duke
parents:
diff changeset
493 bool Reflection::can_relax_access_check_for(
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
494 Klass* accessor, Klass* accessee, bool classloader_only) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
495 InstanceKlass* accessor_ik = InstanceKlass::cast(accessor);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
496 InstanceKlass* accessee_ik = InstanceKlass::cast(accessee);
431
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
497
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
498 // If either is on the other's host_klass chain, access is OK,
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
499 // because one is inside the other.
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
500 if (under_host_klass(accessor_ik, accessee) ||
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
501 under_host_klass(accessee_ik, accessor))
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
502 return true;
a45484ea312d 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 196
diff changeset
503
0
a61af66fc99e Initial load
duke
parents:
diff changeset
504 if (RelaxAccessControlCheck ||
a61af66fc99e Initial load
duke
parents:
diff changeset
505 (accessor_ik->major_version() < JAVA_1_5_VERSION &&
a61af66fc99e Initial load
duke
parents:
diff changeset
506 accessee_ik->major_version() < JAVA_1_5_VERSION)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
507 return classloader_only &&
a61af66fc99e Initial load
duke
parents:
diff changeset
508 Verifier::relax_verify_for(accessor_ik->class_loader()) &&
a61af66fc99e Initial load
duke
parents:
diff changeset
509 accessor_ik->protection_domain() == accessee_ik->protection_domain() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
510 accessor_ik->class_loader() == accessee_ik->class_loader();
a61af66fc99e Initial load
duke
parents:
diff changeset
511 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
512 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
513 }
a61af66fc99e Initial load
duke
parents:
diff changeset
514 }
a61af66fc99e Initial load
duke
parents:
diff changeset
515
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
516 bool Reflection::verify_field_access(Klass* current_class,
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
517 Klass* resolved_class,
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
518 Klass* field_class,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
519 AccessFlags access,
a61af66fc99e Initial load
duke
parents:
diff changeset
520 bool classloader_only,
a61af66fc99e Initial load
duke
parents:
diff changeset
521 bool protected_restriction) {
a61af66fc99e Initial load
duke
parents:
diff changeset
522 // Verify that current_class can access a field of field_class, where that
a61af66fc99e Initial load
duke
parents:
diff changeset
523 // field's access bits are "access". We assume that we've already verified
a61af66fc99e Initial load
duke
parents:
diff changeset
524 // that current_class can access field_class.
a61af66fc99e Initial load
duke
parents:
diff changeset
525 //
a61af66fc99e Initial load
duke
parents:
diff changeset
526 // If the classloader_only flag is set, we automatically allow any accesses
a61af66fc99e Initial load
duke
parents:
diff changeset
527 // in which current_class doesn't have a classloader.
a61af66fc99e Initial load
duke
parents:
diff changeset
528 //
a61af66fc99e Initial load
duke
parents:
diff changeset
529 // "resolved_class" is the runtime type of "field_class". Sometimes we don't
a61af66fc99e Initial load
duke
parents:
diff changeset
530 // need this distinction (e.g. if all we have is the runtime type, or during
a61af66fc99e Initial load
duke
parents:
diff changeset
531 // class file parsing when we only care about the static type); in that case
a61af66fc99e Initial load
duke
parents:
diff changeset
532 // callers should ensure that resolved_class == field_class.
a61af66fc99e Initial load
duke
parents:
diff changeset
533 //
a61af66fc99e Initial load
duke
parents:
diff changeset
534 if ((current_class == NULL) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
535 (current_class == field_class) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
536 access.is_public()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
537 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
538 }
a61af66fc99e Initial load
duke
parents:
diff changeset
539
a61af66fc99e Initial load
duke
parents:
diff changeset
540 if (access.is_protected()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
541 if (!protected_restriction) {
a61af66fc99e Initial load
duke
parents:
diff changeset
542 // See if current_class is a subclass of field_class
a61af66fc99e Initial load
duke
parents:
diff changeset
543 if (Klass::cast(current_class)->is_subclass_of(field_class)) {
115
e7a91a357527 6622385: Accessing protected static methods
kamg
parents: 51
diff changeset
544 if (access.is_static() || // static fields are ok, see 6622385
e7a91a357527 6622385: Accessing protected static methods
kamg
parents: 51
diff changeset
545 current_class == resolved_class ||
0
a61af66fc99e Initial load
duke
parents:
diff changeset
546 field_class == resolved_class ||
a61af66fc99e Initial load
duke
parents:
diff changeset
547 Klass::cast(current_class)->is_subclass_of(resolved_class) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
548 Klass::cast(resolved_class)->is_subclass_of(current_class)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
549 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
550 }
a61af66fc99e Initial load
duke
parents:
diff changeset
551 }
a61af66fc99e Initial load
duke
parents:
diff changeset
552 }
a61af66fc99e Initial load
duke
parents:
diff changeset
553 }
a61af66fc99e Initial load
duke
parents:
diff changeset
554
a61af66fc99e Initial load
duke
parents:
diff changeset
555 if (!access.is_private() && is_same_class_package(current_class, field_class)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
556 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
557 }
a61af66fc99e Initial load
duke
parents:
diff changeset
558
a61af66fc99e Initial load
duke
parents:
diff changeset
559 // New (1.4) reflection implementation. Allow all accesses from
a61af66fc99e Initial load
duke
parents:
diff changeset
560 // sun/reflect/MagicAccessorImpl subclasses to succeed trivially.
a61af66fc99e Initial load
duke
parents:
diff changeset
561 if ( JDK_Version::is_gte_jdk14x_version()
a61af66fc99e Initial load
duke
parents:
diff changeset
562 && UseNewReflection
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 665
diff changeset
563 && Klass::cast(current_class)->is_subclass_of(SystemDictionary::reflect_MagicAccessorImpl_klass())) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
564 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
565 }
a61af66fc99e Initial load
duke
parents:
diff changeset
566
a61af66fc99e Initial load
duke
parents:
diff changeset
567 return can_relax_access_check_for(
a61af66fc99e Initial load
duke
parents:
diff changeset
568 current_class, field_class, classloader_only);
a61af66fc99e Initial load
duke
parents:
diff changeset
569 }
a61af66fc99e Initial load
duke
parents:
diff changeset
570
a61af66fc99e Initial load
duke
parents:
diff changeset
571
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
572 bool Reflection::is_same_class_package(Klass* class1, Klass* class2) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
573 return InstanceKlass::cast(class1)->is_same_class_package(class2);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
574 }
a61af66fc99e Initial load
duke
parents:
diff changeset
575
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
576 bool Reflection::is_same_package_member(Klass* class1, Klass* class2, TRAPS) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
577 return InstanceKlass::cast(class1)->is_same_package_member(class2, THREAD);
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
578 }
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
579
0
a61af66fc99e Initial load
duke
parents:
diff changeset
580
a61af66fc99e Initial load
duke
parents:
diff changeset
581 // Checks that the 'outer' klass has declared 'inner' as being an inner klass. If not,
a61af66fc99e Initial load
duke
parents:
diff changeset
582 // throw an incompatible class change exception
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
583 // If inner_is_member, require the inner to be a member of the outer.
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
584 // If !inner_is_member, require the inner to be anonymous (a non-member).
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
585 // Caller is responsible for figuring out in advance which case must be true.
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
586 void Reflection::check_for_inner_class(instanceKlassHandle outer, instanceKlassHandle inner,
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
587 bool inner_is_member, TRAPS) {
5967
f7c4174b33ba 7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents: 3895
diff changeset
588 InnerClassesIterator iter(outer);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
589 constantPoolHandle cp (THREAD, outer->constants());
5967
f7c4174b33ba 7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents: 3895
diff changeset
590 for (; !iter.done(); iter.next()) {
f7c4174b33ba 7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents: 3895
diff changeset
591 int ioff = iter.inner_class_info_index();
f7c4174b33ba 7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents: 3895
diff changeset
592 int ooff = iter.outer_class_info_index();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
593
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
594 if (inner_is_member && ioff != 0 && ooff != 0) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
595 Klass* o = cp->klass_at(ooff, CHECK);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
596 if (o == outer()) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
597 Klass* i = cp->klass_at(ioff, CHECK);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
598 if (i == inner()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
599 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
600 }
a61af66fc99e Initial load
duke
parents:
diff changeset
601 }
a61af66fc99e Initial load
duke
parents:
diff changeset
602 }
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
603 if (!inner_is_member && ioff != 0 && ooff == 0 &&
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
604 cp->klass_name_at_matches(inner, ioff)) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
605 Klass* i = cp->klass_at(ioff, CHECK);
665
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
606 if (i == inner()) {
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
607 return;
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
608 }
c89f86385056 6814659: separable cleanups and subroutines for 6655638
jrose
parents: 431
diff changeset
609 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
610 }
a61af66fc99e Initial load
duke
parents:
diff changeset
611
a61af66fc99e Initial load
duke
parents:
diff changeset
612 // 'inner' not declared as an inner klass in outer
a61af66fc99e Initial load
duke
parents:
diff changeset
613 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
614 Exceptions::fthrow(
a61af66fc99e Initial load
duke
parents:
diff changeset
615 THREAD_AND_LOCATION,
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
616 vmSymbols::java_lang_IncompatibleClassChangeError(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
617 "%s and %s disagree on InnerClasses attribute",
a61af66fc99e Initial load
duke
parents:
diff changeset
618 outer->external_name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
619 inner->external_name()
a61af66fc99e Initial load
duke
parents:
diff changeset
620 );
a61af66fc99e Initial load
duke
parents:
diff changeset
621 }
a61af66fc99e Initial load
duke
parents:
diff changeset
622
a61af66fc99e Initial load
duke
parents:
diff changeset
623 // Utility method converting a single SignatureStream element into java.lang.Class instance
a61af66fc99e Initial load
duke
parents:
diff changeset
624
a61af66fc99e Initial load
duke
parents:
diff changeset
625 oop get_mirror_from_signature(methodHandle method, SignatureStream* ss, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
626 switch (ss->type()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
627 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
628 assert(ss->type() != T_VOID || ss->at_return_type(), "T_VOID should only appear as return type");
a61af66fc99e Initial load
duke
parents:
diff changeset
629 return java_lang_Class::primitive_mirror(ss->type());
a61af66fc99e Initial load
duke
parents:
diff changeset
630 case T_OBJECT:
a61af66fc99e Initial load
duke
parents:
diff changeset
631 case T_ARRAY:
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
632 Symbol* name = ss->as_symbol(CHECK_NULL);
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
633 oop loader = InstanceKlass::cast(method->method_holder())->class_loader();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
634 oop protection_domain = InstanceKlass::cast(method->method_holder())->protection_domain();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
635 Klass* k = SystemDictionary::resolve_or_fail(
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
636 name,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
637 Handle(THREAD, loader),
a61af66fc99e Initial load
duke
parents:
diff changeset
638 Handle(THREAD, protection_domain),
a61af66fc99e Initial load
duke
parents:
diff changeset
639 true, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
640 if (TraceClassResolution) {
a61af66fc99e Initial load
duke
parents:
diff changeset
641 trace_class_resolution(k);
a61af66fc99e Initial load
duke
parents:
diff changeset
642 }
2376
c7f3d0b4570f 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 2177
diff changeset
643 return k->java_mirror();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
644 };
a61af66fc99e Initial load
duke
parents:
diff changeset
645 }
a61af66fc99e Initial load
duke
parents:
diff changeset
646
a61af66fc99e Initial load
duke
parents:
diff changeset
647
a61af66fc99e Initial load
duke
parents:
diff changeset
648 objArrayHandle Reflection::get_parameter_types(methodHandle method, int parameter_count, oop* return_type, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
649 // Allocate array holding parameter types (java.lang.Class instances)
1142
4ce7240d622c 6914300: ciEnv should export all well known classes
never
parents: 665
diff changeset
650 objArrayOop m = oopFactory::new_objArray(SystemDictionary::Class_klass(), parameter_count, CHECK_(objArrayHandle()));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
651 objArrayHandle mirrors (THREAD, m);
a61af66fc99e Initial load
duke
parents:
diff changeset
652 int index = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
653 // Collect parameter types
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
654 ResourceMark rm(THREAD);
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
655 Symbol* signature = method->signature();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
656 SignatureStream ss(signature);
a61af66fc99e Initial load
duke
parents:
diff changeset
657 while (!ss.at_return_type()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
658 oop mirror = get_mirror_from_signature(method, &ss, CHECK_(objArrayHandle()));
a61af66fc99e Initial load
duke
parents:
diff changeset
659 mirrors->obj_at_put(index++, mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
660 ss.next();
a61af66fc99e Initial load
duke
parents:
diff changeset
661 }
a61af66fc99e Initial load
duke
parents:
diff changeset
662 assert(index == parameter_count, "invalid parameter count");
a61af66fc99e Initial load
duke
parents:
diff changeset
663 if (return_type != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
664 // Collect return type as well
a61af66fc99e Initial load
duke
parents:
diff changeset
665 assert(ss.at_return_type(), "return type should be present");
a61af66fc99e Initial load
duke
parents:
diff changeset
666 *return_type = get_mirror_from_signature(method, &ss, CHECK_(objArrayHandle()));
a61af66fc99e Initial load
duke
parents:
diff changeset
667 }
a61af66fc99e Initial load
duke
parents:
diff changeset
668 return mirrors;
a61af66fc99e Initial load
duke
parents:
diff changeset
669 }
a61af66fc99e Initial load
duke
parents:
diff changeset
670
a61af66fc99e Initial load
duke
parents:
diff changeset
671 objArrayHandle Reflection::get_exception_types(methodHandle method, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
672 return method->resolved_checked_exceptions(CHECK_(objArrayHandle()));
a61af66fc99e Initial load
duke
parents:
diff changeset
673 }
a61af66fc99e Initial load
duke
parents:
diff changeset
674
a61af66fc99e Initial load
duke
parents:
diff changeset
675
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
676 Handle Reflection::new_type(Symbol* signature, KlassHandle k, TRAPS) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
677 // Basic types
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
678 BasicType type = vmSymbols::signature_type(signature);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
679 if (type != T_OBJECT) {
a61af66fc99e Initial load
duke
parents:
diff changeset
680 return Handle(THREAD, Universe::java_mirror(type));
a61af66fc99e Initial load
duke
parents:
diff changeset
681 }
a61af66fc99e Initial load
duke
parents:
diff changeset
682
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
683 oop loader = InstanceKlass::cast(k())->class_loader();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
684 oop protection_domain = Klass::cast(k())->protection_domain();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
685 Klass* result = SystemDictionary::resolve_or_fail(signature,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
686 Handle(THREAD, loader),
a61af66fc99e Initial load
duke
parents:
diff changeset
687 Handle(THREAD, protection_domain),
a61af66fc99e Initial load
duke
parents:
diff changeset
688 true, CHECK_(Handle()));
a61af66fc99e Initial load
duke
parents:
diff changeset
689
a61af66fc99e Initial load
duke
parents:
diff changeset
690 if (TraceClassResolution) {
a61af66fc99e Initial load
duke
parents:
diff changeset
691 trace_class_resolution(result);
a61af66fc99e Initial load
duke
parents:
diff changeset
692 }
a61af66fc99e Initial load
duke
parents:
diff changeset
693
a61af66fc99e Initial load
duke
parents:
diff changeset
694 oop nt = Klass::cast(result)->java_mirror();
a61af66fc99e Initial load
duke
parents:
diff changeset
695 return Handle(THREAD, nt);
a61af66fc99e Initial load
duke
parents:
diff changeset
696 }
a61af66fc99e Initial load
duke
parents:
diff changeset
697
a61af66fc99e Initial load
duke
parents:
diff changeset
698
a61af66fc99e Initial load
duke
parents:
diff changeset
699 oop Reflection::new_method(methodHandle method, bool intern_name, bool for_constant_pool_access, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
700 // In jdk1.2.x, getMethods on an interface erroneously includes <clinit>, thus the complicated assert.
a61af66fc99e Initial load
duke
parents:
diff changeset
701 // Also allow sun.reflect.ConstantPool to refer to <clinit> methods as java.lang.reflect.Methods.
a61af66fc99e Initial load
duke
parents:
diff changeset
702 assert(!method()->is_initializer() ||
a61af66fc99e Initial load
duke
parents:
diff changeset
703 (for_constant_pool_access && method()->is_static()) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
704 (method()->name() == vmSymbols::class_initializer_name()
a61af66fc99e Initial load
duke
parents:
diff changeset
705 && Klass::cast(method()->method_holder())->is_interface() && JDK_Version::is_jdk12x_version()), "should call new_constructor instead");
a61af66fc99e Initial load
duke
parents:
diff changeset
706 instanceKlassHandle holder (THREAD, method->method_holder());
a61af66fc99e Initial load
duke
parents:
diff changeset
707 int slot = method->method_idnum();
a61af66fc99e Initial load
duke
parents:
diff changeset
708
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
709 Symbol* signature = method->signature();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
710 int parameter_count = ArgumentCount(signature).size();
a61af66fc99e Initial load
duke
parents:
diff changeset
711 oop return_type_oop = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
712 objArrayHandle parameter_types = get_parameter_types(method, parameter_count, &return_type_oop, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
713 if (parameter_types.is_null() || return_type_oop == NULL) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
714
a61af66fc99e Initial load
duke
parents:
diff changeset
715 Handle return_type(THREAD, return_type_oop);
a61af66fc99e Initial load
duke
parents:
diff changeset
716
a61af66fc99e Initial load
duke
parents:
diff changeset
717 objArrayHandle exception_types = get_exception_types(method, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
718
a61af66fc99e Initial load
duke
parents:
diff changeset
719 if (exception_types.is_null()) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
720
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
721 Symbol* method_name = method->name();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
722 Handle name;
a61af66fc99e Initial load
duke
parents:
diff changeset
723 if (intern_name) {
a61af66fc99e Initial load
duke
parents:
diff changeset
724 // intern_name is only true with UseNewReflection
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
725 oop name_oop = StringTable::intern(method_name, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
726 name = Handle(THREAD, name_oop);
a61af66fc99e Initial load
duke
parents:
diff changeset
727 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
728 name = java_lang_String::create_from_symbol(method_name, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
729 }
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
730 if (name == NULL) return NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
731
a61af66fc99e Initial load
duke
parents:
diff changeset
732 int modifiers = method->access_flags().as_int() & JVM_RECOGNIZED_METHOD_MODIFIERS;
a61af66fc99e Initial load
duke
parents:
diff changeset
733
a61af66fc99e Initial load
duke
parents:
diff changeset
734 Handle mh = java_lang_reflect_Method::create(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
735
a61af66fc99e Initial load
duke
parents:
diff changeset
736 java_lang_reflect_Method::set_clazz(mh(), holder->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
737 java_lang_reflect_Method::set_slot(mh(), slot);
a61af66fc99e Initial load
duke
parents:
diff changeset
738 java_lang_reflect_Method::set_name(mh(), name());
a61af66fc99e Initial load
duke
parents:
diff changeset
739 java_lang_reflect_Method::set_return_type(mh(), return_type());
a61af66fc99e Initial load
duke
parents:
diff changeset
740 java_lang_reflect_Method::set_parameter_types(mh(), parameter_types());
a61af66fc99e Initial load
duke
parents:
diff changeset
741 java_lang_reflect_Method::set_exception_types(mh(), exception_types());
a61af66fc99e Initial load
duke
parents:
diff changeset
742 java_lang_reflect_Method::set_modifiers(mh(), modifiers);
a61af66fc99e Initial load
duke
parents:
diff changeset
743 java_lang_reflect_Method::set_override(mh(), false);
a61af66fc99e Initial load
duke
parents:
diff changeset
744 if (java_lang_reflect_Method::has_signature_field() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
745 method->generic_signature() != NULL) {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
746 Symbol* gs = method->generic_signature();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
747 Handle sig = java_lang_String::create_from_symbol(gs, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
748 java_lang_reflect_Method::set_signature(mh(), sig());
a61af66fc99e Initial load
duke
parents:
diff changeset
749 }
a61af66fc99e Initial load
duke
parents:
diff changeset
750 if (java_lang_reflect_Method::has_annotations_field()) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
751 typeArrayOop an_oop = Annotations::make_java_array(method->annotations(), CHECK_NULL);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
752 java_lang_reflect_Method::set_annotations(mh(), an_oop);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
753 }
a61af66fc99e Initial load
duke
parents:
diff changeset
754 if (java_lang_reflect_Method::has_parameter_annotations_field()) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
755 typeArrayOop an_oop = Annotations::make_java_array(method->parameter_annotations(), CHECK_NULL);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
756 java_lang_reflect_Method::set_parameter_annotations(mh(), an_oop);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
757 }
a61af66fc99e Initial load
duke
parents:
diff changeset
758 if (java_lang_reflect_Method::has_annotation_default_field()) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
759 typeArrayOop an_oop = Annotations::make_java_array(method->annotation_default(), CHECK_NULL);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
760 java_lang_reflect_Method::set_annotation_default(mh(), an_oop);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
761 }
a61af66fc99e Initial load
duke
parents:
diff changeset
762 return mh();
a61af66fc99e Initial load
duke
parents:
diff changeset
763 }
a61af66fc99e Initial load
duke
parents:
diff changeset
764
a61af66fc99e Initial load
duke
parents:
diff changeset
765
a61af66fc99e Initial load
duke
parents:
diff changeset
766 oop Reflection::new_constructor(methodHandle method, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
767 assert(method()->is_initializer(), "should call new_method instead");
a61af66fc99e Initial load
duke
parents:
diff changeset
768
a61af66fc99e Initial load
duke
parents:
diff changeset
769 instanceKlassHandle holder (THREAD, method->method_holder());
a61af66fc99e Initial load
duke
parents:
diff changeset
770 int slot = method->method_idnum();
a61af66fc99e Initial load
duke
parents:
diff changeset
771
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
772 Symbol* signature = method->signature();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
773 int parameter_count = ArgumentCount(signature).size();
a61af66fc99e Initial load
duke
parents:
diff changeset
774 objArrayHandle parameter_types = get_parameter_types(method, parameter_count, NULL, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
775 if (parameter_types.is_null()) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
776
a61af66fc99e Initial load
duke
parents:
diff changeset
777 objArrayHandle exception_types = get_exception_types(method, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
778 if (exception_types.is_null()) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
779
a61af66fc99e Initial load
duke
parents:
diff changeset
780 int modifiers = method->access_flags().as_int() & JVM_RECOGNIZED_METHOD_MODIFIERS;
a61af66fc99e Initial load
duke
parents:
diff changeset
781
a61af66fc99e Initial load
duke
parents:
diff changeset
782 Handle ch = java_lang_reflect_Constructor::create(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
783
a61af66fc99e Initial load
duke
parents:
diff changeset
784 java_lang_reflect_Constructor::set_clazz(ch(), holder->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
785 java_lang_reflect_Constructor::set_slot(ch(), slot);
a61af66fc99e Initial load
duke
parents:
diff changeset
786 java_lang_reflect_Constructor::set_parameter_types(ch(), parameter_types());
a61af66fc99e Initial load
duke
parents:
diff changeset
787 java_lang_reflect_Constructor::set_exception_types(ch(), exception_types());
a61af66fc99e Initial load
duke
parents:
diff changeset
788 java_lang_reflect_Constructor::set_modifiers(ch(), modifiers);
a61af66fc99e Initial load
duke
parents:
diff changeset
789 java_lang_reflect_Constructor::set_override(ch(), false);
a61af66fc99e Initial load
duke
parents:
diff changeset
790 if (java_lang_reflect_Constructor::has_signature_field() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
791 method->generic_signature() != NULL) {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
792 Symbol* gs = method->generic_signature();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
793 Handle sig = java_lang_String::create_from_symbol(gs, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
794 java_lang_reflect_Constructor::set_signature(ch(), sig());
a61af66fc99e Initial load
duke
parents:
diff changeset
795 }
a61af66fc99e Initial load
duke
parents:
diff changeset
796 if (java_lang_reflect_Constructor::has_annotations_field()) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
797 typeArrayOop an_oop = Annotations::make_java_array(method->annotations(), CHECK_NULL);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
798 java_lang_reflect_Constructor::set_annotations(ch(), an_oop);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
799 }
a61af66fc99e Initial load
duke
parents:
diff changeset
800 if (java_lang_reflect_Constructor::has_parameter_annotations_field()) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
801 typeArrayOop an_oop = Annotations::make_java_array(method->parameter_annotations(), CHECK_NULL);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
802 java_lang_reflect_Constructor::set_parameter_annotations(ch(), an_oop);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
803 }
a61af66fc99e Initial load
duke
parents:
diff changeset
804 return ch();
a61af66fc99e Initial load
duke
parents:
diff changeset
805 }
a61af66fc99e Initial load
duke
parents:
diff changeset
806
a61af66fc99e Initial load
duke
parents:
diff changeset
807
a61af66fc99e Initial load
duke
parents:
diff changeset
808 oop Reflection::new_field(fieldDescriptor* fd, bool intern_name, TRAPS) {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
809 Symbol* field_name = fd->name();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
810 Handle name;
a61af66fc99e Initial load
duke
parents:
diff changeset
811 if (intern_name) {
a61af66fc99e Initial load
duke
parents:
diff changeset
812 // intern_name is only true with UseNewReflection
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
813 oop name_oop = StringTable::intern(field_name, CHECK_NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
814 name = Handle(THREAD, name_oop);
a61af66fc99e Initial load
duke
parents:
diff changeset
815 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
816 name = java_lang_String::create_from_symbol(field_name, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
817 }
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
818 Symbol* signature = fd->signature();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
819 instanceKlassHandle holder (THREAD, fd->field_holder());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
820 Handle type = new_type(signature, holder, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
821 Handle rh = java_lang_reflect_Field::create(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
822
a61af66fc99e Initial load
duke
parents:
diff changeset
823 java_lang_reflect_Field::set_clazz(rh(), Klass::cast(fd->field_holder())->java_mirror());
a61af66fc99e Initial load
duke
parents:
diff changeset
824 java_lang_reflect_Field::set_slot(rh(), fd->index());
a61af66fc99e Initial load
duke
parents:
diff changeset
825 java_lang_reflect_Field::set_name(rh(), name());
a61af66fc99e Initial load
duke
parents:
diff changeset
826 java_lang_reflect_Field::set_type(rh(), type());
a61af66fc99e Initial load
duke
parents:
diff changeset
827 // Note the ACC_ANNOTATION bit, which is a per-class access flag, is never set here.
a61af66fc99e Initial load
duke
parents:
diff changeset
828 java_lang_reflect_Field::set_modifiers(rh(), fd->access_flags().as_int() & JVM_RECOGNIZED_FIELD_MODIFIERS);
a61af66fc99e Initial load
duke
parents:
diff changeset
829 java_lang_reflect_Field::set_override(rh(), false);
a61af66fc99e Initial load
duke
parents:
diff changeset
830 if (java_lang_reflect_Field::has_signature_field() &&
6176
634b8615a6ba 7177409: Perf regression in JVM_GetClassDeclaredFields after generic signature changes.
jiangli
parents: 5967
diff changeset
831 fd->has_generic_signature()) {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
832 Symbol* gs = fd->generic_signature();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
833 Handle sig = java_lang_String::create_from_symbol(gs, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
834 java_lang_reflect_Field::set_signature(rh(), sig());
a61af66fc99e Initial load
duke
parents:
diff changeset
835 }
a61af66fc99e Initial load
duke
parents:
diff changeset
836 if (java_lang_reflect_Field::has_annotations_field()) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
837 typeArrayOop an_oop = Annotations::make_java_array(fd->annotations(), CHECK_NULL);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
838 java_lang_reflect_Field::set_annotations(rh(), an_oop);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
839 }
a61af66fc99e Initial load
duke
parents:
diff changeset
840 return rh();
a61af66fc99e Initial load
duke
parents:
diff changeset
841 }
a61af66fc99e Initial load
duke
parents:
diff changeset
842
a61af66fc99e Initial load
duke
parents:
diff changeset
843
a61af66fc99e Initial load
duke
parents:
diff changeset
844 methodHandle Reflection::resolve_interface_call(instanceKlassHandle klass, methodHandle method,
a61af66fc99e Initial load
duke
parents:
diff changeset
845 KlassHandle recv_klass, Handle receiver, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
846 assert(!method.is_null() , "method should not be null");
a61af66fc99e Initial load
duke
parents:
diff changeset
847
a61af66fc99e Initial load
duke
parents:
diff changeset
848 CallInfo info;
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
849 Symbol* signature = method->signature();
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
850 Symbol* name = method->name();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
851 LinkResolver::resolve_interface_call(info, receiver, recv_klass, klass,
a61af66fc99e Initial load
duke
parents:
diff changeset
852 name, signature,
a61af66fc99e Initial load
duke
parents:
diff changeset
853 KlassHandle(), false, true,
a61af66fc99e Initial load
duke
parents:
diff changeset
854 CHECK_(methodHandle()));
a61af66fc99e Initial load
duke
parents:
diff changeset
855 return info.selected_method();
a61af66fc99e Initial load
duke
parents:
diff changeset
856 }
a61af66fc99e Initial load
duke
parents:
diff changeset
857
a61af66fc99e Initial load
duke
parents:
diff changeset
858
a61af66fc99e Initial load
duke
parents:
diff changeset
859 oop Reflection::invoke(instanceKlassHandle klass, methodHandle reflected_method,
a61af66fc99e Initial load
duke
parents:
diff changeset
860 Handle receiver, bool override, objArrayHandle ptypes,
a61af66fc99e Initial load
duke
parents:
diff changeset
861 BasicType rtype, objArrayHandle args, bool is_method_invoke, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
862 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
863
a61af66fc99e Initial load
duke
parents:
diff changeset
864 methodHandle method; // actual method to invoke
a61af66fc99e Initial load
duke
parents:
diff changeset
865 KlassHandle target_klass; // target klass, receiver's klass for non-static
a61af66fc99e Initial load
duke
parents:
diff changeset
866
a61af66fc99e Initial load
duke
parents:
diff changeset
867 // Ensure klass is initialized
a61af66fc99e Initial load
duke
parents:
diff changeset
868 klass->initialize(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
869
a61af66fc99e Initial load
duke
parents:
diff changeset
870 bool is_static = reflected_method->is_static();
a61af66fc99e Initial load
duke
parents:
diff changeset
871 if (is_static) {
a61af66fc99e Initial load
duke
parents:
diff changeset
872 // ignore receiver argument
a61af66fc99e Initial load
duke
parents:
diff changeset
873 method = reflected_method;
a61af66fc99e Initial load
duke
parents:
diff changeset
874 target_klass = klass;
a61af66fc99e Initial load
duke
parents:
diff changeset
875 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
876 // check for null receiver
a61af66fc99e Initial load
duke
parents:
diff changeset
877 if (receiver.is_null()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
878 THROW_0(vmSymbols::java_lang_NullPointerException());
a61af66fc99e Initial load
duke
parents:
diff changeset
879 }
a61af66fc99e Initial load
duke
parents:
diff changeset
880 // Check class of receiver against class declaring method
a61af66fc99e Initial load
duke
parents:
diff changeset
881 if (!receiver->is_a(klass())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
882 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "object is not an instance of declaring class");
a61af66fc99e Initial load
duke
parents:
diff changeset
883 }
a61af66fc99e Initial load
duke
parents:
diff changeset
884 // target klass is receiver's klass
a61af66fc99e Initial load
duke
parents:
diff changeset
885 target_klass = KlassHandle(THREAD, receiver->klass());
a61af66fc99e Initial load
duke
parents:
diff changeset
886 // no need to resolve if method is private or <init>
a61af66fc99e Initial load
duke
parents:
diff changeset
887 if (reflected_method->is_private() || reflected_method->name() == vmSymbols::object_initializer_name()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
888 method = reflected_method;
a61af66fc99e Initial load
duke
parents:
diff changeset
889 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
890 // resolve based on the receiver
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
891 if (InstanceKlass::cast(reflected_method->method_holder())->is_interface()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
892 // resolve interface call
a61af66fc99e Initial load
duke
parents:
diff changeset
893 if (ReflectionWrapResolutionErrors) {
a61af66fc99e Initial load
duke
parents:
diff changeset
894 // new default: 6531596
a61af66fc99e Initial load
duke
parents:
diff changeset
895 // Match resolution errors with those thrown due to reflection inlining
a61af66fc99e Initial load
duke
parents:
diff changeset
896 // Linktime resolution & IllegalAccessCheck already done by Class.getMethod()
a61af66fc99e Initial load
duke
parents:
diff changeset
897 method = resolve_interface_call(klass, reflected_method, target_klass, receiver, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
898 if (HAS_PENDING_EXCEPTION) {
a61af66fc99e Initial load
duke
parents:
diff changeset
899 // Method resolution threw an exception; wrap it in an InvocationTargetException
a61af66fc99e Initial load
duke
parents:
diff changeset
900 oop resolution_exception = PENDING_EXCEPTION;
a61af66fc99e Initial load
duke
parents:
diff changeset
901 CLEAR_PENDING_EXCEPTION;
a61af66fc99e Initial load
duke
parents:
diff changeset
902 JavaCallArguments args(Handle(THREAD, resolution_exception));
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
903 THROW_ARG_0(vmSymbols::java_lang_reflect_InvocationTargetException(),
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
904 vmSymbols::throwable_void_signature(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
905 &args);
a61af66fc99e Initial load
duke
parents:
diff changeset
906 }
a61af66fc99e Initial load
duke
parents:
diff changeset
907 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
908 method = resolve_interface_call(klass, reflected_method, target_klass, receiver, CHECK_(NULL));
a61af66fc99e Initial load
duke
parents:
diff changeset
909 }
a61af66fc99e Initial load
duke
parents:
diff changeset
910 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
911 // if the method can be overridden, we resolve using the vtable index.
a61af66fc99e Initial load
duke
parents:
diff changeset
912 int index = reflected_method->vtable_index();
a61af66fc99e Initial load
duke
parents:
diff changeset
913 method = reflected_method;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
914 if (index != Method::nonvirtual_vtable_index) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
915 // target_klass might be an arrayKlassOop but all vtables start at
a61af66fc99e Initial load
duke
parents:
diff changeset
916 // the same place. The cast is to avoid virtual call and assertion.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
917 InstanceKlass* inst = (InstanceKlass*)target_klass();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
918 method = methodHandle(THREAD, inst->method_at_vtable(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
919 }
a61af66fc99e Initial load
duke
parents:
diff changeset
920 if (!method.is_null()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
921 // Check for abstract methods as well
a61af66fc99e Initial load
duke
parents:
diff changeset
922 if (method->is_abstract()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
923 // new default: 6531596
a61af66fc99e Initial load
duke
parents:
diff changeset
924 if (ReflectionWrapResolutionErrors) {
a61af66fc99e Initial load
duke
parents:
diff changeset
925 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
926 Handle h_origexception = Exceptions::new_exception(THREAD,
a61af66fc99e Initial load
duke
parents:
diff changeset
927 vmSymbols::java_lang_AbstractMethodError(),
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
928 Method::name_and_sig_as_C_string(Klass::cast(target_klass()),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
929 method->name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
930 method->signature()));
a61af66fc99e Initial load
duke
parents:
diff changeset
931 JavaCallArguments args(h_origexception);
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
932 THROW_ARG_0(vmSymbols::java_lang_reflect_InvocationTargetException(),
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
933 vmSymbols::throwable_void_signature(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
934 &args);
a61af66fc99e Initial load
duke
parents:
diff changeset
935 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
936 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
937 THROW_MSG_0(vmSymbols::java_lang_AbstractMethodError(),
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
938 Method::name_and_sig_as_C_string(Klass::cast(target_klass()),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
939 method->name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
940 method->signature()));
a61af66fc99e Initial load
duke
parents:
diff changeset
941 }
a61af66fc99e Initial load
duke
parents:
diff changeset
942 }
a61af66fc99e Initial load
duke
parents:
diff changeset
943 }
a61af66fc99e Initial load
duke
parents:
diff changeset
944 }
a61af66fc99e Initial load
duke
parents:
diff changeset
945 }
a61af66fc99e Initial load
duke
parents:
diff changeset
946 }
a61af66fc99e Initial load
duke
parents:
diff changeset
947
a61af66fc99e Initial load
duke
parents:
diff changeset
948 // I believe this is a ShouldNotGetHere case which requires
a61af66fc99e Initial load
duke
parents:
diff changeset
949 // an internal vtable bug. If you ever get this please let Karen know.
a61af66fc99e Initial load
duke
parents:
diff changeset
950 if (method.is_null()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
951 ResourceMark rm(THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
952 THROW_MSG_0(vmSymbols::java_lang_NoSuchMethodError(),
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
953 Method::name_and_sig_as_C_string(Klass::cast(klass()),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
954 reflected_method->name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
955 reflected_method->signature()));
a61af66fc99e Initial load
duke
parents:
diff changeset
956 }
a61af66fc99e Initial load
duke
parents:
diff changeset
957
a61af66fc99e Initial load
duke
parents:
diff changeset
958 // In the JDK 1.4 reflection implementation, the security check is
a61af66fc99e Initial load
duke
parents:
diff changeset
959 // done at the Java level
a61af66fc99e Initial load
duke
parents:
diff changeset
960 if (!(JDK_Version::is_gte_jdk14x_version() && UseNewReflection)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
961
a61af66fc99e Initial load
duke
parents:
diff changeset
962 // Access checking (unless overridden by Method)
a61af66fc99e Initial load
duke
parents:
diff changeset
963 if (!override) {
a61af66fc99e Initial load
duke
parents:
diff changeset
964 if (!(klass->is_public() && reflected_method->is_public())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
965 bool access = Reflection::reflect_check_access(klass(), reflected_method->access_flags(), target_klass(), is_method_invoke, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
966 if (!access) {
a61af66fc99e Initial load
duke
parents:
diff changeset
967 return NULL; // exception
a61af66fc99e Initial load
duke
parents:
diff changeset
968 }
a61af66fc99e Initial load
duke
parents:
diff changeset
969 }
a61af66fc99e Initial load
duke
parents:
diff changeset
970 }
a61af66fc99e Initial load
duke
parents:
diff changeset
971
a61af66fc99e Initial load
duke
parents:
diff changeset
972 } // !(Universe::is_gte_jdk14x_version() && UseNewReflection)
a61af66fc99e Initial load
duke
parents:
diff changeset
973
a61af66fc99e Initial load
duke
parents:
diff changeset
974 assert(ptypes->is_objArray(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
975 int args_len = args.is_null() ? 0 : args->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
976 // Check number of arguments
a61af66fc99e Initial load
duke
parents:
diff changeset
977 if (ptypes->length() != args_len) {
a61af66fc99e Initial load
duke
parents:
diff changeset
978 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "wrong number of arguments");
a61af66fc99e Initial load
duke
parents:
diff changeset
979 }
a61af66fc99e Initial load
duke
parents:
diff changeset
980
a61af66fc99e Initial load
duke
parents:
diff changeset
981 // Create object to contain parameters for the JavaCall
a61af66fc99e Initial load
duke
parents:
diff changeset
982 JavaCallArguments java_args(method->size_of_parameters());
a61af66fc99e Initial load
duke
parents:
diff changeset
983
a61af66fc99e Initial load
duke
parents:
diff changeset
984 if (!is_static) {
a61af66fc99e Initial load
duke
parents:
diff changeset
985 java_args.push_oop(receiver);
a61af66fc99e Initial load
duke
parents:
diff changeset
986 }
a61af66fc99e Initial load
duke
parents:
diff changeset
987
a61af66fc99e Initial load
duke
parents:
diff changeset
988 for (int i = 0; i < args_len; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
989 oop type_mirror = ptypes->obj_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
990 oop arg = args->obj_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
991 if (java_lang_Class::is_primitive(type_mirror)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
992 jvalue value;
a61af66fc99e Initial load
duke
parents:
diff changeset
993 BasicType ptype = basic_type_mirror_to_basic_type(type_mirror, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
994 BasicType atype = unbox_for_primitive(arg, &value, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
995 if (ptype != atype) {
a61af66fc99e Initial load
duke
parents:
diff changeset
996 widen(&value, atype, ptype, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
997 }
a61af66fc99e Initial load
duke
parents:
diff changeset
998 switch (ptype) {
a61af66fc99e Initial load
duke
parents:
diff changeset
999 case T_BOOLEAN: java_args.push_int(value.z); break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1000 case T_CHAR: java_args.push_int(value.c); break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1001 case T_BYTE: java_args.push_int(value.b); break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1002 case T_SHORT: java_args.push_int(value.s); break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1003 case T_INT: java_args.push_int(value.i); break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1004 case T_LONG: java_args.push_long(value.j); break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1005 case T_FLOAT: java_args.push_float(value.f); break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1006 case T_DOUBLE: java_args.push_double(value.d); break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1007 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
1008 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "argument type mismatch");
a61af66fc99e Initial load
duke
parents:
diff changeset
1009 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1010 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
1011 if (arg != NULL) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1012 Klass* k = java_lang_Class::as_Klass(type_mirror);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1013 if (!arg->is_a(k)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1014 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), "argument type mismatch");
a61af66fc99e Initial load
duke
parents:
diff changeset
1015 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1016 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1017 Handle arg_handle(THREAD, arg); // Create handle for argument
a61af66fc99e Initial load
duke
parents:
diff changeset
1018 java_args.push_oop(arg_handle); // Push handle
a61af66fc99e Initial load
duke
parents:
diff changeset
1019 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1020 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1021
a61af66fc99e Initial load
duke
parents:
diff changeset
1022 assert(java_args.size_of_parameters() == method->size_of_parameters(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
1023
a61af66fc99e Initial load
duke
parents:
diff changeset
1024 // All oops (including receiver) is passed in as Handles. An potential oop is returned as an
a61af66fc99e Initial load
duke
parents:
diff changeset
1025 // oop (i.e., NOT as an handle)
a61af66fc99e Initial load
duke
parents:
diff changeset
1026 JavaValue result(rtype);
a61af66fc99e Initial load
duke
parents:
diff changeset
1027 JavaCalls::call(&result, method, &java_args, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
1028
a61af66fc99e Initial load
duke
parents:
diff changeset
1029 if (HAS_PENDING_EXCEPTION) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1030 // Method threw an exception; wrap it in an InvocationTargetException
a61af66fc99e Initial load
duke
parents:
diff changeset
1031 oop target_exception = PENDING_EXCEPTION;
a61af66fc99e Initial load
duke
parents:
diff changeset
1032 CLEAR_PENDING_EXCEPTION;
a61af66fc99e Initial load
duke
parents:
diff changeset
1033 JavaCallArguments args(Handle(THREAD, target_exception));
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
1034 THROW_ARG_0(vmSymbols::java_lang_reflect_InvocationTargetException(),
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
1035 vmSymbols::throwable_void_signature(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1036 &args);
a61af66fc99e Initial load
duke
parents:
diff changeset
1037 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
1038 if (rtype == T_BOOLEAN || rtype == T_BYTE || rtype == T_CHAR || rtype == T_SHORT)
a61af66fc99e Initial load
duke
parents:
diff changeset
1039 narrow((jvalue*) result.get_value_addr(), rtype, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1040 return box((jvalue*) result.get_value_addr(), rtype, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1041 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1042 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1043
a61af66fc99e Initial load
duke
parents:
diff changeset
1044
a61af66fc99e Initial load
duke
parents:
diff changeset
1045 void Reflection::narrow(jvalue* value, BasicType narrow_type, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1046 switch (narrow_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1047 case T_BOOLEAN:
a61af66fc99e Initial load
duke
parents:
diff changeset
1048 value->z = (jboolean) value->i;
a61af66fc99e Initial load
duke
parents:
diff changeset
1049 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
1050 case T_BYTE:
a61af66fc99e Initial load
duke
parents:
diff changeset
1051 value->b = (jbyte) value->i;
a61af66fc99e Initial load
duke
parents:
diff changeset
1052 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
1053 case T_CHAR:
a61af66fc99e Initial load
duke
parents:
diff changeset
1054 value->c = (jchar) value->i;
a61af66fc99e Initial load
duke
parents:
diff changeset
1055 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
1056 case T_SHORT:
a61af66fc99e Initial load
duke
parents:
diff changeset
1057 value->s = (jshort) value->i;
a61af66fc99e Initial load
duke
parents:
diff changeset
1058 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
1059 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
1060 break; // fail
a61af66fc99e Initial load
duke
parents:
diff changeset
1061 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1062 THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), "argument type mismatch");
a61af66fc99e Initial load
duke
parents:
diff changeset
1063 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1064
a61af66fc99e Initial load
duke
parents:
diff changeset
1065
a61af66fc99e Initial load
duke
parents:
diff changeset
1066 BasicType Reflection::basic_type_mirror_to_basic_type(oop basic_type_mirror, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1067 assert(java_lang_Class::is_primitive(basic_type_mirror), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
1068 return java_lang_Class::primitive_type(basic_type_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1069 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1070
a61af66fc99e Initial load
duke
parents:
diff changeset
1071 // This would be nicer if, say, java.lang.reflect.Method was a subclass
a61af66fc99e Initial load
duke
parents:
diff changeset
1072 // of java.lang.reflect.Constructor
a61af66fc99e Initial load
duke
parents:
diff changeset
1073
a61af66fc99e Initial load
duke
parents:
diff changeset
1074 oop Reflection::invoke_method(oop method_mirror, Handle receiver, objArrayHandle args, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1075 oop mirror = java_lang_reflect_Method::clazz(method_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1076 int slot = java_lang_reflect_Method::slot(method_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1077 bool override = java_lang_reflect_Method::override(method_mirror) != 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1078 objArrayHandle ptypes(THREAD, objArrayOop(java_lang_reflect_Method::parameter_types(method_mirror)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1079
a61af66fc99e Initial load
duke
parents:
diff changeset
1080 oop return_type_mirror = java_lang_reflect_Method::return_type(method_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1081 BasicType rtype;
a61af66fc99e Initial load
duke
parents:
diff changeset
1082 if (java_lang_Class::is_primitive(return_type_mirror)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1083 rtype = basic_type_mirror_to_basic_type(return_type_mirror, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1084 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
1085 rtype = T_OBJECT;
a61af66fc99e Initial load
duke
parents:
diff changeset
1086 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1087
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1088 instanceKlassHandle klass(THREAD, java_lang_Class::as_Klass(mirror));
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1089 Method* m = klass->method_with_idnum(slot);
51
1ffa5cdd0b7e 6667089: 3/3 multiple redefinitions of a class break reflection
dcubed
parents: 0
diff changeset
1090 if (m == NULL) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1091 THROW_MSG_0(vmSymbols::java_lang_InternalError(), "invoke");
a61af66fc99e Initial load
duke
parents:
diff changeset
1092 }
51
1ffa5cdd0b7e 6667089: 3/3 multiple redefinitions of a class break reflection
dcubed
parents: 0
diff changeset
1093 methodHandle method(THREAD, m);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1094
a61af66fc99e Initial load
duke
parents:
diff changeset
1095 return invoke(klass, method, receiver, override, ptypes, rtype, args, true, THREAD);
a61af66fc99e Initial load
duke
parents:
diff changeset
1096 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1097
a61af66fc99e Initial load
duke
parents:
diff changeset
1098
a61af66fc99e Initial load
duke
parents:
diff changeset
1099 oop Reflection::invoke_constructor(oop constructor_mirror, objArrayHandle args, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1100 oop mirror = java_lang_reflect_Constructor::clazz(constructor_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1101 int slot = java_lang_reflect_Constructor::slot(constructor_mirror);
a61af66fc99e Initial load
duke
parents:
diff changeset
1102 bool override = java_lang_reflect_Constructor::override(constructor_mirror) != 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
1103 objArrayHandle ptypes(THREAD, objArrayOop(java_lang_reflect_Constructor::parameter_types(constructor_mirror)));
a61af66fc99e Initial load
duke
parents:
diff changeset
1104
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1105 instanceKlassHandle klass(THREAD, java_lang_Class::as_Klass(mirror));
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1106 Method* m = klass->method_with_idnum(slot);
51
1ffa5cdd0b7e 6667089: 3/3 multiple redefinitions of a class break reflection
dcubed
parents: 0
diff changeset
1107 if (m == NULL) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1108 THROW_MSG_0(vmSymbols::java_lang_InternalError(), "invoke");
a61af66fc99e Initial load
duke
parents:
diff changeset
1109 }
51
1ffa5cdd0b7e 6667089: 3/3 multiple redefinitions of a class break reflection
dcubed
parents: 0
diff changeset
1110 methodHandle method(THREAD, m);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1111 assert(method->name() == vmSymbols::object_initializer_name(), "invalid constructor");
a61af66fc99e Initial load
duke
parents:
diff changeset
1112
a61af66fc99e Initial load
duke
parents:
diff changeset
1113 // Make sure klass gets initialize
a61af66fc99e Initial load
duke
parents:
diff changeset
1114 klass->initialize(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1115
a61af66fc99e Initial load
duke
parents:
diff changeset
1116 // Create new instance (the receiver)
a61af66fc99e Initial load
duke
parents:
diff changeset
1117 klass->check_valid_for_instantiation(false, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1118 Handle receiver = klass->allocate_instance_handle(CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1119
a61af66fc99e Initial load
duke
parents:
diff changeset
1120 // Ignore result from call and return receiver
a61af66fc99e Initial load
duke
parents:
diff changeset
1121 invoke(klass, method, receiver, override, ptypes, T_VOID, args, false, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1122 return receiver();
a61af66fc99e Initial load
duke
parents:
diff changeset
1123 }