1 /* 2 * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 */ 23 24 #include "precompiled.hpp" 25 #include "code/codeCache.hpp" 26 #include "code/scopeDesc.hpp" 27 #include "interpreter/linkResolver.hpp" 28 #include "memory/oopFactory.hpp" 29 #include "oops/generateOopMap.hpp" 30 #include "oops/fieldStreams.hpp" 31 #include "oops/oop.inline.hpp" 32 #include "oops/objArrayOop.inline.hpp" 33 #include "runtime/fieldDescriptor.hpp" 34 #include "runtime/javaCalls.hpp" 35 #include "jvmci/jvmciRuntime.hpp" 36 #include "compiler/abstractCompiler.hpp" 37 #include "compiler/compileBroker.hpp" 38 #include "compiler/compilerOracle.hpp" 39 #include "compiler/disassembler.hpp" 40 #include "compiler/oopMap.hpp" 41 #include "jvmci/jvmciCompilerToVM.hpp" 42 #include "jvmci/jvmciCompiler.hpp" 43 #include "jvmci/jvmciEnv.hpp" 44 #include "jvmci/jvmciJavaClasses.hpp" 45 #include "jvmci/jvmciCodeInstaller.hpp" 46 #include "jvmci/vmStructs_jvmci.hpp" 47 #include "gc/g1/heapRegion.hpp" 48 #include "runtime/javaCalls.hpp" 49 #include "runtime/deoptimization.hpp" 50 #include "runtime/vframe.hpp" 51 #include "runtime/vframe_hp.hpp" 52 #include "runtime/vmStructs.hpp" 53 54 55 // Entry to native method implementation that transitions current thread to '_thread_in_vm'. 56 #define C2V_VMENTRY(result_type, name, signature) \ 57 JNIEXPORT result_type JNICALL c2v_ ## name signature { \ 58 TRACE_jvmci_1("CompilerToVM::" #name); \ 59 TRACE_CALL(result_type, jvmci_ ## name signature) \ 60 JVMCI_VM_ENTRY_MARK; \ 61 62 #define C2V_END } 63 64 oop CompilerToVM::get_jvmci_method(const methodHandle& method, TRAPS) { 65 if (method() != NULL) { 66 JavaValue result(T_OBJECT); 67 JavaCallArguments args; 68 args.push_long((jlong) (address) method()); 69 JavaCalls::call_static(&result, SystemDictionary::HotSpotResolvedJavaMethodImpl_klass(), vmSymbols::fromMetaspace_name(), vmSymbols::method_fromMetaspace_signature(), &args, CHECK_NULL); 70 71 return (oop)result.get_jobject(); 72 } 73 return NULL; 74 } 75 76 oop CompilerToVM::get_jvmci_type(KlassHandle klass, TRAPS) { 77 if (klass() != NULL) { 78 JavaValue result(T_OBJECT); 79 JavaCallArguments args; 80 args.push_oop(klass->java_mirror()); 81 JavaCalls::call_static(&result, SystemDictionary::HotSpotResolvedObjectTypeImpl_klass(), vmSymbols::fromMetaspace_name(), vmSymbols::klass_fromMetaspace_signature(), &args, CHECK_NULL); 82 83 return (oop)result.get_jobject(); 84 } 85 return NULL; 86 } 87 88 extern "C" { 89 extern VMStructEntry* jvmciHotSpotVMStructs; 90 extern uint64_t jvmciHotSpotVMStructEntryTypeNameOffset; 91 extern uint64_t jvmciHotSpotVMStructEntryFieldNameOffset; 92 extern uint64_t jvmciHotSpotVMStructEntryTypeStringOffset; 93 extern uint64_t jvmciHotSpotVMStructEntryIsStaticOffset; 94 extern uint64_t jvmciHotSpotVMStructEntryOffsetOffset; 95 extern uint64_t jvmciHotSpotVMStructEntryAddressOffset; 96 extern uint64_t jvmciHotSpotVMStructEntryArrayStride; 97 98 extern VMTypeEntry* jvmciHotSpotVMTypes; 99 extern uint64_t jvmciHotSpotVMTypeEntryTypeNameOffset; 100 extern uint64_t jvmciHotSpotVMTypeEntrySuperclassNameOffset; 101 extern uint64_t jvmciHotSpotVMTypeEntryIsOopTypeOffset; 102 extern uint64_t jvmciHotSpotVMTypeEntryIsIntegerTypeOffset; 103 extern uint64_t jvmciHotSpotVMTypeEntryIsUnsignedOffset; 104 extern uint64_t jvmciHotSpotVMTypeEntrySizeOffset; 105 extern uint64_t jvmciHotSpotVMTypeEntryArrayStride; 106 107 extern VMIntConstantEntry* jvmciHotSpotVMIntConstants; 108 extern uint64_t jvmciHotSpotVMIntConstantEntryNameOffset; 109 extern uint64_t jvmciHotSpotVMIntConstantEntryValueOffset; 110 extern uint64_t jvmciHotSpotVMIntConstantEntryArrayStride; 111 112 extern VMLongConstantEntry* jvmciHotSpotVMLongConstants; 113 extern uint64_t jvmciHotSpotVMLongConstantEntryNameOffset; 114 extern uint64_t jvmciHotSpotVMLongConstantEntryValueOffset; 115 extern uint64_t jvmciHotSpotVMLongConstantEntryArrayStride; 116 117 extern VMAddressEntry* jvmciHotSpotVMAddresses; 118 extern uint64_t jvmciHotSpotVMAddressEntryNameOffset; 119 extern uint64_t jvmciHotSpotVMAddressEntryValueOffset; 120 extern uint64_t jvmciHotSpotVMAddressEntryArrayStride; 121 } 122 123 int CompilerToVM::Data::InstanceKlass_vtable_start_offset; 124 int CompilerToVM::Data::InstanceKlass_vtable_length_offset; 125 126 int CompilerToVM::Data::Method_extra_stack_entries; 127 128 address CompilerToVM::Data::SharedRuntime_ic_miss_stub; 129 address CompilerToVM::Data::SharedRuntime_handle_wrong_method_stub; 130 address CompilerToVM::Data::SharedRuntime_deopt_blob_unpack; 131 address CompilerToVM::Data::SharedRuntime_deopt_blob_uncommon_trap; 132 133 size_t CompilerToVM::Data::ThreadLocalAllocBuffer_alignment_reserve; 134 135 CollectedHeap* CompilerToVM::Data::Universe_collectedHeap; 136 int CompilerToVM::Data::Universe_base_vtable_size; 137 address CompilerToVM::Data::Universe_narrow_oop_base; 138 int CompilerToVM::Data::Universe_narrow_oop_shift; 139 address CompilerToVM::Data::Universe_narrow_klass_base; 140 int CompilerToVM::Data::Universe_narrow_klass_shift; 141 void* CompilerToVM::Data::Universe_non_oop_bits; 142 uintptr_t CompilerToVM::Data::Universe_verify_oop_mask; 143 uintptr_t CompilerToVM::Data::Universe_verify_oop_bits; 144 145 bool CompilerToVM::Data::_supports_inline_contig_alloc; 146 HeapWord** CompilerToVM::Data::_heap_end_addr; 147 HeapWord** CompilerToVM::Data::_heap_top_addr; 148 149 jbyte* CompilerToVM::Data::cardtable_start_address; 150 int CompilerToVM::Data::cardtable_shift; 151 152 int CompilerToVM::Data::vm_page_size; 153 154 void CompilerToVM::Data::initialize() { 155 InstanceKlass_vtable_start_offset = InstanceKlass::vtable_start_offset(); 156 InstanceKlass_vtable_length_offset = InstanceKlass::vtable_length_offset() * HeapWordSize; 157 158 Method_extra_stack_entries = Method::extra_stack_entries(); 159 160 SharedRuntime_ic_miss_stub = SharedRuntime::get_ic_miss_stub(); 161 SharedRuntime_handle_wrong_method_stub = SharedRuntime::get_handle_wrong_method_stub(); 162 SharedRuntime_deopt_blob_unpack = SharedRuntime::deopt_blob()->unpack(); 163 SharedRuntime_deopt_blob_uncommon_trap = SharedRuntime::deopt_blob()->uncommon_trap(); 164 165 ThreadLocalAllocBuffer_alignment_reserve = ThreadLocalAllocBuffer::alignment_reserve(); 166 167 Universe_collectedHeap = Universe::heap(); 168 Universe_base_vtable_size = Universe::base_vtable_size(); 169 Universe_narrow_oop_base = Universe::narrow_oop_base(); 170 Universe_narrow_oop_shift = Universe::narrow_oop_shift(); 171 Universe_narrow_klass_base = Universe::narrow_klass_base(); 172 Universe_narrow_klass_shift = Universe::narrow_klass_shift(); 173 Universe_non_oop_bits = Universe::non_oop_word(); 174 Universe_verify_oop_mask = Universe::verify_oop_mask(); 175 Universe_verify_oop_bits = Universe::verify_oop_bits(); 176 177 _supports_inline_contig_alloc = Universe::heap()->supports_inline_contig_alloc(); 178 _heap_end_addr = _supports_inline_contig_alloc ? Universe::heap()->end_addr() : (HeapWord**) -1; 179 _heap_top_addr = _supports_inline_contig_alloc ? Universe::heap()->top_addr() : (HeapWord**) -1; 180 181 BarrierSet* bs = Universe::heap()->barrier_set(); 182 switch (bs->kind()) { 183 case BarrierSet::CardTableModRef: 184 case BarrierSet::CardTableForRS: 185 case BarrierSet::CardTableExtension: 186 case BarrierSet::G1SATBCT: 187 case BarrierSet::G1SATBCTLogging: { 188 jbyte* base = barrier_set_cast<CardTableModRefBS>(bs)->byte_map_base; 189 assert(base != 0, "unexpected byte_map_base"); 190 cardtable_start_address = base; 191 cardtable_shift = CardTableModRefBS::card_shift; 192 break; 193 } 194 case BarrierSet::ModRef: 195 cardtable_start_address = 0; 196 cardtable_shift = 0; 197 // No post barriers 198 break; 199 default: 200 ShouldNotReachHere(); 201 break; 202 } 203 204 vm_page_size = os::vm_page_size(); 205 } 206 207 /** 208 * We put all jvmciHotSpotVM values in an array so we can read them easily from Java. 209 */ 210 static uintptr_t ciHotSpotVMData[28]; 211 212 C2V_VMENTRY(jlong, initializeConfiguration, (JNIEnv *env, jobject)) 213 ciHotSpotVMData[0] = (uintptr_t) jvmciHotSpotVMStructs; 214 ciHotSpotVMData[1] = jvmciHotSpotVMStructEntryTypeNameOffset; 215 ciHotSpotVMData[2] = jvmciHotSpotVMStructEntryFieldNameOffset; 216 ciHotSpotVMData[3] = jvmciHotSpotVMStructEntryTypeStringOffset; 217 ciHotSpotVMData[4] = jvmciHotSpotVMStructEntryIsStaticOffset; 218 ciHotSpotVMData[5] = jvmciHotSpotVMStructEntryOffsetOffset; 219 ciHotSpotVMData[6] = jvmciHotSpotVMStructEntryAddressOffset; 220 ciHotSpotVMData[7] = jvmciHotSpotVMStructEntryArrayStride; 221 222 ciHotSpotVMData[8] = (uintptr_t) jvmciHotSpotVMTypes; 223 ciHotSpotVMData[9] = jvmciHotSpotVMTypeEntryTypeNameOffset; 224 ciHotSpotVMData[10] = jvmciHotSpotVMTypeEntrySuperclassNameOffset; 225 ciHotSpotVMData[11] = jvmciHotSpotVMTypeEntryIsOopTypeOffset; 226 ciHotSpotVMData[12] = jvmciHotSpotVMTypeEntryIsIntegerTypeOffset; 227 ciHotSpotVMData[13] = jvmciHotSpotVMTypeEntryIsUnsignedOffset; 228 ciHotSpotVMData[14] = jvmciHotSpotVMTypeEntrySizeOffset; 229 ciHotSpotVMData[15] = jvmciHotSpotVMTypeEntryArrayStride; 230 231 ciHotSpotVMData[16] = (uintptr_t) jvmciHotSpotVMIntConstants; 232 ciHotSpotVMData[17] = jvmciHotSpotVMIntConstantEntryNameOffset; 233 ciHotSpotVMData[18] = jvmciHotSpotVMIntConstantEntryValueOffset; 234 ciHotSpotVMData[19] = jvmciHotSpotVMIntConstantEntryArrayStride; 235 236 ciHotSpotVMData[20] = (uintptr_t) jvmciHotSpotVMLongConstants; 237 ciHotSpotVMData[21] = jvmciHotSpotVMLongConstantEntryNameOffset; 238 ciHotSpotVMData[22] = jvmciHotSpotVMLongConstantEntryValueOffset; 239 ciHotSpotVMData[23] = jvmciHotSpotVMLongConstantEntryArrayStride; 240 241 ciHotSpotVMData[24] = (uintptr_t) jvmciHotSpotVMAddresses; 242 ciHotSpotVMData[25] = jvmciHotSpotVMAddressEntryNameOffset; 243 ciHotSpotVMData[26] = jvmciHotSpotVMAddressEntryValueOffset; 244 ciHotSpotVMData[27] = jvmciHotSpotVMAddressEntryArrayStride; 245 246 CompilerToVM::Data::initialize(); 247 248 return (jlong) (address) &ciHotSpotVMData; 249 C2V_END 250 251 C2V_VMENTRY(jbyteArray, getBytecode, (JNIEnv *, jobject, jobject jvmci_method)) 252 methodHandle method = CompilerToVM::asMethod(jvmci_method); 253 ResourceMark rm; 254 255 int code_size = method->code_size(); 256 typeArrayOop reconstituted_code = oopFactory::new_byteArray(code_size, CHECK_NULL); 257 258 guarantee(method->method_holder()->is_rewritten(), "Method's holder should be rewritten"); 259 // iterate over all bytecodes and replace non-Java bytecodes 260 261 for (BytecodeStream s(method); s.next() != Bytecodes::_illegal; ) { 262 Bytecodes::Code code = s.code(); 263 Bytecodes::Code raw_code = s.raw_code(); 264 int bci = s.bci(); 265 int len = s.instruction_size(); 266 267 // Restore original byte code. 268 reconstituted_code->byte_at_put(bci, (jbyte) (s.is_wide()? Bytecodes::_wide : code)); 269 if (len > 1) { 270 memcpy(reconstituted_code->byte_at_addr(bci + 1), s.bcp()+1, len-1); 271 } 272 273 if (len > 1) { 274 // Restore the big-endian constant pool indexes. 275 // Cf. Rewriter::scan_method 276 switch (code) { 277 case Bytecodes::_getstatic: 278 case Bytecodes::_putstatic: 279 case Bytecodes::_getfield: 280 case Bytecodes::_putfield: 281 case Bytecodes::_invokevirtual: 282 case Bytecodes::_invokespecial: 283 case Bytecodes::_invokestatic: 284 case Bytecodes::_invokeinterface: 285 case Bytecodes::_invokehandle: { 286 int cp_index = Bytes::get_native_u2((address) reconstituted_code->byte_at_addr(bci + 1)); 287 Bytes::put_Java_u2((address) reconstituted_code->byte_at_addr(bci + 1), (u2) cp_index); 288 break; 289 } 290 291 case Bytecodes::_invokedynamic: 292 int cp_index = Bytes::get_native_u4((address) reconstituted_code->byte_at_addr(bci + 1)); 293 Bytes::put_Java_u4((address) reconstituted_code->byte_at_addr(bci + 1), (u4) cp_index); 294 break; 295 } 296 297 // Not all ldc byte code are rewritten. 298 switch (raw_code) { 299 case Bytecodes::_fast_aldc: { 300 int cpc_index = reconstituted_code->byte_at(bci + 1) & 0xff; 301 int cp_index = method->constants()->object_to_cp_index(cpc_index); 302 assert(cp_index < method->constants()->length(), "sanity check"); 303 reconstituted_code->byte_at_put(bci + 1, (jbyte) cp_index); 304 break; 305 } 306 307 case Bytecodes::_fast_aldc_w: { 308 int cpc_index = Bytes::get_native_u2((address) reconstituted_code->byte_at_addr(bci + 1)); 309 int cp_index = method->constants()->object_to_cp_index(cpc_index); 310 assert(cp_index < method->constants()->length(), "sanity check"); 311 Bytes::put_Java_u2((address) reconstituted_code->byte_at_addr(bci + 1), (u2) cp_index); 312 break; 313 } 314 } 315 } 316 } 317 318 return (jbyteArray) JNIHandles::make_local(THREAD, reconstituted_code); 319 C2V_END 320 321 C2V_VMENTRY(jint, getExceptionTableLength, (JNIEnv *, jobject, jobject jvmci_method)) 322 ResourceMark rm; 323 methodHandle method = CompilerToVM::asMethod(jvmci_method); 324 return method->exception_table_length(); 325 C2V_END 326 327 C2V_VMENTRY(jlong, getExceptionTableStart, (JNIEnv *, jobject, jobject jvmci_method)) 328 ResourceMark rm; 329 methodHandle method = CompilerToVM::asMethod(jvmci_method); 330 if (method->exception_table_length() == 0) { 331 return 0L; 332 } 333 return (jlong) (address) method->exception_table_start(); 334 C2V_END 335 336 C2V_VMENTRY(jobject, getResolvedJavaMethodAtSlot, (JNIEnv *, jobject, jclass holder_handle, jint slot)) 337 oop java_class = JNIHandles::resolve(holder_handle); 338 Klass* holder = java_lang_Class::as_Klass(java_class); 339 methodHandle method = InstanceKlass::cast(holder)->method_with_idnum(slot); 340 oop result = CompilerToVM::get_jvmci_method(method, CHECK_NULL); 341 return JNIHandles::make_local(THREAD, result); 342 } 343 344 C2V_VMENTRY(jobject, getResolvedJavaMethod, (JNIEnv *, jobject, jobject base, jlong offset)) 345 methodHandle method; 346 oop base_object = JNIHandles::resolve(base); 347 if (base_object == NULL) { 348 method = *((Method**)(offset)); 349 } else if (base_object->is_a(SystemDictionary::MemberName_klass())) { 350 method = (Method*) (intptr_t) base_object->long_field(offset); 351 } else if (base_object->is_a(SystemDictionary::HotSpotResolvedJavaMethodImpl_klass())) { 352 method = *((Method**)(HotSpotResolvedJavaMethodImpl::metaspaceMethod(base_object) + offset)); 353 } else { 354 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), 355 err_msg("Unexpected type: %s", base_object->klass()->external_name())); 356 } 357 assert (method.is_null() || method->is_method(), "invalid read"); 358 oop result = CompilerToVM::get_jvmci_method(method, CHECK_NULL); 359 return JNIHandles::make_local(THREAD, result); 360 } 361 362 C2V_VMENTRY(jobject, getConstantPool, (JNIEnv *, jobject, jobject base, jlong offset)) 363 constantPoolHandle cp; 364 oop base_object = JNIHandles::resolve(base); 365 jlong base_address = 0; 366 if (base_object != NULL) { 367 if (base_object->is_a(SystemDictionary::HotSpotResolvedJavaMethodImpl_klass())) { 368 base_address = HotSpotResolvedJavaMethodImpl::metaspaceMethod(base_object); 369 } else if (base_object->is_a(SystemDictionary::HotSpotConstantPool_klass())) { 370 base_address = HotSpotConstantPool::metaspaceConstantPool(base_object); 371 } else if (base_object->is_a(SystemDictionary::HotSpotResolvedObjectTypeImpl_klass())) { 372 base_address = (jlong) CompilerToVM::asKlass(base_object); 373 } else { 374 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), 375 err_msg("Unexpected type: %s", base_object->klass()->external_name())); 376 } 377 } 378 cp = *((ConstantPool**) (intptr_t) (base_address + offset)); 379 if (!cp.is_null()) { 380 JavaValue method_result(T_OBJECT); 381 JavaCallArguments args; 382 args.push_long((jlong) (address) cp()); 383 JavaCalls::call_static(&method_result, SystemDictionary::HotSpotConstantPool_klass(), vmSymbols::fromMetaspace_name(), vmSymbols::constantPool_fromMetaspace_signature(), &args, CHECK_NULL); 384 return JNIHandles::make_local(THREAD, (oop)method_result.get_jobject()); 385 } 386 return NULL; 387 } 388 389 C2V_VMENTRY(jobject, getResolvedJavaType, (JNIEnv *, jobject, jobject base, jlong offset, jboolean compressed)) 390 KlassHandle klass; 391 oop base_object = JNIHandles::resolve(base); 392 jlong base_address = 0; 393 if (base_object != NULL && offset == oopDesc::klass_offset_in_bytes()) { 394 klass = base_object->klass(); 395 } else if (!compressed) { 396 if (base_object != NULL) { 397 if (base_object->is_a(SystemDictionary::HotSpotResolvedJavaMethodImpl_klass())) { 398 base_address = HotSpotResolvedJavaMethodImpl::metaspaceMethod(base_object); 399 } else if (base_object->is_a(SystemDictionary::HotSpotConstantPool_klass())) { 400 base_address = HotSpotConstantPool::metaspaceConstantPool(base_object); 401 } else if (base_object->is_a(SystemDictionary::HotSpotResolvedObjectTypeImpl_klass())) { 402 base_address = (jlong) CompilerToVM::asKlass(base_object); 403 } else if (base_object->is_a(SystemDictionary::Class_klass())) { 404 base_address = (jlong) (address) base_object; 405 } else { 406 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), 407 err_msg("Unexpected arguments: %s " JLONG_FORMAT " %s", base_object->klass()->external_name(), offset, compressed ? "true" : "false")); 408 } 409 } 410 klass = *((Klass**) (intptr_t) (base_address + offset)); 411 } else { 412 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), 413 err_msg("Unexpected arguments: %s " JLONG_FORMAT " %s", base_object->klass()->external_name(), offset, compressed ? "true" : "false")); 414 } 415 assert (klass.is_null() || klass->is_klass(), "invalid read"); 416 oop result = CompilerToVM::get_jvmci_type(klass, CHECK_NULL); 417 return JNIHandles::make_local(THREAD, result); 418 } 419 420 C2V_VMENTRY(jobject, findUniqueConcreteMethod, (JNIEnv *, jobject, jobject jvmci_type, jobject jvmci_method)) 421 ResourceMark rm; 422 methodHandle method = CompilerToVM::asMethod(jvmci_method); 423 KlassHandle holder = CompilerToVM::asKlass(jvmci_type); 424 if (holder->is_interface()) { 425 THROW_MSG_0(vmSymbols::java_lang_InternalError(), err_msg("Interface %s should be handled in Java code", holder->external_name())); 426 } 427 428 methodHandle ucm; 429 { 430 MutexLocker locker(Compile_lock); 431 ucm = Dependencies::find_unique_concrete_method(holder(), method()); 432 } 433 oop result = CompilerToVM::get_jvmci_method(ucm, CHECK_NULL); 434 return JNIHandles::make_local(THREAD, result); 435 C2V_END 436 437 C2V_VMENTRY(jobject, getImplementor, (JNIEnv *, jobject, jobject jvmci_type)) 438 InstanceKlass* klass = (InstanceKlass*) CompilerToVM::asKlass(jvmci_type); 439 oop implementor = CompilerToVM::get_jvmci_type(klass->implementor(), CHECK_NULL); 440 return JNIHandles::make_local(THREAD, implementor); 441 C2V_END 442 443 C2V_VMENTRY(jboolean, methodIsIgnoredBySecurityStackWalk,(JNIEnv *, jobject, jobject jvmci_method)) 444 methodHandle method = CompilerToVM::asMethod(jvmci_method); 445 return method->is_ignored_by_security_stack_walk(); 446 C2V_END 447 448 C2V_VMENTRY(jboolean, canInlineMethod,(JNIEnv *, jobject, jobject jvmci_method)) 449 methodHandle method = CompilerToVM::asMethod(jvmci_method); 450 return !method->is_not_compilable() && !CompilerOracle::should_not_inline(method) && !method->dont_inline(); 451 C2V_END 452 453 C2V_VMENTRY(jboolean, shouldInlineMethod,(JNIEnv *, jobject, jobject jvmci_method)) 454 methodHandle method = CompilerToVM::asMethod(jvmci_method); 455 return CompilerOracle::should_inline(method) || method->force_inline(); 456 C2V_END 457 458 C2V_VMENTRY(jobject, lookupType, (JNIEnv*, jobject, jstring jname, jclass accessing_class, jboolean resolve)) 459 ResourceMark rm; 460 Handle name = JNIHandles::resolve(jname); 461 Symbol* class_name = java_lang_String::as_symbol(name, CHECK_0); 462 if (java_lang_String::length(name()) <= 1) { 463 THROW_MSG_0(vmSymbols::java_lang_InternalError(), err_msg("Primitive type %s should be handled in Java code", class_name->as_C_string())); 464 } 465 466 Klass* resolved_klass = NULL; 467 Handle class_loader; 468 Handle protection_domain; 469 if (JNIHandles::resolve(accessing_class) == NULL) { 470 THROW_0(vmSymbols::java_lang_NullPointerException()); 471 } 472 Klass* accessing_klass = java_lang_Class::as_Klass(JNIHandles::resolve(accessing_class)); 473 class_loader = accessing_klass->class_loader(); 474 protection_domain = accessing_klass->protection_domain(); 475 476 if (resolve) { 477 resolved_klass = SystemDictionary::resolve_or_null(class_name, class_loader, protection_domain, CHECK_0); 478 } else { 479 if (class_name->byte_at(0) == 'L' && 480 class_name->byte_at(class_name->utf8_length()-1) == ';') { 481 // This is a name from a signature. Strip off the trimmings. 482 // Call recursive to keep scope of strippedsym. 483 TempNewSymbol strippedsym = SymbolTable::new_symbol(class_name->as_utf8()+1, 484 class_name->utf8_length()-2, 485 CHECK_0); 486 resolved_klass = SystemDictionary::find(strippedsym, class_loader, protection_domain, CHECK_0); 487 } else if (FieldType::is_array(class_name)) { 488 FieldArrayInfo fd; 489 // dimension and object_key in FieldArrayInfo are assigned as a side-effect 490 // of this call 491 BasicType t = FieldType::get_array_info(class_name, fd, CHECK_0); 492 if (t == T_OBJECT) { 493 TempNewSymbol strippedsym = SymbolTable::new_symbol(class_name->as_utf8()+1+fd.dimension(), 494 class_name->utf8_length()-2-fd.dimension(), 495 CHECK_0); 496 // naked oop "k" is OK here -- we assign back into it 497 resolved_klass = SystemDictionary::find(strippedsym, 498 class_loader, 499 protection_domain, 500 CHECK_0); 501 if (resolved_klass != NULL) { 502 resolved_klass = resolved_klass->array_klass(fd.dimension(), CHECK_0); 503 } 504 } else { 505 resolved_klass = Universe::typeArrayKlassObj(t); 506 resolved_klass = TypeArrayKlass::cast(resolved_klass)->array_klass(fd.dimension(), CHECK_0); 507 } 508 } 509 } 510 Handle result = CompilerToVM::get_jvmci_type(resolved_klass, CHECK_NULL); 511 return JNIHandles::make_local(THREAD, result()); 512 C2V_END 513 514 C2V_VMENTRY(jobject, resolveConstantInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 515 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 516 oop result = cp->resolve_constant_at(index, CHECK_NULL); 517 return JNIHandles::make_local(THREAD, result); 518 C2V_END 519 520 C2V_VMENTRY(jobject, resolvePossiblyCachedConstantInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 521 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 522 oop result = cp->resolve_possibly_cached_constant_at(index, CHECK_NULL); 523 return JNIHandles::make_local(THREAD, result); 524 C2V_END 525 526 C2V_VMENTRY(jint, lookupNameAndTypeRefIndexInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 527 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 528 return cp->name_and_type_ref_index_at(index); 529 C2V_END 530 531 C2V_VMENTRY(jobject, lookupNameInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint which)) 532 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 533 Handle sym = java_lang_String::create_from_symbol(cp->name_ref_at(which), CHECK_NULL); 534 return JNIHandles::make_local(THREAD, sym()); 535 C2V_END 536 537 C2V_VMENTRY(jobject, lookupSignatureInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint which)) 538 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 539 Handle sym = java_lang_String::create_from_symbol(cp->signature_ref_at(which), CHECK_NULL); 540 return JNIHandles::make_local(THREAD, sym()); 541 C2V_END 542 543 C2V_VMENTRY(jint, lookupKlassRefIndexInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 544 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 545 return cp->klass_ref_index_at(index); 546 C2V_END 547 548 C2V_VMENTRY(jobject, resolveTypeInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 549 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 550 Klass* resolved_klass = cp->klass_at(index, CHECK_NULL); 551 Handle klass = CompilerToVM::get_jvmci_type(resolved_klass, CHECK_NULL); 552 return JNIHandles::make_local(THREAD, klass()); 553 C2V_END 554 555 C2V_VMENTRY(jobject, lookupKlassInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index, jbyte opcode)) 556 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 557 KlassHandle loading_klass(cp->pool_holder()); 558 bool is_accessible = false; 559 KlassHandle klass = JVMCIEnv::get_klass_by_index(cp, index, is_accessible, loading_klass); 560 Symbol* symbol = NULL; 561 if (klass.is_null()) { 562 symbol = cp->klass_name_at(index); 563 } 564 Handle result; 565 if (!klass.is_null()) { 566 result = CompilerToVM::get_jvmci_type(klass, CHECK_NULL); 567 } else { 568 result = java_lang_String::create_from_symbol(symbol, CHECK_NULL); 569 } 570 return JNIHandles::make_local(THREAD, result()); 571 C2V_END 572 573 C2V_VMENTRY(jobject, lookupAppendixInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 574 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 575 oop appendix_oop = ConstantPool::appendix_at_if_loaded(cp, index); 576 return JNIHandles::make_local(THREAD, appendix_oop); 577 C2V_END 578 579 C2V_VMENTRY(jobject, lookupMethodInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index, jbyte opcode)) 580 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 581 instanceKlassHandle pool_holder(cp->pool_holder()); 582 Bytecodes::Code bc = (Bytecodes::Code) (((int) opcode) & 0xFF); 583 methodHandle method = JVMCIEnv::get_method_by_index(cp, index, bc, pool_holder); 584 oop result = CompilerToVM::get_jvmci_method(method, CHECK_NULL); 585 return JNIHandles::make_local(THREAD, result); 586 C2V_END 587 588 C2V_VMENTRY(jint, constantPoolRemapInstructionOperandFromCache, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 589 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 590 return cp->remap_instruction_operand_from_cache(index); 591 C2V_END 592 593 C2V_VMENTRY(jobject, resolveFieldInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index, jbyte opcode, jlongArray info_handle)) 594 ResourceMark rm; 595 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 596 Bytecodes::Code code = (Bytecodes::Code)(((int) opcode) & 0xFF); 597 fieldDescriptor fd; 598 LinkInfo link_info(cp, index, CHECK_0); 599 LinkResolver::resolve_field(fd, link_info, Bytecodes::java_code(code), false, CHECK_0); 600 typeArrayOop info = (typeArrayOop) JNIHandles::resolve(info_handle); 601 assert(info != NULL && info->length() == 2, "must be"); 602 info->long_at_put(0, (jlong) fd.access_flags().as_int()); 603 info->long_at_put(1, (jlong) fd.offset()); 604 oop field_holder = CompilerToVM::get_jvmci_type(fd.field_holder(), CHECK_NULL); 605 return JNIHandles::make_local(THREAD, field_holder); 606 C2V_END 607 608 C2V_VMENTRY(jint, getVtableIndexForInterfaceMethod, (JNIEnv *, jobject, jobject jvmci_type, jobject jvmci_method)) 609 ResourceMark rm; 610 Klass* klass = CompilerToVM::asKlass(jvmci_type); 611 Method* method = CompilerToVM::asMethod(jvmci_method); 612 if (klass->is_interface()) { 613 THROW_MSG_0(vmSymbols::java_lang_InternalError(), err_msg("Interface %s should be handled in Java code", klass->external_name())); 614 } 615 if (!method->method_holder()->is_interface()) { 616 THROW_MSG_0(vmSymbols::java_lang_InternalError(), err_msg("Method %s is not held by an interface, this case should be handled in Java code", method->name_and_sig_as_C_string())); 617 } 618 if (!InstanceKlass::cast(klass)->is_linked()) { 619 THROW_MSG_0(vmSymbols::java_lang_InternalError(), err_msg("Class %s must be linked", klass->external_name())); 620 } 621 return LinkResolver::vtable_index_of_interface_method(klass, method); 622 C2V_END 623 624 C2V_VMENTRY(jobject, resolveMethod, (JNIEnv *, jobject, jobject receiver_jvmci_type, jobject jvmci_method, jobject caller_jvmci_type)) 625 Klass* recv_klass = CompilerToVM::asKlass(receiver_jvmci_type); 626 Klass* caller_klass = CompilerToVM::asKlass(caller_jvmci_type); 627 Method* method = CompilerToVM::asMethod(jvmci_method); 628 629 if (recv_klass->is_array_klass() || (InstanceKlass::cast(recv_klass)->is_linked())) { 630 Klass* holder_klass = method->method_holder(); 631 Symbol* method_name = method->name(); 632 Symbol* method_signature = method->signature(); 633 634 if (holder_klass->is_interface()) { 635 // do link-time resolution to check all access rules. 636 LinkInfo link_info(holder_klass, method_name, method_signature, caller_klass, true); 637 methodHandle resolved_method = LinkResolver::linktime_resolve_interface_method_or_null(link_info); 638 if (resolved_method.is_null() || resolved_method->is_private()) { 639 return NULL; 640 } 641 assert(recv_klass->is_subtype_of(holder_klass), ""); 642 // do actual lookup 643 methodHandle sel_method = LinkResolver::lookup_instance_method_in_klasses(recv_klass, resolved_method->name(), resolved_method->signature(), CHECK_AND_CLEAR_0); 644 oop result = CompilerToVM::get_jvmci_method(sel_method, CHECK_NULL); 645 return JNIHandles::make_local(THREAD, result); 646 } else { 647 // do link-time resolution to check all access rules. 648 LinkInfo link_info(holder_klass, method_name, method_signature, caller_klass, true); 649 methodHandle resolved_method = LinkResolver::linktime_resolve_virtual_method_or_null(link_info); 650 if (resolved_method.is_null()) { 651 return NULL; 652 } 653 // do actual lookup (see LinkResolver::runtime_resolve_virtual_method) 654 int vtable_index = Method::invalid_vtable_index; 655 Method* selected_method; 656 657 if (resolved_method->method_holder()->is_interface()) { // miranda method 658 vtable_index = LinkResolver::vtable_index_of_interface_method(holder_klass, resolved_method); 659 assert(vtable_index >= 0 , "we should have valid vtable index at this point"); 660 661 InstanceKlass* inst = InstanceKlass::cast(recv_klass); 662 selected_method = inst->method_at_vtable(vtable_index); 663 } else { 664 // at this point we are sure that resolved_method is virtual and not 665 // a miranda method; therefore, it must have a valid vtable index. 666 assert(!resolved_method->has_itable_index(), ""); 667 vtable_index = resolved_method->vtable_index(); 668 // We could get a negative vtable_index for final methods, 669 // because as an optimization they are they are never put in the vtable, 670 // unless they override an existing method. 671 // If we do get a negative, it means the resolved method is the the selected 672 // method, and it can never be changed by an override. 673 if (vtable_index == Method::nonvirtual_vtable_index) { 674 assert(resolved_method->can_be_statically_bound(), "cannot override this method"); 675 selected_method = resolved_method(); 676 } else { 677 // recv_klass might be an arrayKlassOop but all vtables start at 678 // the same place. The cast is to avoid virtual call and assertion. 679 InstanceKlass* inst = (InstanceKlass*)recv_klass; 680 selected_method = inst->method_at_vtable(vtable_index); 681 } 682 } 683 oop result = CompilerToVM::get_jvmci_method(selected_method, CHECK_NULL); 684 return JNIHandles::make_local(THREAD, result); 685 } 686 } 687 return NULL; 688 C2V_END 689 690 C2V_VMENTRY(jboolean, hasFinalizableSubclass,(JNIEnv *, jobject, jobject jvmci_type)) 691 Klass* klass = CompilerToVM::asKlass(jvmci_type); 692 assert(klass != NULL, "method must not be called for primitive types"); 693 return Dependencies::find_finalizable_subclass(klass) != NULL; 694 C2V_END 695 696 C2V_VMENTRY(jobject, getClassInitializer, (JNIEnv *, jobject, jobject jvmci_type)) 697 InstanceKlass* klass = (InstanceKlass*) CompilerToVM::asKlass(jvmci_type); 698 oop result = CompilerToVM::get_jvmci_method(klass->class_initializer(), CHECK_NULL); 699 return JNIHandles::make_local(THREAD, result); 700 C2V_END 701 702 C2V_VMENTRY(jlong, getMaxCallTargetOffset, (JNIEnv*, jobject, jlong addr)) 703 address target_addr = (address) addr; 704 if (target_addr != 0x0) { 705 int64_t off_low = (int64_t)target_addr - ((int64_t)CodeCache::low_bound() + sizeof(int)); 706 int64_t off_high = (int64_t)target_addr - ((int64_t)CodeCache::high_bound() + sizeof(int)); 707 return MAX2(ABS(off_low), ABS(off_high)); 708 } 709 return -1; 710 C2V_END 711 712 C2V_VMENTRY(void, doNotInlineOrCompile,(JNIEnv *, jobject, jobject jvmci_method)) 713 methodHandle method = CompilerToVM::asMethod(jvmci_method); 714 method->set_not_c1_compilable(); 715 method->set_not_c2_compilable(); 716 method->set_dont_inline(true); 717 C2V_END 718 719 C2V_VMENTRY(jint, installCode, (JNIEnv *jniEnv, jobject, jobject target, jobject compiled_code, jobject installed_code, jobject speculation_log)) 720 ResourceMark rm; 721 HandleMark hm; 722 Handle target_handle = JNIHandles::resolve(target); 723 Handle compiled_code_handle = JNIHandles::resolve(compiled_code); 724 CodeBlob* cb = NULL; 725 Handle installed_code_handle = JNIHandles::resolve(installed_code); 726 Handle speculation_log_handle = JNIHandles::resolve(speculation_log); 727 728 JVMCICompiler* compiler = JVMCICompiler::instance(CHECK_JNI_ERR); 729 730 TraceTime install_time("installCode", JVMCICompiler::codeInstallTimer()); 731 CodeInstaller installer; 732 JVMCIEnv::CodeInstallResult result = installer.install(compiler, target_handle, compiled_code_handle, cb, installed_code_handle, speculation_log_handle, CHECK_0); 733 734 if (PrintCodeCacheOnCompilation) { 735 stringStream s; 736 // Dump code cache into a buffer before locking the tty, 737 { 738 MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag); 739 CodeCache::print_summary(&s, false); 740 } 741 ttyLocker ttyl; 742 tty->print_raw_cr(s.as_string()); 743 } 744 745 if (result != JVMCIEnv::ok) { 746 assert(cb == NULL, "should be"); 747 } else { 748 if (!installed_code_handle.is_null()) { 749 assert(installed_code_handle->is_a(InstalledCode::klass()), "wrong type"); 750 nmethod::invalidate_installed_code(installed_code_handle, CHECK_0); 751 { 752 // Ensure that all updates to the InstalledCode fields are consistent. 753 MutexLockerEx pl(Patching_lock, Mutex::_no_safepoint_check_flag); 754 InstalledCode::set_address(installed_code_handle, (jlong) cb); 755 InstalledCode::set_version(installed_code_handle, InstalledCode::version(installed_code_handle) + 1); 756 if (cb->is_nmethod()) { 757 InstalledCode::set_entryPoint(installed_code_handle, (jlong) cb->as_nmethod_or_null()->verified_entry_point()); 758 } else { 759 InstalledCode::set_entryPoint(installed_code_handle, (jlong) cb->code_begin()); 760 } 761 if (installed_code_handle->is_a(HotSpotInstalledCode::klass())) { 762 HotSpotInstalledCode::set_size(installed_code_handle, cb->size()); 763 HotSpotInstalledCode::set_codeStart(installed_code_handle, (jlong) cb->code_begin()); 764 HotSpotInstalledCode::set_codeSize(installed_code_handle, cb->code_size()); 765 } 766 } 767 nmethod* nm = cb->as_nmethod_or_null(); 768 if (nm != NULL && installed_code_handle->is_scavengable()) { 769 assert(nm->detect_scavenge_root_oops(), "nm should be scavengable if installed_code is scavengable"); 770 if (!UseG1GC) { 771 assert(nm->on_scavenge_root_list(), "nm should be on scavengable list"); 772 } 773 } 774 } 775 } 776 return result; 777 C2V_END 778 779 C2V_VMENTRY(jint, getMetadata, (JNIEnv *jniEnv, jobject, jobject target, jobject compiled_code, jobject metadata)) 780 ResourceMark rm; 781 HandleMark hm; 782 783 Handle target_handle = JNIHandles::resolve(target); 784 Handle compiled_code_handle = JNIHandles::resolve(compiled_code); 785 Handle metadata_handle = JNIHandles::resolve(metadata); 786 787 HotSpotOopMap::klass()->initialize(thread); 788 789 CodeMetadata code_metadata; 790 CodeBlob *cb = NULL; 791 CodeInstaller installer; 792 793 JVMCIEnv::CodeInstallResult result = installer.gather_metadata(target_handle, compiled_code_handle, code_metadata, CHECK_0); //cb, pc_descs, nr_pc_descs, scopes_descs, scopes_size, reloc_buffer); 794 if (result != JVMCIEnv::ok) { 795 return result; 796 } 797 798 if (code_metadata.get_nr_pc_desc() > 0) { 799 typeArrayHandle pcArrayOop = oopFactory::new_byteArray(sizeof(PcDesc) * code_metadata.get_nr_pc_desc(), CHECK_(JVMCIEnv::cache_full)); 800 memcpy(pcArrayOop->byte_at_addr(0), code_metadata.get_pc_desc(), sizeof(PcDesc) * code_metadata.get_nr_pc_desc()); 801 HotSpotMetaData::set_pcDescBytes(metadata_handle, pcArrayOop()); 802 } 803 804 if (code_metadata.get_scopes_size() > 0) { 805 typeArrayHandle scopesArrayOop = oopFactory::new_byteArray(code_metadata.get_scopes_size(), CHECK_(JVMCIEnv::cache_full)); 806 memcpy(scopesArrayOop->byte_at_addr(0), code_metadata.get_scopes_desc(), code_metadata.get_scopes_size()); 807 HotSpotMetaData::set_scopesDescBytes(metadata_handle, scopesArrayOop()); 808 } 809 810 RelocBuffer* reloc_buffer = code_metadata.get_reloc_buffer(); 811 typeArrayHandle relocArrayOop = oopFactory::new_byteArray((int) reloc_buffer->size(), CHECK_(JVMCIEnv::cache_full)); 812 if (reloc_buffer->size() > 0) { 813 memcpy(relocArrayOop->byte_at_addr(0), reloc_buffer->begin(), reloc_buffer->size()); 814 } 815 HotSpotMetaData::set_relocBytes(metadata_handle, relocArrayOop()); 816 817 const OopMapSet* oopMapSet = installer.oopMapSet(); 818 { 819 ResourceMark mark; 820 ImmutableOopMapBuilder builder(oopMapSet); 821 int oopmap_size = builder.heap_size(); 822 typeArrayHandle oopMapArrayHandle = oopFactory::new_byteArray(oopmap_size, CHECK_(JVMCIEnv::cache_full)); 823 builder.generate_into((address) oopMapArrayHandle->byte_at_addr(0)); 824 HotSpotMetaData::set_oopMaps(metadata_handle, oopMapArrayHandle()); 825 } 826 827 HotSpotMetaData::set_metadata(metadata_handle, NULL); 828 829 ExceptionHandlerTable* handler = code_metadata.get_exception_table(); 830 int table_size = handler->size_in_bytes(); 831 typeArrayHandle exceptionArrayOop = oopFactory::new_byteArray(table_size, CHECK_(JVMCIEnv::cache_full)); 832 833 if (table_size > 0) { 834 handler->copy_bytes_to((address) exceptionArrayOop->byte_at_addr(0)); 835 } 836 HotSpotMetaData::set_exceptionBytes(metadata_handle, exceptionArrayOop()); 837 838 return result; 839 C2V_END 840 841 C2V_VMENTRY(void, notifyCompilationStatistics, (JNIEnv *jniEnv, jobject, jint id, jobject hotspot_method, jboolean osr, jint processedBytecodes, jlong time, jlong timeUnitsPerSecond, jobject installed_code)) 842 JVMCICompiler* compiler = JVMCICompiler::instance(CHECK); 843 CompilerStatistics* stats = compiler->stats(); 844 845 elapsedTimer timer = elapsedTimer(time, timeUnitsPerSecond); 846 if (osr) { 847 stats->_osr.update(timer, processedBytecodes); 848 } else { 849 stats->_standard.update(timer, processedBytecodes); 850 } 851 Handle installed_code_handle = JNIHandles::resolve(installed_code); 852 if (installed_code_handle->is_a(HotSpotInstalledCode::klass())) { 853 stats->_nmethods_size += HotSpotInstalledCode::size(installed_code_handle); 854 stats->_nmethods_code_size += HotSpotInstalledCode::codeSize(installed_code_handle); 855 } 856 857 if (CITimeEach) { 858 methodHandle method = CompilerToVM::asMethod(hotspot_method); 859 float bytes_per_sec = 1.0 * processedBytecodes / timer.seconds(); 860 tty->print_cr("%3d seconds: %f bytes/sec: %f (bytes %d)", 861 id, timer.seconds(), bytes_per_sec, processedBytecodes); 862 } 863 C2V_END 864 865 C2V_VMENTRY(void, resetCompilationStatistics, (JNIEnv *jniEnv, jobject)) 866 JVMCICompiler* compiler = JVMCICompiler::instance(CHECK); 867 CompilerStatistics* stats = compiler->stats(); 868 stats->_standard.reset(); 869 stats->_osr.reset(); 870 C2V_END 871 872 C2V_VMENTRY(jobject, disassembleCodeBlob, (JNIEnv *jniEnv, jobject, jobject installedCode)) 873 ResourceMark rm; 874 HandleMark hm; 875 876 if (installedCode == NULL) { 877 THROW_MSG_NULL(vmSymbols::java_lang_NullPointerException(), "installedCode is null"); 878 } 879 880 jlong codeBlob = InstalledCode::address(installedCode); 881 if (codeBlob == 0L) { 882 return NULL; 883 } 884 885 CodeBlob* cb = (CodeBlob*) (address) codeBlob; 886 if (cb == NULL) { 887 return NULL; 888 } 889 890 // We don't want the stringStream buffer to resize during disassembly as it 891 // uses scoped resource memory. If a nested function called during disassembly uses 892 // a ResourceMark and the buffer expands within the scope of the mark, 893 // the buffer becomes garbage when that scope is exited. Experience shows that 894 // the disassembled code is typically about 10x the code size so a fixed buffer 895 // sized to 20x code size plus a fixed amount for header info should be sufficient. 896 int bufferSize = cb->code_size() * 20 + 1024; 897 char* buffer = NEW_RESOURCE_ARRAY(char, bufferSize); 898 stringStream st(buffer, bufferSize); 899 if (cb->is_nmethod()) { 900 nmethod* nm = (nmethod*) cb; 901 if (!nm->is_alive()) { 902 return NULL; 903 } 904 } 905 Disassembler::decode(cb, &st); 906 if (st.size() <= 0) { 907 return NULL; 908 } 909 910 Handle result = java_lang_String::create_from_platform_dependent_str(st.as_string(), CHECK_NULL); 911 return JNIHandles::make_local(THREAD, result()); 912 C2V_END 913 914 C2V_VMENTRY(jobject, getStackTraceElement, (JNIEnv*, jobject, jobject jvmci_method, int bci)) 915 ResourceMark rm; 916 HandleMark hm; 917 918 methodHandle method = CompilerToVM::asMethod(jvmci_method); 919 oop element = java_lang_StackTraceElement::create(method, bci, CHECK_NULL); 920 return JNIHandles::make_local(THREAD, element); 921 C2V_END 922 923 C2V_VMENTRY(jobject, executeInstalledCode, (JNIEnv*, jobject, jobject args, jobject hotspotInstalledCode)) 924 ResourceMark rm; 925 HandleMark hm; 926 927 jlong nmethodValue = InstalledCode::address(hotspotInstalledCode); 928 if (nmethodValue == 0L) { 929 THROW_NULL(vmSymbols::jdk_vm_ci_code_InvalidInstalledCodeException()); 930 } 931 nmethod* nm = (nmethod*) (address) nmethodValue; 932 methodHandle mh = nm->method(); 933 Symbol* signature = mh->signature(); 934 JavaCallArguments jca(mh->size_of_parameters()); 935 936 JavaArgumentUnboxer jap(signature, &jca, (arrayOop) JNIHandles::resolve(args), mh->is_static()); 937 JavaValue result(jap.get_ret_type()); 938 jca.set_alternative_target(nm); 939 JavaCalls::call(&result, mh, &jca, CHECK_NULL); 940 941 if (jap.get_ret_type() == T_VOID) { 942 return NULL; 943 } else if (jap.get_ret_type() == T_OBJECT || jap.get_ret_type() == T_ARRAY) { 944 return JNIHandles::make_local(THREAD, (oop) result.get_jobject()); 945 } else { 946 jvalue *value = (jvalue *) result.get_value_addr(); 947 // Narrow the value down if required (Important on big endian machines) 948 switch (jap.get_ret_type()) { 949 case T_BOOLEAN: 950 value->z = (jboolean) value->i; 951 break; 952 case T_BYTE: 953 value->b = (jbyte) value->i; 954 break; 955 case T_CHAR: 956 value->c = (jchar) value->i; 957 break; 958 case T_SHORT: 959 value->s = (jshort) value->i; 960 break; 961 } 962 oop o = java_lang_boxing_object::create(jap.get_ret_type(), value, CHECK_NULL); 963 return JNIHandles::make_local(THREAD, o); 964 } 965 C2V_END 966 967 C2V_VMENTRY(jlongArray, getLineNumberTable, (JNIEnv *, jobject, jobject jvmci_method)) 968 Method* method = CompilerToVM::asMethod(jvmci_method); 969 if (!method->has_linenumber_table()) { 970 return NULL; 971 } 972 u2 num_entries = 0; 973 CompressedLineNumberReadStream streamForSize(method->compressed_linenumber_table()); 974 while (streamForSize.read_pair()) { 975 num_entries++; 976 } 977 978 CompressedLineNumberReadStream stream(method->compressed_linenumber_table()); 979 typeArrayOop result = oopFactory::new_longArray(2 * num_entries, CHECK_NULL); 980 981 int i = 0; 982 jlong value; 983 while (stream.read_pair()) { 984 value = ((long) stream.bci()); 985 result->long_at_put(i, value); 986 value = ((long) stream.line()); 987 result->long_at_put(i + 1, value); 988 i += 2; 989 } 990 991 return (jlongArray) JNIHandles::make_local(THREAD, result); 992 C2V_END 993 994 C2V_VMENTRY(jlong, getLocalVariableTableStart, (JNIEnv *, jobject, jobject jvmci_method)) 995 ResourceMark rm; 996 Method* method = CompilerToVM::asMethod(jvmci_method); 997 if (!method->has_localvariable_table()) { 998 return 0; 999 } 1000 return (jlong) (address) method->localvariable_table_start(); 1001 C2V_END 1002 1003 C2V_VMENTRY(jint, getLocalVariableTableLength, (JNIEnv *, jobject, jobject jvmci_method)) 1004 ResourceMark rm; 1005 Method* method = CompilerToVM::asMethod(jvmci_method); 1006 return method->localvariable_table_length(); 1007 C2V_END 1008 1009 C2V_VMENTRY(void, reprofile, (JNIEnv*, jobject, jobject jvmci_method)) 1010 Method* method = CompilerToVM::asMethod(jvmci_method); 1011 MethodCounters* mcs = method->method_counters(); 1012 if (mcs != NULL) { 1013 mcs->clear_counters(); 1014 } 1015 NOT_PRODUCT(method->set_compiled_invocation_count(0)); 1016 1017 nmethod* code = method->code(); 1018 if (code != NULL) { 1019 code->make_not_entrant(); 1020 } 1021 1022 MethodData* method_data = method->method_data(); 1023 if (method_data == NULL) { 1024 ClassLoaderData* loader_data = method->method_holder()->class_loader_data(); 1025 method_data = MethodData::allocate(loader_data, method, CHECK); 1026 method->set_method_data(method_data); 1027 } else { 1028 method_data->initialize(); 1029 } 1030 C2V_END 1031 1032 1033 C2V_VMENTRY(void, invalidateInstalledCode, (JNIEnv*, jobject, jobject installed_code)) 1034 Handle installed_code_handle = JNIHandles::resolve(installed_code); 1035 nmethod::invalidate_installed_code(installed_code_handle, CHECK); 1036 C2V_END 1037 1038 C2V_VMENTRY(jobject, readUncompressedOop, (JNIEnv*, jobject, jlong addr)) 1039 oop ret = oopDesc::load_decode_heap_oop((oop*)(address)addr); 1040 return JNIHandles::make_local(THREAD, ret); 1041 C2V_END 1042 1043 C2V_VMENTRY(jlongArray, collectCounters, (JNIEnv*, jobject)) 1044 typeArrayOop arrayOop = oopFactory::new_longArray(JVMCICounterSize, CHECK_NULL); 1045 JavaThread::collect_counters(arrayOop); 1046 return (jlongArray) JNIHandles::make_local(THREAD, arrayOop); 1047 C2V_END 1048 1049 C2V_VMENTRY(int, allocateCompileId, (JNIEnv*, jobject, jobject jvmci_method, int entry_bci)) 1050 HandleMark hm; 1051 ResourceMark rm; 1052 if (JNIHandles::resolve(jvmci_method) == NULL) { 1053 THROW_0(vmSymbols::java_lang_NullPointerException()); 1054 } 1055 Method* method = CompilerToVM::asMethod(jvmci_method); 1056 if (entry_bci >= method->code_size() || entry_bci < -1) { 1057 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), err_msg("Unexpected bci %d", entry_bci)); 1058 } 1059 return CompileBroker::assign_compile_id_unlocked(THREAD, method, entry_bci); 1060 C2V_END 1061 1062 1063 C2V_VMENTRY(jboolean, isMature, (JNIEnv*, jobject, jlong metaspace_method_data)) 1064 MethodData* mdo = CompilerToVM::asMethodData(metaspace_method_data); 1065 return mdo != NULL && mdo->is_mature(); 1066 C2V_END 1067 1068 C2V_VMENTRY(jboolean, hasCompiledCodeForOSR, (JNIEnv*, jobject, jobject jvmci_method, int entry_bci, int comp_level)) 1069 Method* method = CompilerToVM::asMethod(jvmci_method); 1070 return method->lookup_osr_nmethod_for(entry_bci, comp_level, true) != NULL; 1071 C2V_END 1072 1073 C2V_VMENTRY(jobject, getSymbol, (JNIEnv*, jobject, jlong symbol)) 1074 Handle sym = java_lang_String::create_from_symbol((Symbol*)(address)symbol, CHECK_NULL); 1075 return JNIHandles::make_local(THREAD, sym()); 1076 C2V_END 1077 1078 bool matches(jobjectArray methods, Method* method) { 1079 objArrayOop methods_oop = (objArrayOop) JNIHandles::resolve(methods); 1080 1081 for (int i = 0; i < methods_oop->length(); i++) { 1082 oop resolved = methods_oop->obj_at(i); 1083 if (resolved->is_a(HotSpotResolvedJavaMethodImpl::klass()) && CompilerToVM::asMethod(resolved) == method) { 1084 return true; 1085 } 1086 } 1087 return false; 1088 } 1089 1090 C2V_VMENTRY(jobject, getNextStackFrame, (JNIEnv*, jobject compilerToVM, jobject hs_frame, jobjectArray methods, jint initialSkip)) 1091 ResourceMark rm; 1092 1093 if (!thread->has_last_Java_frame()) return NULL; 1094 Handle result = HotSpotStackFrameReference::klass()->allocate_instance(thread); 1095 HotSpotStackFrameReference::klass()->initialize(thread); 1096 1097 StackFrameStream fst(thread); 1098 if (hs_frame != NULL) { 1099 // look for the correct stack frame if one is given 1100 intptr_t* stack_pointer = (intptr_t*) HotSpotStackFrameReference::stackPointer(hs_frame); 1101 while (fst.current()->sp() != stack_pointer && !fst.is_done()) { 1102 fst.next(); 1103 } 1104 if (fst.current()->sp() != stack_pointer) { 1105 THROW_MSG_NULL(vmSymbols::java_lang_IllegalStateException(), "stack frame not found") 1106 } 1107 } 1108 1109 int frame_number = 0; 1110 vframe* vf = vframe::new_vframe(fst.current(), fst.register_map(), thread); 1111 if (hs_frame != NULL) { 1112 // look for the correct vframe within the stack frame if one is given 1113 int last_frame_number = HotSpotStackFrameReference::frameNumber(hs_frame); 1114 while (frame_number < last_frame_number) { 1115 if (vf->is_top()) { 1116 THROW_MSG_NULL(vmSymbols::java_lang_IllegalStateException(), "invalid frame number") 1117 } 1118 vf = vf->sender(); 1119 frame_number ++; 1120 } 1121 // move one frame forward 1122 if (vf->is_top()) { 1123 if (fst.is_done()) { 1124 return NULL; 1125 } 1126 fst.next(); 1127 vf = vframe::new_vframe(fst.current(), fst.register_map(), thread); 1128 frame_number = 0; 1129 } else { 1130 vf = vf->sender(); 1131 frame_number++; 1132 } 1133 } 1134 1135 while (true) { 1136 // look for the given method 1137 while (true) { 1138 StackValueCollection* locals = NULL; 1139 if (vf->is_compiled_frame()) { 1140 // compiled method frame 1141 compiledVFrame* cvf = compiledVFrame::cast(vf); 1142 if (methods == NULL || matches(methods, cvf->method())) { 1143 if (initialSkip > 0) { 1144 initialSkip --; 1145 } else { 1146 ScopeDesc* scope = cvf->scope(); 1147 // native wrapper do not have a scope 1148 if (scope != NULL && scope->objects() != NULL) { 1149 bool realloc_failures = Deoptimization::realloc_objects(thread, fst.current(), scope->objects(), THREAD); 1150 Deoptimization::reassign_fields(fst.current(), fst.register_map(), scope->objects(), realloc_failures, false); 1151 1152 GrowableArray<ScopeValue*>* local_values = scope->locals(); 1153 typeArrayHandle array = oopFactory::new_boolArray(local_values->length(), thread); 1154 for (int i = 0; i < local_values->length(); i++) { 1155 ScopeValue* value = local_values->at(i); 1156 if (value->is_object()) { 1157 array->bool_at_put(i, true); 1158 } 1159 } 1160 HotSpotStackFrameReference::set_localIsVirtual(result, array()); 1161 } else { 1162 HotSpotStackFrameReference::set_localIsVirtual(result, NULL); 1163 } 1164 1165 locals = cvf->locals(); 1166 HotSpotStackFrameReference::set_bci(result, cvf->bci()); 1167 oop method = CompilerToVM::get_jvmci_method(cvf->method(), CHECK_NULL); 1168 HotSpotStackFrameReference::set_method(result, method); 1169 } 1170 } 1171 } else if (vf->is_interpreted_frame()) { 1172 // interpreted method frame 1173 interpretedVFrame* ivf = interpretedVFrame::cast(vf); 1174 if (methods == NULL || matches(methods, ivf->method())) { 1175 if (initialSkip > 0) { 1176 initialSkip --; 1177 } else { 1178 locals = ivf->locals(); 1179 HotSpotStackFrameReference::set_bci(result, ivf->bci()); 1180 oop method = CompilerToVM::get_jvmci_method(ivf->method(), CHECK_NULL); 1181 HotSpotStackFrameReference::set_method(result, method); 1182 HotSpotStackFrameReference::set_localIsVirtual(result, NULL); 1183 } 1184 } 1185 } 1186 1187 // locals != NULL means that we found a matching frame and result is already partially initialized 1188 if (locals != NULL) { 1189 HotSpotStackFrameReference::set_compilerToVM(result, JNIHandles::resolve(compilerToVM)); 1190 HotSpotStackFrameReference::set_stackPointer(result, (jlong) fst.current()->sp()); 1191 HotSpotStackFrameReference::set_frameNumber(result, frame_number); 1192 1193 // initialize the locals array 1194 objArrayHandle array = oopFactory::new_objectArray(locals->size(), thread); 1195 for (int i = 0; i < locals->size(); i++) { 1196 StackValue* var = locals->at(i); 1197 if (var->type() == T_OBJECT) { 1198 array->obj_at_put(i, locals->at(i)->get_obj()()); 1199 } 1200 } 1201 HotSpotStackFrameReference::set_locals(result, array()); 1202 1203 return JNIHandles::make_local(thread, result()); 1204 } 1205 1206 if (vf->is_top()) { 1207 break; 1208 } 1209 frame_number++; 1210 vf = vf->sender(); 1211 } // end of vframe loop 1212 1213 if (fst.is_done()) { 1214 break; 1215 } 1216 fst.next(); 1217 vf = vframe::new_vframe(fst.current(), fst.register_map(), thread); 1218 frame_number = 0; 1219 } // end of frame loop 1220 1221 // the end was reached without finding a matching method 1222 return NULL; 1223 C2V_END 1224 1225 C2V_VMENTRY(void, resolveInvokeDynamicInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 1226 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 1227 CallInfo callInfo; 1228 LinkResolver::resolve_invoke(callInfo, Handle(), cp, index, Bytecodes::_invokedynamic, CHECK); 1229 ConstantPoolCacheEntry* cp_cache_entry = cp->invokedynamic_cp_cache_entry_at(index); 1230 cp_cache_entry->set_dynamic_call(cp, callInfo); 1231 C2V_END 1232 1233 C2V_VMENTRY(void, resolveInvokeHandleInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index)) 1234 constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); 1235 CallInfo callInfo; 1236 LinkResolver::resolve_invoke(callInfo, Handle(), cp, index, Bytecodes::_invokehandle, CHECK); 1237 ConstantPoolCacheEntry* cp_cache_entry = cp_cache_entry = cp->cache()->entry_at(cp->decode_cpcache_index(index)); 1238 cp_cache_entry->set_method_handle(cp, callInfo); 1239 C2V_END 1240 1241 C2V_VMENTRY(jboolean, shouldDebugNonSafepoints, (JNIEnv*, jobject)) 1242 //see compute_recording_non_safepoints in debugInfroRec.cpp 1243 if (JvmtiExport::should_post_compiled_method_load() && FLAG_IS_DEFAULT(DebugNonSafepoints)) { 1244 return true; 1245 } 1246 return DebugNonSafepoints; 1247 C2V_END 1248 1249 // public native void materializeVirtualObjects(HotSpotStackFrameReference stackFrame, boolean invalidate); 1250 C2V_VMENTRY(void, materializeVirtualObjects, (JNIEnv*, jobject, jobject hs_frame, bool invalidate)) 1251 ResourceMark rm; 1252 1253 if (hs_frame == NULL) { 1254 THROW_MSG(vmSymbols::java_lang_NullPointerException(), "stack frame is null") 1255 } 1256 1257 HotSpotStackFrameReference::klass()->initialize(thread); 1258 1259 // look for the given stack frame 1260 StackFrameStream fst(thread); 1261 intptr_t* stack_pointer = (intptr_t*) HotSpotStackFrameReference::stackPointer(hs_frame); 1262 while (fst.current()->sp() != stack_pointer && !fst.is_done()) { 1263 fst.next(); 1264 } 1265 if (fst.current()->sp() != stack_pointer) { 1266 THROW_MSG(vmSymbols::java_lang_IllegalStateException(), "stack frame not found") 1267 } 1268 1269 if (invalidate) { 1270 if (!fst.current()->is_compiled_frame()) { 1271 THROW_MSG(vmSymbols::java_lang_IllegalStateException(), "compiled stack frame expected") 1272 } 1273 assert(fst.current()->cb()->is_nmethod(), "nmethod expected"); 1274 ((nmethod*) fst.current()->cb())->make_not_entrant(); 1275 } 1276 Deoptimization::deoptimize(thread, *fst.current(), fst.register_map(), Deoptimization::Reason_none); 1277 // look for the frame again as it has been updated by deopt (pc, deopt state...) 1278 StackFrameStream fstAfterDeopt(thread); 1279 while (fstAfterDeopt.current()->sp() != stack_pointer && !fstAfterDeopt.is_done()) { 1280 fstAfterDeopt.next(); 1281 } 1282 if (fstAfterDeopt.current()->sp() != stack_pointer) { 1283 THROW_MSG(vmSymbols::java_lang_IllegalStateException(), "stack frame not found after deopt") 1284 } 1285 1286 vframe* vf = vframe::new_vframe(fstAfterDeopt.current(), fstAfterDeopt.register_map(), thread); 1287 if (!vf->is_compiled_frame()) { 1288 THROW_MSG(vmSymbols::java_lang_IllegalStateException(), "compiled stack frame expected") 1289 } 1290 1291 GrowableArray<compiledVFrame*>* virtualFrames = new GrowableArray<compiledVFrame*>(10); 1292 while (true) { 1293 assert(vf->is_compiled_frame(), "Wrong frame type"); 1294 virtualFrames->push(compiledVFrame::cast(vf)); 1295 if (vf->is_top()) { 1296 break; 1297 } 1298 vf = vf->sender(); 1299 } 1300 1301 int last_frame_number = HotSpotStackFrameReference::frameNumber(hs_frame); 1302 if (last_frame_number >= virtualFrames->length()) { 1303 THROW_MSG(vmSymbols::java_lang_IllegalStateException(), "invalid frame number") 1304 } 1305 1306 // Reallocate the non-escaping objects and restore their fields. 1307 assert (virtualFrames->at(last_frame_number)->scope() != NULL,"invalid scope"); 1308 GrowableArray<ScopeValue*>* objects = virtualFrames->at(last_frame_number)->scope()->objects(); 1309 1310 if (objects == NULL) { 1311 // no objects to materialize 1312 return; 1313 } 1314 1315 bool realloc_failures = Deoptimization::realloc_objects(thread, fstAfterDeopt.current(), objects, THREAD); 1316 Deoptimization::reassign_fields(fstAfterDeopt.current(), fstAfterDeopt.register_map(), objects, realloc_failures, false); 1317 1318 for (int frame_index = 0; frame_index < virtualFrames->length(); frame_index++) { 1319 compiledVFrame* cvf = virtualFrames->at(frame_index); 1320 1321 GrowableArray<ScopeValue*>* scopeLocals = cvf->scope()->locals(); 1322 StackValueCollection* locals = cvf->locals(); 1323 1324 if (locals != NULL) { 1325 for (int i2 = 0; i2 < locals->size(); i2++) { 1326 StackValue* var = locals->at(i2); 1327 if (var->type() == T_OBJECT && scopeLocals->at(i2)->is_object()) { 1328 jvalue val; 1329 val.l = (jobject) locals->at(i2)->get_obj()(); 1330 cvf->update_local(T_OBJECT, i2, val); 1331 } 1332 } 1333 } 1334 } 1335 1336 // all locals are materialized by now 1337 HotSpotStackFrameReference::set_localIsVirtual(hs_frame, NULL); 1338 1339 // update the locals array 1340 objArrayHandle array = HotSpotStackFrameReference::locals(hs_frame); 1341 StackValueCollection* locals = virtualFrames->at(last_frame_number)->locals(); 1342 for (int i = 0; i < locals->size(); i++) { 1343 StackValue* var = locals->at(i); 1344 if (var->type() == T_OBJECT) { 1345 array->obj_at_put(i, locals->at(i)->get_obj()()); 1346 } 1347 } 1348 C2V_END 1349 1350 C2V_VMENTRY(void, writeDebugOutput, (JNIEnv*, jobject, jbyteArray bytes, jint offset, jint length)) 1351 if (bytes == NULL) { 1352 THROW(vmSymbols::java_lang_NullPointerException()); 1353 } 1354 typeArrayOop array = (typeArrayOop) JNIHandles::resolve(bytes); 1355 1356 // Check if offset and length are non negative. 1357 if (offset < 0 || length < 0) { 1358 THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException()); 1359 } 1360 // Check if the range is valid. 1361 if ((((unsigned int) length + (unsigned int) offset) > (unsigned int) array->length())) { 1362 THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException()); 1363 } 1364 while (length > 0) { 1365 jbyte* start = array->byte_at_addr(offset); 1366 tty->write((char*) start, MIN2(length, O_BUFLEN)); 1367 length -= O_BUFLEN; 1368 offset += O_BUFLEN; 1369 } 1370 C2V_END 1371 1372 C2V_VMENTRY(void, flushDebugOutput, (JNIEnv*, jobject)) 1373 tty->flush(); 1374 C2V_END 1375 1376 C2V_VMENTRY(int, methodDataProfileDataSize, (JNIEnv*, jobject, jlong metaspace_method_data, jint position)) 1377 ResourceMark rm; 1378 MethodData* mdo = CompilerToVM::asMethodData(metaspace_method_data); 1379 ProfileData* profile_data = mdo->data_at(position); 1380 if (mdo->is_valid(profile_data)) { 1381 return profile_data->size_in_bytes(); 1382 } 1383 DataLayout* data = mdo->extra_data_base(); 1384 DataLayout* end = mdo->extra_data_limit(); 1385 for (;; data = mdo->next_extra(data)) { 1386 assert(data < end, "moved past end of extra data"); 1387 profile_data = data->data_in(); 1388 if (mdo->dp_to_di(profile_data->dp()) == position) { 1389 return profile_data->size_in_bytes(); 1390 } 1391 } 1392 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(), err_msg("Invalid profile data position %d", position)); 1393 C2V_END 1394 1395 C2V_VMENTRY(int, interpreterFrameSize, (JNIEnv*, jobject, jobject bytecode_frame_handle)) 1396 if (bytecode_frame_handle == NULL) { 1397 THROW_0(vmSymbols::java_lang_NullPointerException()); 1398 } 1399 1400 oop top_bytecode_frame = JNIHandles::resolve_non_null(bytecode_frame_handle); 1401 oop bytecode_frame = top_bytecode_frame; 1402 int size = 0; 1403 int callee_parameters = 0; 1404 int callee_locals = 0; 1405 Method* method = getMethodFromHotSpotMethod(BytecodePosition::method(bytecode_frame)); 1406 int extra_args = method->max_stack() - BytecodeFrame::numStack(bytecode_frame); 1407 1408 while (bytecode_frame != NULL) { 1409 int locks = BytecodeFrame::numLocks(bytecode_frame); 1410 int temps = BytecodeFrame::numStack(bytecode_frame); 1411 bool is_top_frame = (bytecode_frame == top_bytecode_frame); 1412 Method* method = getMethodFromHotSpotMethod(BytecodePosition::method(bytecode_frame)); 1413 1414 int frame_size = BytesPerWord * Interpreter::size_activation(method->max_stack(), 1415 temps + callee_parameters, 1416 extra_args, 1417 locks, 1418 callee_parameters, 1419 callee_locals, 1420 is_top_frame); 1421 size += frame_size; 1422 1423 callee_parameters = method->size_of_parameters(); 1424 callee_locals = method->max_locals(); 1425 extra_args = 0; 1426 bytecode_frame = BytecodePosition::caller(bytecode_frame); 1427 } 1428 return size + Deoptimization::last_frame_adjust(0, callee_locals) * BytesPerWord; 1429 C2V_END 1430 1431 1432 #define CC (char*) /*cast a literal from (const char*)*/ 1433 #define FN_PTR(f) CAST_FROM_FN_PTR(void*, &(c2v_ ## f)) 1434 1435 #define STRING "Ljava/lang/String;" 1436 #define OBJECT "Ljava/lang/Object;" 1437 #define CLASS "Ljava/lang/Class;" 1438 #define STACK_TRACE_ELEMENT "Ljava/lang/StackTraceElement;" 1439 #define INSTALLED_CODE "Ljdk/vm/ci/code/InstalledCode;" 1440 #define TARGET_DESCRIPTION "Ljdk/vm/ci/code/TargetDescription;" 1441 #define BYTECODE_FRAME "Ljdk/vm/ci/code/BytecodeFrame;" 1442 #define RESOLVED_METHOD "Ljdk/vm/ci/meta/ResolvedJavaMethod;" 1443 #define HS_RESOLVED_METHOD "Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethodImpl;" 1444 #define HS_RESOLVED_KLASS "Ljdk/vm/ci/hotspot/HotSpotResolvedObjectTypeImpl;" 1445 #define HS_CONSTANT_POOL "Ljdk/vm/ci/hotspot/HotSpotConstantPool;" 1446 #define HS_COMPILED_CODE "Ljdk/vm/ci/hotspot/HotSpotCompiledCode;" 1447 #define HS_CONFIG "Ljdk/vm/ci/hotspot/HotSpotVMConfig;" 1448 #define HS_METADATA "Ljdk/vm/ci/hotspot/HotSpotMetaData;" 1449 #define HS_STACK_FRAME_REF "Ljdk/vm/ci/hotspot/HotSpotStackFrameReference;" 1450 #define HS_SPECULATION_LOG "Ljdk/vm/ci/hotspot/HotSpotSpeculationLog;" 1451 #define METASPACE_METHOD_DATA "J" 1452 1453 JNINativeMethod CompilerToVM::methods[] = { 1454 {CC"getBytecode", CC"("HS_RESOLVED_METHOD")[B", FN_PTR(getBytecode)}, 1455 {CC"getExceptionTableStart", CC"("HS_RESOLVED_METHOD")J", FN_PTR(getExceptionTableStart)}, 1456 {CC"getExceptionTableLength", CC"("HS_RESOLVED_METHOD")I", FN_PTR(getExceptionTableLength)}, 1457 {CC"findUniqueConcreteMethod", CC"("HS_RESOLVED_KLASS HS_RESOLVED_METHOD")"HS_RESOLVED_METHOD, FN_PTR(findUniqueConcreteMethod)}, 1458 {CC"getImplementor", CC"("HS_RESOLVED_KLASS")"HS_RESOLVED_KLASS, FN_PTR(getImplementor)}, 1459 {CC"getStackTraceElement", CC"("HS_RESOLVED_METHOD"I)"STACK_TRACE_ELEMENT, FN_PTR(getStackTraceElement)}, 1460 {CC"methodIsIgnoredBySecurityStackWalk", CC"("HS_RESOLVED_METHOD")Z", FN_PTR(methodIsIgnoredBySecurityStackWalk)}, 1461 {CC"doNotInlineOrCompile", CC"("HS_RESOLVED_METHOD")V", FN_PTR(doNotInlineOrCompile)}, 1462 {CC"canInlineMethod", CC"("HS_RESOLVED_METHOD")Z", FN_PTR(canInlineMethod)}, 1463 {CC"shouldInlineMethod", CC"("HS_RESOLVED_METHOD")Z", FN_PTR(shouldInlineMethod)}, 1464 {CC"lookupType", CC"("STRING CLASS"Z)"HS_RESOLVED_KLASS, FN_PTR(lookupType)}, 1465 {CC"lookupNameInPool", CC"("HS_CONSTANT_POOL"I)"STRING, FN_PTR(lookupNameInPool)}, 1466 {CC"lookupNameAndTypeRefIndexInPool", CC"("HS_CONSTANT_POOL"I)I", FN_PTR(lookupNameAndTypeRefIndexInPool)}, 1467 {CC"lookupSignatureInPool", CC"("HS_CONSTANT_POOL"I)"STRING, FN_PTR(lookupSignatureInPool)}, 1468 {CC"lookupKlassRefIndexInPool", CC"("HS_CONSTANT_POOL"I)I", FN_PTR(lookupKlassRefIndexInPool)}, 1469 {CC"lookupKlassInPool", CC"("HS_CONSTANT_POOL"I)Ljava/lang/Object;", FN_PTR(lookupKlassInPool)}, 1470 {CC"lookupAppendixInPool", CC"("HS_CONSTANT_POOL"I)"OBJECT, FN_PTR(lookupAppendixInPool)}, 1471 {CC"lookupMethodInPool", CC"("HS_CONSTANT_POOL"IB)"HS_RESOLVED_METHOD, FN_PTR(lookupMethodInPool)}, 1472 {CC"constantPoolRemapInstructionOperandFromCache", CC"("HS_CONSTANT_POOL"I)I", FN_PTR(constantPoolRemapInstructionOperandFromCache)}, 1473 {CC"resolveConstantInPool", CC"("HS_CONSTANT_POOL"I)"OBJECT, FN_PTR(resolveConstantInPool)}, 1474 {CC"resolvePossiblyCachedConstantInPool", CC"("HS_CONSTANT_POOL"I)"OBJECT, FN_PTR(resolvePossiblyCachedConstantInPool)}, 1475 {CC"resolveTypeInPool", CC"("HS_CONSTANT_POOL"I)"HS_RESOLVED_KLASS, FN_PTR(resolveTypeInPool)}, 1476 {CC"resolveFieldInPool", CC"("HS_CONSTANT_POOL"IB[J)"HS_RESOLVED_KLASS, FN_PTR(resolveFieldInPool)}, 1477 {CC"resolveInvokeDynamicInPool", CC"("HS_CONSTANT_POOL"I)V", FN_PTR(resolveInvokeDynamicInPool)}, 1478 {CC"resolveInvokeHandleInPool", CC"("HS_CONSTANT_POOL"I)V", FN_PTR(resolveInvokeHandleInPool)}, 1479 {CC"resolveMethod", CC"("HS_RESOLVED_KLASS HS_RESOLVED_METHOD HS_RESOLVED_KLASS")"HS_RESOLVED_METHOD, FN_PTR(resolveMethod)}, 1480 {CC"getVtableIndexForInterfaceMethod", CC"("HS_RESOLVED_KLASS HS_RESOLVED_METHOD")I", FN_PTR(getVtableIndexForInterfaceMethod)}, 1481 {CC"getClassInitializer", CC"("HS_RESOLVED_KLASS")"HS_RESOLVED_METHOD, FN_PTR(getClassInitializer)}, 1482 {CC"hasFinalizableSubclass", CC"("HS_RESOLVED_KLASS")Z", FN_PTR(hasFinalizableSubclass)}, 1483 {CC"getMaxCallTargetOffset", CC"(J)J", FN_PTR(getMaxCallTargetOffset)}, 1484 {CC"getResolvedJavaMethodAtSlot", CC"("CLASS"I)"HS_RESOLVED_METHOD, FN_PTR(getResolvedJavaMethodAtSlot)}, 1485 {CC"getResolvedJavaMethod", CC"(Ljava/lang/Object;J)"HS_RESOLVED_METHOD, FN_PTR(getResolvedJavaMethod)}, 1486 {CC"getConstantPool", CC"(Ljava/lang/Object;J)"HS_CONSTANT_POOL, FN_PTR(getConstantPool)}, 1487 {CC"getResolvedJavaType", CC"(Ljava/lang/Object;JZ)"HS_RESOLVED_KLASS, FN_PTR(getResolvedJavaType)}, 1488 {CC"initializeConfiguration", CC"("HS_CONFIG")J", FN_PTR(initializeConfiguration)}, 1489 {CC"installCode", CC"("TARGET_DESCRIPTION HS_COMPILED_CODE INSTALLED_CODE HS_SPECULATION_LOG")I", FN_PTR(installCode)}, 1490 {CC"getMetadata", CC"("TARGET_DESCRIPTION HS_COMPILED_CODE HS_METADATA")I", FN_PTR(getMetadata)}, 1491 {CC"notifyCompilationStatistics", CC"(I"HS_RESOLVED_METHOD"ZIJJ"INSTALLED_CODE")V", FN_PTR(notifyCompilationStatistics)}, 1492 {CC"resetCompilationStatistics", CC"()V", FN_PTR(resetCompilationStatistics)}, 1493 {CC"disassembleCodeBlob", CC"("INSTALLED_CODE")"STRING, FN_PTR(disassembleCodeBlob)}, 1494 {CC"executeInstalledCode", CC"(["OBJECT INSTALLED_CODE")"OBJECT, FN_PTR(executeInstalledCode)}, 1495 {CC"getLineNumberTable", CC"("HS_RESOLVED_METHOD")[J", FN_PTR(getLineNumberTable)}, 1496 {CC"getLocalVariableTableStart", CC"("HS_RESOLVED_METHOD")J", FN_PTR(getLocalVariableTableStart)}, 1497 {CC"getLocalVariableTableLength", CC"("HS_RESOLVED_METHOD")I", FN_PTR(getLocalVariableTableLength)}, 1498 {CC"reprofile", CC"("HS_RESOLVED_METHOD")V", FN_PTR(reprofile)}, 1499 {CC"invalidateInstalledCode", CC"("INSTALLED_CODE")V", FN_PTR(invalidateInstalledCode)}, 1500 {CC"readUncompressedOop", CC"(J)"OBJECT, FN_PTR(readUncompressedOop)}, 1501 {CC"collectCounters", CC"()[J", FN_PTR(collectCounters)}, 1502 {CC"allocateCompileId", CC"("HS_RESOLVED_METHOD"I)I", FN_PTR(allocateCompileId)}, 1503 {CC"isMature", CC"("METASPACE_METHOD_DATA")Z", FN_PTR(isMature)}, 1504 {CC"hasCompiledCodeForOSR", CC"("HS_RESOLVED_METHOD"II)Z", FN_PTR(hasCompiledCodeForOSR)}, 1505 {CC"getSymbol", CC"(J)"STRING, FN_PTR(getSymbol)}, 1506 {CC"getNextStackFrame", CC"("HS_STACK_FRAME_REF "["RESOLVED_METHOD"I)"HS_STACK_FRAME_REF, FN_PTR(getNextStackFrame)}, 1507 {CC"materializeVirtualObjects", CC"("HS_STACK_FRAME_REF"Z)V", FN_PTR(materializeVirtualObjects)}, 1508 {CC"shouldDebugNonSafepoints", CC"()Z", FN_PTR(shouldDebugNonSafepoints)}, 1509 {CC"writeDebugOutput", CC"([BII)V", FN_PTR(writeDebugOutput)}, 1510 {CC"flushDebugOutput", CC"()V", FN_PTR(flushDebugOutput)}, 1511 {CC"methodDataProfileDataSize", CC"(JI)I", FN_PTR(methodDataProfileDataSize)}, 1512 {CC"interpreterFrameSize", CC"("BYTECODE_FRAME")I", FN_PTR(interpreterFrameSize)}, 1513 }; 1514 1515 int CompilerToVM::methods_count() { 1516 return sizeof(methods) / sizeof(JNINativeMethod); 1517 } 1518