Mercurial > hg > truffle
comparison src/share/vm/classfile/javaClasses.cpp @ 2357:8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
Summary: package and class renaming only; delete unused methods and classes
Reviewed-by: twisti
author | jrose |
---|---|
date | Fri, 11 Mar 2011 22:34:57 -0800 |
parents | 72dee110246f |
children | c7f3d0b4570f |
comparison
equal
deleted
inserted
replaced
2356:72dee110246f | 2357:8033953d67ff |
---|---|
2196 | 2196 |
2197 SystemDictionary::SoftReference_klass()->long_field_put(offset, value); | 2197 SystemDictionary::SoftReference_klass()->long_field_put(offset, value); |
2198 } | 2198 } |
2199 | 2199 |
2200 | 2200 |
2201 // Support for java_dyn_MethodHandle | 2201 // Support for java_lang_invoke_MethodHandle |
2202 | 2202 |
2203 int java_dyn_MethodHandle::_type_offset; | 2203 int java_lang_invoke_MethodHandle::_type_offset; |
2204 int java_dyn_MethodHandle::_vmtarget_offset; | 2204 int java_lang_invoke_MethodHandle::_vmtarget_offset; |
2205 int java_dyn_MethodHandle::_vmentry_offset; | 2205 int java_lang_invoke_MethodHandle::_vmentry_offset; |
2206 int java_dyn_MethodHandle::_vmslots_offset; | 2206 int java_lang_invoke_MethodHandle::_vmslots_offset; |
2207 | 2207 |
2208 int sun_dyn_MemberName::_clazz_offset; | 2208 int java_lang_invoke_MemberName::_clazz_offset; |
2209 int sun_dyn_MemberName::_name_offset; | 2209 int java_lang_invoke_MemberName::_name_offset; |
2210 int sun_dyn_MemberName::_type_offset; | 2210 int java_lang_invoke_MemberName::_type_offset; |
2211 int sun_dyn_MemberName::_flags_offset; | 2211 int java_lang_invoke_MemberName::_flags_offset; |
2212 int sun_dyn_MemberName::_vmtarget_offset; | 2212 int java_lang_invoke_MemberName::_vmtarget_offset; |
2213 int sun_dyn_MemberName::_vmindex_offset; | 2213 int java_lang_invoke_MemberName::_vmindex_offset; |
2214 | 2214 |
2215 int sun_dyn_DirectMethodHandle::_vmindex_offset; | 2215 int java_lang_invoke_DirectMethodHandle::_vmindex_offset; |
2216 | 2216 |
2217 int sun_dyn_BoundMethodHandle::_argument_offset; | 2217 int java_lang_invoke_BoundMethodHandle::_argument_offset; |
2218 int sun_dyn_BoundMethodHandle::_vmargslot_offset; | 2218 int java_lang_invoke_BoundMethodHandle::_vmargslot_offset; |
2219 | 2219 |
2220 int sun_dyn_AdapterMethodHandle::_conversion_offset; | 2220 int java_lang_invoke_AdapterMethodHandle::_conversion_offset; |
2221 | 2221 |
2222 void java_dyn_MethodHandle::compute_offsets() { | 2222 void java_lang_invoke_MethodHandle::compute_offsets() { |
2223 klassOop k = SystemDictionary::MethodHandle_klass(); | 2223 klassOop k = SystemDictionary::MethodHandle_klass(); |
2224 if (k != NULL && EnableMethodHandles) { | 2224 if (k != NULL && EnableMethodHandles) { |
2225 bool allow_super = false; | 2225 bool allow_super = false; |
2226 if (AllowTransitionalJSR292) allow_super = true; // temporary, to access sun.dyn.MethodHandleImpl | 2226 if (AllowTransitionalJSR292) allow_super = true; // temporary, to access java.dyn.MethodHandleImpl |
2227 compute_offset(_type_offset, k, vmSymbols::type_name(), vmSymbols::java_dyn_MethodType_signature(), allow_super); | 2227 compute_offset(_type_offset, k, vmSymbols::type_name(), vmSymbols::java_lang_invoke_MethodType_signature(), allow_super); |
2228 compute_offset(_vmtarget_offset, k, vmSymbols::vmtarget_name(), vmSymbols::object_signature(), allow_super); | 2228 compute_offset(_vmtarget_offset, k, vmSymbols::vmtarget_name(), vmSymbols::object_signature(), allow_super); |
2229 compute_offset(_vmentry_offset, k, vmSymbols::vmentry_name(), vmSymbols::machine_word_signature(), allow_super); | 2229 compute_offset(_vmentry_offset, k, vmSymbols::vmentry_name(), vmSymbols::machine_word_signature(), allow_super); |
2230 | 2230 |
2231 // Note: MH.vmslots (if it is present) is a hoisted copy of MH.type.form.vmslots. | 2231 // Note: MH.vmslots (if it is present) is a hoisted copy of MH.type.form.vmslots. |
2232 // It is optional pending experiments to keep or toss. | 2232 // It is optional pending experiments to keep or toss. |
2233 compute_optional_offset(_vmslots_offset, k, vmSymbols::vmslots_name(), vmSymbols::int_signature(), allow_super); | 2233 compute_optional_offset(_vmslots_offset, k, vmSymbols::vmslots_name(), vmSymbols::int_signature(), allow_super); |
2234 } | 2234 } |
2235 } | 2235 } |
2236 | 2236 |
2237 void sun_dyn_MemberName::compute_offsets() { | 2237 void java_lang_invoke_MemberName::compute_offsets() { |
2238 klassOop k = SystemDictionary::MemberName_klass(); | 2238 klassOop k = SystemDictionary::MemberName_klass(); |
2239 if (k != NULL && EnableMethodHandles) { | 2239 if (k != NULL && EnableMethodHandles) { |
2240 compute_offset(_clazz_offset, k, vmSymbols::clazz_name(), vmSymbols::class_signature()); | 2240 compute_offset(_clazz_offset, k, vmSymbols::clazz_name(), vmSymbols::class_signature()); |
2241 compute_offset(_name_offset, k, vmSymbols::name_name(), vmSymbols::string_signature()); | 2241 compute_offset(_name_offset, k, vmSymbols::name_name(), vmSymbols::string_signature()); |
2242 compute_offset(_type_offset, k, vmSymbols::type_name(), vmSymbols::object_signature()); | 2242 compute_offset(_type_offset, k, vmSymbols::type_name(), vmSymbols::object_signature()); |
2244 compute_offset(_vmtarget_offset, k, vmSymbols::vmtarget_name(), vmSymbols::object_signature()); | 2244 compute_offset(_vmtarget_offset, k, vmSymbols::vmtarget_name(), vmSymbols::object_signature()); |
2245 compute_offset(_vmindex_offset, k, vmSymbols::vmindex_name(), vmSymbols::int_signature()); | 2245 compute_offset(_vmindex_offset, k, vmSymbols::vmindex_name(), vmSymbols::int_signature()); |
2246 } | 2246 } |
2247 } | 2247 } |
2248 | 2248 |
2249 void sun_dyn_DirectMethodHandle::compute_offsets() { | 2249 void java_lang_invoke_DirectMethodHandle::compute_offsets() { |
2250 klassOop k = SystemDictionary::DirectMethodHandle_klass(); | 2250 klassOop k = SystemDictionary::DirectMethodHandle_klass(); |
2251 if (k != NULL && EnableMethodHandles) { | 2251 if (k != NULL && EnableMethodHandles) { |
2252 compute_offset(_vmindex_offset, k, vmSymbols::vmindex_name(), vmSymbols::int_signature(), true); | 2252 compute_offset(_vmindex_offset, k, vmSymbols::vmindex_name(), vmSymbols::int_signature(), true); |
2253 } | 2253 } |
2254 } | 2254 } |
2255 | 2255 |
2256 void sun_dyn_BoundMethodHandle::compute_offsets() { | 2256 void java_lang_invoke_BoundMethodHandle::compute_offsets() { |
2257 klassOop k = SystemDictionary::BoundMethodHandle_klass(); | 2257 klassOop k = SystemDictionary::BoundMethodHandle_klass(); |
2258 if (k != NULL && EnableMethodHandles) { | 2258 if (k != NULL && EnableMethodHandles) { |
2259 compute_offset(_vmargslot_offset, k, vmSymbols::vmargslot_name(), vmSymbols::int_signature(), true); | 2259 compute_offset(_vmargslot_offset, k, vmSymbols::vmargslot_name(), vmSymbols::int_signature(), true); |
2260 compute_offset(_argument_offset, k, vmSymbols::argument_name(), vmSymbols::object_signature(), true); | 2260 compute_offset(_argument_offset, k, vmSymbols::argument_name(), vmSymbols::object_signature(), true); |
2261 } | 2261 } |
2262 } | 2262 } |
2263 | 2263 |
2264 void sun_dyn_AdapterMethodHandle::compute_offsets() { | 2264 void java_lang_invoke_AdapterMethodHandle::compute_offsets() { |
2265 klassOop k = SystemDictionary::AdapterMethodHandle_klass(); | 2265 klassOop k = SystemDictionary::AdapterMethodHandle_klass(); |
2266 if (k != NULL && EnableMethodHandles) { | 2266 if (k != NULL && EnableMethodHandles) { |
2267 compute_offset(_conversion_offset, k, vmSymbols::conversion_name(), vmSymbols::int_signature(), true); | 2267 compute_offset(_conversion_offset, k, vmSymbols::conversion_name(), vmSymbols::int_signature(), true); |
2268 } | 2268 } |
2269 } | 2269 } |
2270 | 2270 |
2271 oop java_dyn_MethodHandle::type(oop mh) { | 2271 oop java_lang_invoke_MethodHandle::type(oop mh) { |
2272 return mh->obj_field(_type_offset); | 2272 return mh->obj_field(_type_offset); |
2273 } | 2273 } |
2274 | 2274 |
2275 void java_dyn_MethodHandle::set_type(oop mh, oop mtype) { | 2275 void java_lang_invoke_MethodHandle::set_type(oop mh, oop mtype) { |
2276 mh->obj_field_put(_type_offset, mtype); | 2276 mh->obj_field_put(_type_offset, mtype); |
2277 } | 2277 } |
2278 | 2278 |
2279 int java_dyn_MethodHandle::vmslots(oop mh) { | 2279 int java_lang_invoke_MethodHandle::vmslots(oop mh) { |
2280 int vmslots_offset = _vmslots_offset; | 2280 int vmslots_offset = _vmslots_offset; |
2281 if (vmslots_offset != 0) { | 2281 if (vmslots_offset != 0) { |
2282 #ifdef ASSERT | 2282 #ifdef ASSERT |
2283 int x = mh->int_field(vmslots_offset); | 2283 int x = mh->int_field(vmslots_offset); |
2284 int y = compute_vmslots(mh); | 2284 int y = compute_vmslots(mh); |
2289 return compute_vmslots(mh); | 2289 return compute_vmslots(mh); |
2290 } | 2290 } |
2291 } | 2291 } |
2292 | 2292 |
2293 // if MH.vmslots exists, hoist into it the value of type.form.vmslots | 2293 // if MH.vmslots exists, hoist into it the value of type.form.vmslots |
2294 void java_dyn_MethodHandle::init_vmslots(oop mh) { | 2294 void java_lang_invoke_MethodHandle::init_vmslots(oop mh) { |
2295 int vmslots_offset = _vmslots_offset; | 2295 int vmslots_offset = _vmslots_offset; |
2296 if (vmslots_offset != 0) { | 2296 if (vmslots_offset != 0) { |
2297 mh->int_field_put(vmslots_offset, compute_vmslots(mh)); | 2297 mh->int_field_put(vmslots_offset, compute_vmslots(mh)); |
2298 } | 2298 } |
2299 } | 2299 } |
2300 | 2300 |
2301 // fetch type.form.vmslots, which is the number of JVM stack slots | 2301 // fetch type.form.vmslots, which is the number of JVM stack slots |
2302 // required to carry the arguments of this MH | 2302 // required to carry the arguments of this MH |
2303 int java_dyn_MethodHandle::compute_vmslots(oop mh) { | 2303 int java_lang_invoke_MethodHandle::compute_vmslots(oop mh) { |
2304 oop mtype = type(mh); | 2304 oop mtype = type(mh); |
2305 if (mtype == NULL) return 0; // Java code would get NPE | 2305 if (mtype == NULL) return 0; // Java code would get NPE |
2306 oop form = java_dyn_MethodType::form(mtype); | 2306 oop form = java_lang_invoke_MethodType::form(mtype); |
2307 if (form == NULL) return 0; // Java code would get NPE | 2307 if (form == NULL) return 0; // Java code would get NPE |
2308 return java_dyn_MethodTypeForm::vmslots(form); | 2308 return java_lang_invoke_MethodTypeForm::vmslots(form); |
2309 } | 2309 } |
2310 | 2310 |
2311 // fetch the low-level entry point for this mh | 2311 // fetch the low-level entry point for this mh |
2312 MethodHandleEntry* java_dyn_MethodHandle::vmentry(oop mh) { | 2312 MethodHandleEntry* java_lang_invoke_MethodHandle::vmentry(oop mh) { |
2313 return (MethodHandleEntry*) mh->address_field(_vmentry_offset); | 2313 return (MethodHandleEntry*) mh->address_field(_vmentry_offset); |
2314 } | 2314 } |
2315 | 2315 |
2316 void java_dyn_MethodHandle::set_vmentry(oop mh, MethodHandleEntry* me) { | 2316 void java_lang_invoke_MethodHandle::set_vmentry(oop mh, MethodHandleEntry* me) { |
2317 assert(_vmentry_offset != 0, "must be present"); | 2317 assert(_vmentry_offset != 0, "must be present"); |
2318 | 2318 |
2319 // This is always the final step that initializes a valid method handle: | 2319 // This is always the final step that initializes a valid method handle: |
2320 mh->release_address_field_put(_vmentry_offset, (address) me); | 2320 mh->release_address_field_put(_vmentry_offset, (address) me); |
2321 | 2321 |
2325 // But just in case, we use release_address_field_put. | 2325 // But just in case, we use release_address_field_put. |
2326 } | 2326 } |
2327 | 2327 |
2328 /// MemberName accessors | 2328 /// MemberName accessors |
2329 | 2329 |
2330 oop sun_dyn_MemberName::clazz(oop mname) { | 2330 oop java_lang_invoke_MemberName::clazz(oop mname) { |
2331 assert(is_instance(mname), "wrong type"); | 2331 assert(is_instance(mname), "wrong type"); |
2332 return mname->obj_field(_clazz_offset); | 2332 return mname->obj_field(_clazz_offset); |
2333 } | 2333 } |
2334 | 2334 |
2335 void sun_dyn_MemberName::set_clazz(oop mname, oop clazz) { | 2335 void java_lang_invoke_MemberName::set_clazz(oop mname, oop clazz) { |
2336 assert(is_instance(mname), "wrong type"); | 2336 assert(is_instance(mname), "wrong type"); |
2337 mname->obj_field_put(_clazz_offset, clazz); | 2337 mname->obj_field_put(_clazz_offset, clazz); |
2338 } | 2338 } |
2339 | 2339 |
2340 oop sun_dyn_MemberName::name(oop mname) { | 2340 oop java_lang_invoke_MemberName::name(oop mname) { |
2341 assert(is_instance(mname), "wrong type"); | 2341 assert(is_instance(mname), "wrong type"); |
2342 return mname->obj_field(_name_offset); | 2342 return mname->obj_field(_name_offset); |
2343 } | 2343 } |
2344 | 2344 |
2345 void sun_dyn_MemberName::set_name(oop mname, oop name) { | 2345 void java_lang_invoke_MemberName::set_name(oop mname, oop name) { |
2346 assert(is_instance(mname), "wrong type"); | 2346 assert(is_instance(mname), "wrong type"); |
2347 mname->obj_field_put(_name_offset, name); | 2347 mname->obj_field_put(_name_offset, name); |
2348 } | 2348 } |
2349 | 2349 |
2350 oop sun_dyn_MemberName::type(oop mname) { | 2350 oop java_lang_invoke_MemberName::type(oop mname) { |
2351 assert(is_instance(mname), "wrong type"); | 2351 assert(is_instance(mname), "wrong type"); |
2352 return mname->obj_field(_type_offset); | 2352 return mname->obj_field(_type_offset); |
2353 } | 2353 } |
2354 | 2354 |
2355 void sun_dyn_MemberName::set_type(oop mname, oop type) { | 2355 void java_lang_invoke_MemberName::set_type(oop mname, oop type) { |
2356 assert(is_instance(mname), "wrong type"); | 2356 assert(is_instance(mname), "wrong type"); |
2357 mname->obj_field_put(_type_offset, type); | 2357 mname->obj_field_put(_type_offset, type); |
2358 } | 2358 } |
2359 | 2359 |
2360 int sun_dyn_MemberName::flags(oop mname) { | 2360 int java_lang_invoke_MemberName::flags(oop mname) { |
2361 assert(is_instance(mname), "wrong type"); | 2361 assert(is_instance(mname), "wrong type"); |
2362 return mname->int_field(_flags_offset); | 2362 return mname->int_field(_flags_offset); |
2363 } | 2363 } |
2364 | 2364 |
2365 void sun_dyn_MemberName::set_flags(oop mname, int flags) { | 2365 void java_lang_invoke_MemberName::set_flags(oop mname, int flags) { |
2366 assert(is_instance(mname), "wrong type"); | 2366 assert(is_instance(mname), "wrong type"); |
2367 mname->int_field_put(_flags_offset, flags); | 2367 mname->int_field_put(_flags_offset, flags); |
2368 } | 2368 } |
2369 | 2369 |
2370 oop sun_dyn_MemberName::vmtarget(oop mname) { | 2370 oop java_lang_invoke_MemberName::vmtarget(oop mname) { |
2371 assert(is_instance(mname), "wrong type"); | 2371 assert(is_instance(mname), "wrong type"); |
2372 return mname->obj_field(_vmtarget_offset); | 2372 return mname->obj_field(_vmtarget_offset); |
2373 } | 2373 } |
2374 | 2374 |
2375 void sun_dyn_MemberName::set_vmtarget(oop mname, oop ref) { | 2375 void java_lang_invoke_MemberName::set_vmtarget(oop mname, oop ref) { |
2376 assert(is_instance(mname), "wrong type"); | 2376 assert(is_instance(mname), "wrong type"); |
2377 mname->obj_field_put(_vmtarget_offset, ref); | 2377 mname->obj_field_put(_vmtarget_offset, ref); |
2378 } | 2378 } |
2379 | 2379 |
2380 int sun_dyn_MemberName::vmindex(oop mname) { | 2380 int java_lang_invoke_MemberName::vmindex(oop mname) { |
2381 assert(is_instance(mname), "wrong type"); | 2381 assert(is_instance(mname), "wrong type"); |
2382 return mname->int_field(_vmindex_offset); | 2382 return mname->int_field(_vmindex_offset); |
2383 } | 2383 } |
2384 | 2384 |
2385 void sun_dyn_MemberName::set_vmindex(oop mname, int index) { | 2385 void java_lang_invoke_MemberName::set_vmindex(oop mname, int index) { |
2386 assert(is_instance(mname), "wrong type"); | 2386 assert(is_instance(mname), "wrong type"); |
2387 mname->int_field_put(_vmindex_offset, index); | 2387 mname->int_field_put(_vmindex_offset, index); |
2388 } | 2388 } |
2389 | 2389 |
2390 oop java_dyn_MethodHandle::vmtarget(oop mh) { | 2390 oop java_lang_invoke_MethodHandle::vmtarget(oop mh) { |
2391 assert(is_instance(mh), "MH only"); | 2391 assert(is_instance(mh), "MH only"); |
2392 return mh->obj_field(_vmtarget_offset); | 2392 return mh->obj_field(_vmtarget_offset); |
2393 } | 2393 } |
2394 | 2394 |
2395 void java_dyn_MethodHandle::set_vmtarget(oop mh, oop ref) { | 2395 void java_lang_invoke_MethodHandle::set_vmtarget(oop mh, oop ref) { |
2396 assert(is_instance(mh), "MH only"); | 2396 assert(is_instance(mh), "MH only"); |
2397 mh->obj_field_put(_vmtarget_offset, ref); | 2397 mh->obj_field_put(_vmtarget_offset, ref); |
2398 } | 2398 } |
2399 | 2399 |
2400 int sun_dyn_DirectMethodHandle::vmindex(oop mh) { | 2400 int java_lang_invoke_DirectMethodHandle::vmindex(oop mh) { |
2401 assert(is_instance(mh), "DMH only"); | 2401 assert(is_instance(mh), "DMH only"); |
2402 return mh->int_field(_vmindex_offset); | 2402 return mh->int_field(_vmindex_offset); |
2403 } | 2403 } |
2404 | 2404 |
2405 void sun_dyn_DirectMethodHandle::set_vmindex(oop mh, int index) { | 2405 void java_lang_invoke_DirectMethodHandle::set_vmindex(oop mh, int index) { |
2406 assert(is_instance(mh), "DMH only"); | 2406 assert(is_instance(mh), "DMH only"); |
2407 mh->int_field_put(_vmindex_offset, index); | 2407 mh->int_field_put(_vmindex_offset, index); |
2408 } | 2408 } |
2409 | 2409 |
2410 int sun_dyn_BoundMethodHandle::vmargslot(oop mh) { | 2410 int java_lang_invoke_BoundMethodHandle::vmargslot(oop mh) { |
2411 assert(is_instance(mh), "BMH only"); | 2411 assert(is_instance(mh), "BMH only"); |
2412 return mh->int_field(_vmargslot_offset); | 2412 return mh->int_field(_vmargslot_offset); |
2413 } | 2413 } |
2414 | 2414 |
2415 oop sun_dyn_BoundMethodHandle::argument(oop mh) { | 2415 oop java_lang_invoke_BoundMethodHandle::argument(oop mh) { |
2416 assert(is_instance(mh), "BMH only"); | 2416 assert(is_instance(mh), "BMH only"); |
2417 return mh->obj_field(_argument_offset); | 2417 return mh->obj_field(_argument_offset); |
2418 } | 2418 } |
2419 | 2419 |
2420 int sun_dyn_AdapterMethodHandle::conversion(oop mh) { | 2420 int java_lang_invoke_AdapterMethodHandle::conversion(oop mh) { |
2421 assert(is_instance(mh), "AMH only"); | 2421 assert(is_instance(mh), "AMH only"); |
2422 return mh->int_field(_conversion_offset); | 2422 return mh->int_field(_conversion_offset); |
2423 } | 2423 } |
2424 | 2424 |
2425 void sun_dyn_AdapterMethodHandle::set_conversion(oop mh, int conv) { | 2425 void java_lang_invoke_AdapterMethodHandle::set_conversion(oop mh, int conv) { |
2426 assert(is_instance(mh), "AMH only"); | 2426 assert(is_instance(mh), "AMH only"); |
2427 mh->int_field_put(_conversion_offset, conv); | 2427 mh->int_field_put(_conversion_offset, conv); |
2428 } | 2428 } |
2429 | 2429 |
2430 | 2430 |
2431 // Support for java_dyn_MethodType | 2431 // Support for java_lang_invoke_MethodType |
2432 | 2432 |
2433 int java_dyn_MethodType::_rtype_offset; | 2433 int java_lang_invoke_MethodType::_rtype_offset; |
2434 int java_dyn_MethodType::_ptypes_offset; | 2434 int java_lang_invoke_MethodType::_ptypes_offset; |
2435 int java_dyn_MethodType::_form_offset; | 2435 int java_lang_invoke_MethodType::_form_offset; |
2436 | 2436 |
2437 void java_dyn_MethodType::compute_offsets() { | 2437 void java_lang_invoke_MethodType::compute_offsets() { |
2438 klassOop k = SystemDictionary::MethodType_klass(); | 2438 klassOop k = SystemDictionary::MethodType_klass(); |
2439 if (k != NULL) { | 2439 if (k != NULL) { |
2440 compute_offset(_rtype_offset, k, vmSymbols::rtype_name(), vmSymbols::class_signature()); | 2440 compute_offset(_rtype_offset, k, vmSymbols::rtype_name(), vmSymbols::class_signature()); |
2441 compute_offset(_ptypes_offset, k, vmSymbols::ptypes_name(), vmSymbols::class_array_signature()); | 2441 compute_offset(_ptypes_offset, k, vmSymbols::ptypes_name(), vmSymbols::class_array_signature()); |
2442 compute_offset(_form_offset, k, vmSymbols::form_name(), vmSymbols::java_dyn_MethodTypeForm_signature()); | 2442 compute_offset(_form_offset, k, vmSymbols::form_name(), vmSymbols::java_lang_invoke_MethodTypeForm_signature()); |
2443 } | 2443 } |
2444 } | 2444 } |
2445 | 2445 |
2446 void java_dyn_MethodType::print_signature(oop mt, outputStream* st) { | 2446 void java_lang_invoke_MethodType::print_signature(oop mt, outputStream* st) { |
2447 st->print("("); | 2447 st->print("("); |
2448 objArrayOop pts = ptypes(mt); | 2448 objArrayOop pts = ptypes(mt); |
2449 for (int i = 0, limit = pts->length(); i < limit; i++) { | 2449 for (int i = 0, limit = pts->length(); i < limit; i++) { |
2450 java_lang_Class::print_signature(pts->obj_at(i), st); | 2450 java_lang_Class::print_signature(pts->obj_at(i), st); |
2451 } | 2451 } |
2452 st->print(")"); | 2452 st->print(")"); |
2453 java_lang_Class::print_signature(rtype(mt), st); | 2453 java_lang_Class::print_signature(rtype(mt), st); |
2454 } | 2454 } |
2455 | 2455 |
2456 Symbol* java_dyn_MethodType::as_signature(oop mt, bool intern_if_not_found, TRAPS) { | 2456 Symbol* java_lang_invoke_MethodType::as_signature(oop mt, bool intern_if_not_found, TRAPS) { |
2457 ResourceMark rm; | 2457 ResourceMark rm; |
2458 stringStream buffer(128); | 2458 stringStream buffer(128); |
2459 print_signature(mt, &buffer); | 2459 print_signature(mt, &buffer); |
2460 const char* sigstr = buffer.base(); | 2460 const char* sigstr = buffer.base(); |
2461 int siglen = (int) buffer.size(); | 2461 int siglen = (int) buffer.size(); |
2466 name = SymbolTable::new_symbol(sigstr, siglen, THREAD); | 2466 name = SymbolTable::new_symbol(sigstr, siglen, THREAD); |
2467 } | 2467 } |
2468 return name; | 2468 return name; |
2469 } | 2469 } |
2470 | 2470 |
2471 oop java_dyn_MethodType::rtype(oop mt) { | 2471 oop java_lang_invoke_MethodType::rtype(oop mt) { |
2472 assert(is_instance(mt), "must be a MethodType"); | 2472 assert(is_instance(mt), "must be a MethodType"); |
2473 return mt->obj_field(_rtype_offset); | 2473 return mt->obj_field(_rtype_offset); |
2474 } | 2474 } |
2475 | 2475 |
2476 objArrayOop java_dyn_MethodType::ptypes(oop mt) { | 2476 objArrayOop java_lang_invoke_MethodType::ptypes(oop mt) { |
2477 assert(is_instance(mt), "must be a MethodType"); | 2477 assert(is_instance(mt), "must be a MethodType"); |
2478 return (objArrayOop) mt->obj_field(_ptypes_offset); | 2478 return (objArrayOop) mt->obj_field(_ptypes_offset); |
2479 } | 2479 } |
2480 | 2480 |
2481 oop java_dyn_MethodType::form(oop mt) { | 2481 oop java_lang_invoke_MethodType::form(oop mt) { |
2482 assert(is_instance(mt), "must be a MethodType"); | 2482 assert(is_instance(mt), "must be a MethodType"); |
2483 return mt->obj_field(_form_offset); | 2483 return mt->obj_field(_form_offset); |
2484 } | 2484 } |
2485 | 2485 |
2486 oop java_dyn_MethodType::ptype(oop mt, int idx) { | 2486 oop java_lang_invoke_MethodType::ptype(oop mt, int idx) { |
2487 return ptypes(mt)->obj_at(idx); | 2487 return ptypes(mt)->obj_at(idx); |
2488 } | 2488 } |
2489 | 2489 |
2490 int java_dyn_MethodType::ptype_count(oop mt) { | 2490 int java_lang_invoke_MethodType::ptype_count(oop mt) { |
2491 return ptypes(mt)->length(); | 2491 return ptypes(mt)->length(); |
2492 } | 2492 } |
2493 | 2493 |
2494 | 2494 |
2495 | 2495 |
2496 // Support for java_dyn_MethodTypeForm | 2496 // Support for java_lang_invoke_MethodTypeForm |
2497 | 2497 |
2498 int java_dyn_MethodTypeForm::_vmslots_offset; | 2498 int java_lang_invoke_MethodTypeForm::_vmslots_offset; |
2499 int java_dyn_MethodTypeForm::_erasedType_offset; | 2499 int java_lang_invoke_MethodTypeForm::_erasedType_offset; |
2500 int java_dyn_MethodTypeForm::_genericInvoker_offset; | 2500 int java_lang_invoke_MethodTypeForm::_genericInvoker_offset; |
2501 | 2501 |
2502 void java_dyn_MethodTypeForm::compute_offsets() { | 2502 void java_lang_invoke_MethodTypeForm::compute_offsets() { |
2503 klassOop k = SystemDictionary::MethodTypeForm_klass(); | 2503 klassOop k = SystemDictionary::MethodTypeForm_klass(); |
2504 if (k != NULL) { | 2504 if (k != NULL) { |
2505 compute_optional_offset(_vmslots_offset, k, vmSymbols::vmslots_name(), vmSymbols::int_signature(), true); | 2505 compute_optional_offset(_vmslots_offset, k, vmSymbols::vmslots_name(), vmSymbols::int_signature(), true); |
2506 compute_optional_offset(_erasedType_offset, k, vmSymbols::erasedType_name(), vmSymbols::java_dyn_MethodType_signature(), true); | 2506 compute_optional_offset(_erasedType_offset, k, vmSymbols::erasedType_name(), vmSymbols::java_lang_invoke_MethodType_signature(), true); |
2507 compute_optional_offset(_genericInvoker_offset, k, vmSymbols::genericInvoker_name(), vmSymbols::java_dyn_MethodHandle_signature(), true); | 2507 compute_optional_offset(_genericInvoker_offset, k, vmSymbols::genericInvoker_name(), vmSymbols::java_lang_invoke_MethodHandle_signature(), true); |
2508 if (_genericInvoker_offset == 0) _genericInvoker_offset = -1; // set to explicit "empty" value | 2508 if (_genericInvoker_offset == 0) _genericInvoker_offset = -1; // set to explicit "empty" value |
2509 } | 2509 } |
2510 } | 2510 } |
2511 | 2511 |
2512 int java_dyn_MethodTypeForm::vmslots(oop mtform) { | 2512 int java_lang_invoke_MethodTypeForm::vmslots(oop mtform) { |
2513 assert(mtform->klass() == SystemDictionary::MethodTypeForm_klass(), "MTForm only"); | 2513 assert(mtform->klass() == SystemDictionary::MethodTypeForm_klass(), "MTForm only"); |
2514 return mtform->int_field(_vmslots_offset); | 2514 return mtform->int_field(_vmslots_offset); |
2515 } | 2515 } |
2516 | 2516 |
2517 oop java_dyn_MethodTypeForm::erasedType(oop mtform) { | 2517 oop java_lang_invoke_MethodTypeForm::erasedType(oop mtform) { |
2518 assert(mtform->klass() == SystemDictionary::MethodTypeForm_klass(), "MTForm only"); | 2518 assert(mtform->klass() == SystemDictionary::MethodTypeForm_klass(), "MTForm only"); |
2519 return mtform->obj_field(_erasedType_offset); | 2519 return mtform->obj_field(_erasedType_offset); |
2520 } | 2520 } |
2521 | 2521 |
2522 oop java_dyn_MethodTypeForm::genericInvoker(oop mtform) { | 2522 oop java_lang_invoke_MethodTypeForm::genericInvoker(oop mtform) { |
2523 assert(mtform->klass() == SystemDictionary::MethodTypeForm_klass(), "MTForm only"); | 2523 assert(mtform->klass() == SystemDictionary::MethodTypeForm_klass(), "MTForm only"); |
2524 return mtform->obj_field(_genericInvoker_offset); | 2524 return mtform->obj_field(_genericInvoker_offset); |
2525 } | 2525 } |
2526 | 2526 |
2527 | 2527 |
2528 // Support for java_dyn_CallSite | 2528 // Support for java_lang_invoke_CallSite |
2529 | 2529 |
2530 int java_dyn_CallSite::_target_offset; | 2530 int java_lang_invoke_CallSite::_target_offset; |
2531 | 2531 |
2532 void java_dyn_CallSite::compute_offsets() { | 2532 void java_lang_invoke_CallSite::compute_offsets() { |
2533 if (!EnableInvokeDynamic) return; | 2533 if (!EnableInvokeDynamic) return; |
2534 klassOop k = SystemDictionary::CallSite_klass(); | 2534 klassOop k = SystemDictionary::CallSite_klass(); |
2535 if (k != NULL) { | 2535 if (k != NULL) { |
2536 compute_offset(_target_offset, k, vmSymbols::target_name(), vmSymbols::java_dyn_MethodHandle_signature()); | 2536 compute_offset(_target_offset, k, vmSymbols::target_name(), vmSymbols::java_lang_invoke_MethodHandle_signature()); |
2537 } | 2537 } |
2538 } | 2538 } |
2539 | 2539 |
2540 oop java_dyn_CallSite::target(oop site) { | 2540 oop java_lang_invoke_CallSite::target(oop site) { |
2541 return site->obj_field(_target_offset); | 2541 return site->obj_field(_target_offset); |
2542 } | 2542 } |
2543 | 2543 |
2544 void java_dyn_CallSite::set_target(oop site, oop target) { | 2544 void java_lang_invoke_CallSite::set_target(oop site, oop target) { |
2545 site->obj_field_put(_target_offset, target); | 2545 site->obj_field_put(_target_offset, target); |
2546 } | 2546 } |
2547 | 2547 |
2548 | 2548 |
2549 // Support for java_security_AccessControlContext | 2549 // Support for java_security_AccessControlContext |
2879 java_lang_Class::compute_offsets(); | 2879 java_lang_Class::compute_offsets(); |
2880 java_lang_System::compute_offsets(); | 2880 java_lang_System::compute_offsets(); |
2881 java_lang_Thread::compute_offsets(); | 2881 java_lang_Thread::compute_offsets(); |
2882 java_lang_ThreadGroup::compute_offsets(); | 2882 java_lang_ThreadGroup::compute_offsets(); |
2883 if (EnableMethodHandles) { | 2883 if (EnableMethodHandles) { |
2884 java_dyn_MethodHandle::compute_offsets(); | 2884 java_lang_invoke_MethodHandle::compute_offsets(); |
2885 sun_dyn_MemberName::compute_offsets(); | 2885 java_lang_invoke_MemberName::compute_offsets(); |
2886 sun_dyn_DirectMethodHandle::compute_offsets(); | 2886 java_lang_invoke_DirectMethodHandle::compute_offsets(); |
2887 sun_dyn_BoundMethodHandle::compute_offsets(); | 2887 java_lang_invoke_BoundMethodHandle::compute_offsets(); |
2888 sun_dyn_AdapterMethodHandle::compute_offsets(); | 2888 java_lang_invoke_AdapterMethodHandle::compute_offsets(); |
2889 java_dyn_MethodType::compute_offsets(); | 2889 java_lang_invoke_MethodType::compute_offsets(); |
2890 java_dyn_MethodTypeForm::compute_offsets(); | 2890 java_lang_invoke_MethodTypeForm::compute_offsets(); |
2891 } | 2891 } |
2892 if (EnableInvokeDynamic) { | 2892 if (EnableInvokeDynamic) { |
2893 java_dyn_CallSite::compute_offsets(); | 2893 java_lang_invoke_CallSite::compute_offsets(); |
2894 } | 2894 } |
2895 java_security_AccessControlContext::compute_offsets(); | 2895 java_security_AccessControlContext::compute_offsets(); |
2896 // Initialize reflection classes. The layouts of these classes | 2896 // Initialize reflection classes. The layouts of these classes |
2897 // changed with the new reflection implementation in JDK 1.4, and | 2897 // changed with the new reflection implementation in JDK 1.4, and |
2898 // since the Universe doesn't know what JDK version it is until this | 2898 // since the Universe doesn't know what JDK version it is until this |