1 /* 2 * Copyright (c) 1999, 2023, 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 25 #include "precompiled.hpp" 26 #include "classfile/vmClasses.hpp" 27 #include "compiler/compilationMemoryStatistic.hpp" 28 #include "compiler/compilerDefinitions.inline.hpp" 29 #include "runtime/handles.inline.hpp" 30 #include "jfr/support/jfrIntrinsics.hpp" 31 #include "opto/c2compiler.hpp" 32 #include "opto/compile.hpp" 33 #include "opto/optoreg.hpp" 34 #include "opto/output.hpp" 35 #include "opto/runtime.hpp" 36 #include "runtime/stubRoutines.hpp" 37 #include "utilities/macros.hpp" 38 39 40 // register information defined by ADLC 41 extern const char register_save_policy[]; 42 extern const int register_save_type[]; 43 44 const char* C2Compiler::retry_no_subsuming_loads() { 45 return "retry without subsuming loads"; 46 } 47 const char* C2Compiler::retry_no_escape_analysis() { 48 return "retry without escape analysis"; 49 } 50 const char* C2Compiler::retry_no_locks_coarsening() { 51 return "retry without locks coarsening"; 52 } 53 const char* C2Compiler::retry_no_iterative_escape_analysis() { 54 return "retry without iterative escape analysis"; 55 } 56 const char* C2Compiler::retry_no_reduce_allocation_merges() { 57 return "retry without reducing allocation merges"; 58 } 59 const char* C2Compiler::retry_no_superword() { 60 return "retry without SuperWord"; 61 } 62 63 void compiler_stubs_init(bool in_compiler_thread); 64 65 bool C2Compiler::init_c2_runtime() { 66 67 // Check assumptions used while running ADLC 68 Compile::adlc_verification(); 69 assert(REG_COUNT <= ConcreteRegisterImpl::number_of_registers, "incompatible register counts"); 70 71 for (int i = 0; i < ConcreteRegisterImpl::number_of_registers ; i++ ) { 72 OptoReg::vm2opto[i] = OptoReg::Bad; 73 } 74 75 for( OptoReg::Name i=OptoReg::Name(0); i<OptoReg::Name(REG_COUNT); i = OptoReg::add(i,1) ) { 76 VMReg r = OptoReg::as_VMReg(i); 77 if (r->is_valid()) { 78 OptoReg::vm2opto[r->value()] = i; 79 } 80 } 81 82 DEBUG_ONLY( Node::init_NodeProperty(); ) 83 84 compiler_stubs_init(true /* in_compiler_thread */); // generate compiler's intrinsics stubs 85 86 Compile::pd_compiler2_init(); 87 88 CompilerThread* thread = CompilerThread::current(); 89 90 HandleMark handle_mark(thread); 91 return OptoRuntime::generate(thread->env()); 92 } 93 94 void C2Compiler::initialize() { 95 assert(!CompilerConfig::is_c1_or_interpreter_only_no_jvmci(), "C2 compiler is launched, it's not c1/interpreter only mode"); 96 // The first compiler thread that gets here will initialize the 97 // small amount of global state (and runtime stubs) that C2 needs. 98 99 // There is a race possible once at startup and then we're fine 100 101 // Note that this is being called from a compiler thread not the 102 // main startup thread. 103 if (should_perform_init()) { 104 bool successful = C2Compiler::init_c2_runtime(); 105 int new_state = (successful) ? initialized : failed; 106 set_state(new_state); 107 } 108 } 109 110 void C2Compiler::compile_method(ciEnv* env, ciMethod* target, int entry_bci, bool install_code, DirectiveSet* directive) { 111 assert(is_initialized(), "Compiler thread must be initialized"); 112 113 CompilationMemoryStatisticMark cmsm(directive); 114 115 bool subsume_loads = SubsumeLoads; 116 bool do_escape_analysis = DoEscapeAnalysis; 117 bool do_iterative_escape_analysis = DoEscapeAnalysis; 118 bool do_reduce_allocation_merges = ReduceAllocationMerges && EliminateAllocations; 119 bool eliminate_boxing = EliminateAutoBox; 120 bool do_locks_coarsening = EliminateLocks; 121 bool do_superword = UseSuperWord; 122 123 while (!env->failing()) { 124 ResourceMark rm; 125 // Attempt to compile while subsuming loads into machine instructions. 126 Options options(subsume_loads, 127 do_escape_analysis, 128 do_iterative_escape_analysis, 129 do_reduce_allocation_merges, 130 eliminate_boxing, 131 do_locks_coarsening, 132 do_superword, 133 install_code); 134 Compile C(env, target, entry_bci, options, directive); 135 136 // Check result and retry if appropriate. 137 if (C.failure_reason() != nullptr) { 138 if (C.failure_reason_is(retry_no_subsuming_loads())) { 139 assert(subsume_loads, "must make progress"); 140 subsume_loads = false; 141 env->report_failure(C.failure_reason()); 142 continue; // retry 143 } 144 if (C.failure_reason_is(retry_no_escape_analysis())) { 145 assert(do_escape_analysis, "must make progress"); 146 do_escape_analysis = false; 147 env->report_failure(C.failure_reason()); 148 continue; // retry 149 } 150 if (C.failure_reason_is(retry_no_iterative_escape_analysis())) { 151 assert(do_iterative_escape_analysis, "must make progress"); 152 do_iterative_escape_analysis = false; 153 env->report_failure(C.failure_reason()); 154 continue; // retry 155 } 156 if (C.failure_reason_is(retry_no_reduce_allocation_merges())) { 157 assert(do_reduce_allocation_merges, "must make progress"); 158 do_reduce_allocation_merges = false; 159 env->report_failure(C.failure_reason()); 160 continue; // retry 161 } 162 if (C.failure_reason_is(retry_no_locks_coarsening())) { 163 assert(do_locks_coarsening, "must make progress"); 164 do_locks_coarsening = false; 165 env->report_failure(C.failure_reason()); 166 continue; // retry 167 } 168 if (C.failure_reason_is(retry_no_superword())) { 169 assert(do_superword, "must make progress"); 170 do_superword = false; 171 env->report_failure(C.failure_reason()); 172 continue; // retry 173 } 174 if (C.has_boxed_value()) { 175 // Recompile without boxing elimination regardless failure reason. 176 assert(eliminate_boxing, "must make progress"); 177 eliminate_boxing = false; 178 env->report_failure(C.failure_reason()); 179 continue; // retry 180 } 181 // Pass any other failure reason up to the ciEnv. 182 // Note that serious, irreversible failures are already logged 183 // on the ciEnv via env->record_method_not_compilable(). 184 env->record_failure(C.failure_reason()); 185 } 186 if (StressRecompilation) { 187 if (subsume_loads) { 188 subsume_loads = false; 189 continue; // retry 190 } 191 if (do_escape_analysis) { 192 do_escape_analysis = false; 193 continue; // retry 194 } 195 if (do_locks_coarsening) { 196 do_locks_coarsening = false; 197 continue; // retry 198 } 199 } 200 // print inlining for last compilation only 201 C.dump_print_inlining(); 202 203 // No retry; just break the loop. 204 break; 205 } 206 } 207 208 void C2Compiler::print_timers() { 209 Compile::print_timers(); 210 } 211 212 bool C2Compiler::is_intrinsic_supported(const methodHandle& method) { 213 vmIntrinsics::ID id = method->intrinsic_id(); 214 return C2Compiler::is_intrinsic_supported(id); 215 } 216 217 bool C2Compiler::is_intrinsic_supported(vmIntrinsics::ID id) { 218 assert(id != vmIntrinsics::_none, "must be a VM intrinsic"); 219 220 if (id < vmIntrinsics::FIRST_ID || id > vmIntrinsics::LAST_COMPILER_INLINE) { 221 return false; 222 } 223 224 switch (id) { 225 case vmIntrinsics::_compressStringC: 226 case vmIntrinsics::_compressStringB: 227 if (!Matcher::match_rule_supported(Op_StrCompressedCopy)) return false; 228 break; 229 case vmIntrinsics::_inflateStringC: 230 case vmIntrinsics::_inflateStringB: 231 if (!Matcher::match_rule_supported(Op_StrInflatedCopy)) return false; 232 break; 233 case vmIntrinsics::_compareToL: 234 case vmIntrinsics::_compareToU: 235 case vmIntrinsics::_compareToLU: 236 case vmIntrinsics::_compareToUL: 237 if (!Matcher::match_rule_supported(Op_StrComp)) return false; 238 break; 239 case vmIntrinsics::_equalsL: 240 case vmIntrinsics::_equalsU: 241 if (!Matcher::match_rule_supported(Op_StrEquals)) return false; 242 break; 243 case vmIntrinsics::_vectorizedHashCode: 244 if (!Matcher::match_rule_supported(Op_VectorizedHashCode)) return false; 245 break; 246 case vmIntrinsics::_equalsB: 247 case vmIntrinsics::_equalsC: 248 if (!Matcher::match_rule_supported(Op_AryEq)) return false; 249 break; 250 case vmIntrinsics::_copyMemory: 251 if (StubRoutines::unsafe_arraycopy() == nullptr) return false; 252 break; 253 case vmIntrinsics::_electronicCodeBook_encryptAESCrypt: 254 if (StubRoutines::electronicCodeBook_encryptAESCrypt() == nullptr) return false; 255 break; 256 case vmIntrinsics::_electronicCodeBook_decryptAESCrypt: 257 if (StubRoutines::electronicCodeBook_decryptAESCrypt() == nullptr) return false; 258 break; 259 case vmIntrinsics::_galoisCounterMode_AESCrypt: 260 if (StubRoutines::galoisCounterMode_AESCrypt() == nullptr) return false; 261 break; 262 case vmIntrinsics::_bigIntegerRightShiftWorker: 263 if (StubRoutines::bigIntegerRightShift() == nullptr) return false; 264 break; 265 case vmIntrinsics::_bigIntegerLeftShiftWorker: 266 if (StubRoutines::bigIntegerLeftShift() == nullptr) return false; 267 break; 268 case vmIntrinsics::_encodeAsciiArray: 269 if (!Matcher::match_rule_supported(Op_EncodeISOArray) || !Matcher::supports_encode_ascii_array) return false; 270 break; 271 case vmIntrinsics::_encodeISOArray: 272 case vmIntrinsics::_encodeByteISOArray: 273 if (!Matcher::match_rule_supported(Op_EncodeISOArray)) return false; 274 break; 275 case vmIntrinsics::_countPositives: 276 if (!Matcher::match_rule_supported(Op_CountPositives)) return false; 277 break; 278 case vmIntrinsics::_bitCount_i: 279 if (!Matcher::match_rule_supported(Op_PopCountI)) return false; 280 break; 281 case vmIntrinsics::_bitCount_l: 282 if (!Matcher::match_rule_supported(Op_PopCountL)) return false; 283 break; 284 case vmIntrinsics::_compress_i: 285 case vmIntrinsics::_compress_l: 286 if (!Matcher::match_rule_supported(Op_CompressBits)) return false; 287 break; 288 case vmIntrinsics::_expand_i: 289 case vmIntrinsics::_expand_l: 290 if (!Matcher::match_rule_supported(Op_ExpandBits)) return false; 291 break; 292 case vmIntrinsics::_numberOfLeadingZeros_i: 293 if (!Matcher::match_rule_supported(Op_CountLeadingZerosI)) return false; 294 break; 295 case vmIntrinsics::_numberOfLeadingZeros_l: 296 if (!Matcher::match_rule_supported(Op_CountLeadingZerosL)) return false; 297 break; 298 case vmIntrinsics::_numberOfTrailingZeros_i: 299 if (!Matcher::match_rule_supported(Op_CountTrailingZerosI)) return false; 300 break; 301 case vmIntrinsics::_numberOfTrailingZeros_l: 302 if (!Matcher::match_rule_supported(Op_CountTrailingZerosL)) return false; 303 break; 304 case vmIntrinsics::_reverse_i: 305 if (!Matcher::match_rule_supported(Op_ReverseI)) return false; 306 break; 307 case vmIntrinsics::_reverse_l: 308 if (!Matcher::match_rule_supported(Op_ReverseL)) return false; 309 break; 310 case vmIntrinsics::_reverseBytes_c: 311 if (!Matcher::match_rule_supported(Op_ReverseBytesUS)) return false; 312 break; 313 case vmIntrinsics::_reverseBytes_s: 314 if (!Matcher::match_rule_supported(Op_ReverseBytesS)) return false; 315 break; 316 case vmIntrinsics::_reverseBytes_i: 317 if (!Matcher::match_rule_supported(Op_ReverseBytesI)) return false; 318 break; 319 case vmIntrinsics::_reverseBytes_l: 320 if (!Matcher::match_rule_supported(Op_ReverseBytesL)) return false; 321 break; 322 case vmIntrinsics::_compareUnsigned_i: 323 if (!Matcher::match_rule_supported(Op_CmpU3)) return false; 324 break; 325 case vmIntrinsics::_compareUnsigned_l: 326 if (!Matcher::match_rule_supported(Op_CmpUL3)) return false; 327 break; 328 case vmIntrinsics::_divideUnsigned_i: 329 if (!Matcher::match_rule_supported(Op_UDivI)) return false; 330 break; 331 case vmIntrinsics::_remainderUnsigned_i: 332 if (!Matcher::match_rule_supported(Op_UModI)) return false; 333 break; 334 case vmIntrinsics::_divideUnsigned_l: 335 if (!Matcher::match_rule_supported(Op_UDivL)) return false; 336 break; 337 case vmIntrinsics::_remainderUnsigned_l: 338 if (!Matcher::match_rule_supported(Op_UModL)) return false; 339 break; 340 case vmIntrinsics::_float16ToFloat: 341 if (!Matcher::match_rule_supported(Op_ConvHF2F)) return false; 342 break; 343 case vmIntrinsics::_floatToFloat16: 344 if (!Matcher::match_rule_supported(Op_ConvF2HF)) return false; 345 break; 346 347 /* CompareAndSet, Object: */ 348 case vmIntrinsics::_compareAndSetReference: 349 #ifdef _LP64 350 if ( UseCompressedOops && !Matcher::match_rule_supported(Op_CompareAndSwapN)) return false; 351 if (!UseCompressedOops && !Matcher::match_rule_supported(Op_CompareAndSwapP)) return false; 352 #else 353 if (!Matcher::match_rule_supported(Op_CompareAndSwapP)) return false; 354 #endif 355 break; 356 case vmIntrinsics::_weakCompareAndSetReferencePlain: 357 case vmIntrinsics::_weakCompareAndSetReferenceAcquire: 358 case vmIntrinsics::_weakCompareAndSetReferenceRelease: 359 case vmIntrinsics::_weakCompareAndSetReference: 360 #ifdef _LP64 361 if ( UseCompressedOops && !Matcher::match_rule_supported(Op_WeakCompareAndSwapN)) return false; 362 if (!UseCompressedOops && !Matcher::match_rule_supported(Op_WeakCompareAndSwapP)) return false; 363 #else 364 if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapP)) return false; 365 #endif 366 break; 367 /* CompareAndSet, Long: */ 368 case vmIntrinsics::_compareAndSetLong: 369 if (!Matcher::match_rule_supported(Op_CompareAndSwapL)) return false; 370 break; 371 case vmIntrinsics::_weakCompareAndSetLongPlain: 372 case vmIntrinsics::_weakCompareAndSetLongAcquire: 373 case vmIntrinsics::_weakCompareAndSetLongRelease: 374 case vmIntrinsics::_weakCompareAndSetLong: 375 if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapL)) return false; 376 break; 377 378 /* CompareAndSet, Int: */ 379 case vmIntrinsics::_compareAndSetInt: 380 if (!Matcher::match_rule_supported(Op_CompareAndSwapI)) return false; 381 break; 382 case vmIntrinsics::_weakCompareAndSetIntPlain: 383 case vmIntrinsics::_weakCompareAndSetIntAcquire: 384 case vmIntrinsics::_weakCompareAndSetIntRelease: 385 case vmIntrinsics::_weakCompareAndSetInt: 386 if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapI)) return false; 387 break; 388 389 /* CompareAndSet, Byte: */ 390 case vmIntrinsics::_compareAndSetByte: 391 if (!Matcher::match_rule_supported(Op_CompareAndSwapB)) return false; 392 break; 393 case vmIntrinsics::_weakCompareAndSetBytePlain: 394 case vmIntrinsics::_weakCompareAndSetByteAcquire: 395 case vmIntrinsics::_weakCompareAndSetByteRelease: 396 case vmIntrinsics::_weakCompareAndSetByte: 397 if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapB)) return false; 398 break; 399 400 /* CompareAndSet, Short: */ 401 case vmIntrinsics::_compareAndSetShort: 402 if (!Matcher::match_rule_supported(Op_CompareAndSwapS)) return false; 403 break; 404 case vmIntrinsics::_weakCompareAndSetShortPlain: 405 case vmIntrinsics::_weakCompareAndSetShortAcquire: 406 case vmIntrinsics::_weakCompareAndSetShortRelease: 407 case vmIntrinsics::_weakCompareAndSetShort: 408 if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapS)) return false; 409 break; 410 411 /* CompareAndExchange, Object: */ 412 case vmIntrinsics::_compareAndExchangeReference: 413 case vmIntrinsics::_compareAndExchangeReferenceAcquire: 414 case vmIntrinsics::_compareAndExchangeReferenceRelease: 415 #ifdef _LP64 416 if ( UseCompressedOops && !Matcher::match_rule_supported(Op_CompareAndExchangeN)) return false; 417 if (!UseCompressedOops && !Matcher::match_rule_supported(Op_CompareAndExchangeP)) return false; 418 #else 419 if (!Matcher::match_rule_supported(Op_CompareAndExchangeP)) return false; 420 #endif 421 break; 422 423 /* CompareAndExchange, Long: */ 424 case vmIntrinsics::_compareAndExchangeLong: 425 case vmIntrinsics::_compareAndExchangeLongAcquire: 426 case vmIntrinsics::_compareAndExchangeLongRelease: 427 if (!Matcher::match_rule_supported(Op_CompareAndExchangeL)) return false; 428 break; 429 430 /* CompareAndExchange, Int: */ 431 case vmIntrinsics::_compareAndExchangeInt: 432 case vmIntrinsics::_compareAndExchangeIntAcquire: 433 case vmIntrinsics::_compareAndExchangeIntRelease: 434 if (!Matcher::match_rule_supported(Op_CompareAndExchangeI)) return false; 435 break; 436 437 /* CompareAndExchange, Byte: */ 438 case vmIntrinsics::_compareAndExchangeByte: 439 case vmIntrinsics::_compareAndExchangeByteAcquire: 440 case vmIntrinsics::_compareAndExchangeByteRelease: 441 if (!Matcher::match_rule_supported(Op_CompareAndExchangeB)) return false; 442 break; 443 444 /* CompareAndExchange, Short: */ 445 case vmIntrinsics::_compareAndExchangeShort: 446 case vmIntrinsics::_compareAndExchangeShortAcquire: 447 case vmIntrinsics::_compareAndExchangeShortRelease: 448 if (!Matcher::match_rule_supported(Op_CompareAndExchangeS)) return false; 449 break; 450 451 case vmIntrinsics::_getAndAddByte: 452 if (!Matcher::match_rule_supported(Op_GetAndAddB)) return false; 453 break; 454 case vmIntrinsics::_getAndAddShort: 455 if (!Matcher::match_rule_supported(Op_GetAndAddS)) return false; 456 break; 457 case vmIntrinsics::_getAndAddInt: 458 if (!Matcher::match_rule_supported(Op_GetAndAddI)) return false; 459 break; 460 case vmIntrinsics::_getAndAddLong: 461 if (!Matcher::match_rule_supported(Op_GetAndAddL)) return false; 462 break; 463 464 case vmIntrinsics::_getAndSetByte: 465 if (!Matcher::match_rule_supported(Op_GetAndSetB)) return false; 466 break; 467 case vmIntrinsics::_getAndSetShort: 468 if (!Matcher::match_rule_supported(Op_GetAndSetS)) return false; 469 break; 470 case vmIntrinsics::_getAndSetInt: 471 if (!Matcher::match_rule_supported(Op_GetAndSetI)) return false; 472 break; 473 case vmIntrinsics::_getAndSetLong: 474 if (!Matcher::match_rule_supported(Op_GetAndSetL)) return false; 475 break; 476 case vmIntrinsics::_getAndSetReference: 477 #ifdef _LP64 478 if (!UseCompressedOops && !Matcher::match_rule_supported(Op_GetAndSetP)) return false; 479 if (UseCompressedOops && !Matcher::match_rule_supported(Op_GetAndSetN)) return false; 480 break; 481 #else 482 if (!Matcher::match_rule_supported(Op_GetAndSetP)) return false; 483 break; 484 #endif 485 case vmIntrinsics::_incrementExactI: 486 case vmIntrinsics::_addExactI: 487 if (!Matcher::match_rule_supported(Op_OverflowAddI)) return false; 488 break; 489 case vmIntrinsics::_incrementExactL: 490 case vmIntrinsics::_addExactL: 491 if (!Matcher::match_rule_supported(Op_OverflowAddL)) return false; 492 break; 493 case vmIntrinsics::_decrementExactI: 494 case vmIntrinsics::_subtractExactI: 495 if (!Matcher::match_rule_supported(Op_OverflowSubI)) return false; 496 break; 497 case vmIntrinsics::_decrementExactL: 498 case vmIntrinsics::_subtractExactL: 499 if (!Matcher::match_rule_supported(Op_OverflowSubL)) return false; 500 break; 501 case vmIntrinsics::_negateExactI: 502 if (!Matcher::match_rule_supported(Op_OverflowSubI)) return false; 503 break; 504 case vmIntrinsics::_negateExactL: 505 if (!Matcher::match_rule_supported(Op_OverflowSubL)) return false; 506 break; 507 case vmIntrinsics::_multiplyExactI: 508 if (!Matcher::match_rule_supported(Op_OverflowMulI)) return false; 509 break; 510 case vmIntrinsics::_multiplyExactL: 511 if (!Matcher::match_rule_supported(Op_OverflowMulL)) return false; 512 break; 513 case vmIntrinsics::_multiplyHigh: 514 if (!Matcher::match_rule_supported(Op_MulHiL)) return false; 515 break; 516 case vmIntrinsics::_unsignedMultiplyHigh: 517 if (!Matcher::match_rule_supported(Op_UMulHiL)) return false; 518 break; 519 case vmIntrinsics::_getCallerClass: 520 if (vmClasses::reflect_CallerSensitive_klass() == nullptr) return false; 521 break; 522 case vmIntrinsics::_onSpinWait: 523 if (!Matcher::match_rule_supported(Op_OnSpinWait)) return false; 524 break; 525 case vmIntrinsics::_fmaD: 526 if (!Matcher::match_rule_supported(Op_FmaD)) return false; 527 break; 528 case vmIntrinsics::_fmaF: 529 if (!Matcher::match_rule_supported(Op_FmaF)) return false; 530 break; 531 case vmIntrinsics::_isDigit: 532 if (!Matcher::match_rule_supported(Op_Digit)) return false; 533 break; 534 case vmIntrinsics::_isLowerCase: 535 if (!Matcher::match_rule_supported(Op_LowerCase)) return false; 536 break; 537 case vmIntrinsics::_isUpperCase: 538 if (!Matcher::match_rule_supported(Op_UpperCase)) return false; 539 break; 540 case vmIntrinsics::_isWhitespace: 541 if (!Matcher::match_rule_supported(Op_Whitespace)) return false; 542 break; 543 case vmIntrinsics::_maxF: 544 case vmIntrinsics::_maxF_strict: 545 if (!Matcher::match_rule_supported(Op_MaxF)) return false; 546 break; 547 case vmIntrinsics::_minF: 548 case vmIntrinsics::_minF_strict: 549 if (!Matcher::match_rule_supported(Op_MinF)) return false; 550 break; 551 case vmIntrinsics::_maxD: 552 case vmIntrinsics::_maxD_strict: 553 if (!Matcher::match_rule_supported(Op_MaxD)) return false; 554 break; 555 case vmIntrinsics::_minD: 556 case vmIntrinsics::_minD_strict: 557 if (!Matcher::match_rule_supported(Op_MinD)) return false; 558 break; 559 case vmIntrinsics::_writeback0: 560 if (!Matcher::match_rule_supported(Op_CacheWB)) return false; 561 break; 562 case vmIntrinsics::_writebackPreSync0: 563 if (!Matcher::match_rule_supported(Op_CacheWBPreSync)) return false; 564 break; 565 case vmIntrinsics::_writebackPostSync0: 566 if (!Matcher::match_rule_supported(Op_CacheWBPostSync)) return false; 567 break; 568 case vmIntrinsics::_rint: 569 case vmIntrinsics::_ceil: 570 case vmIntrinsics::_floor: 571 if (!Matcher::match_rule_supported(Op_RoundDoubleMode)) return false; 572 break; 573 case vmIntrinsics::_dcopySign: 574 if (!Matcher::match_rule_supported(Op_CopySignD)) return false; 575 break; 576 case vmIntrinsics::_fcopySign: 577 if (!Matcher::match_rule_supported(Op_CopySignF)) return false; 578 break; 579 case vmIntrinsics::_dsignum: 580 if (!Matcher::match_rule_supported(Op_SignumD)) return false; 581 break; 582 case vmIntrinsics::_fsignum: 583 if (!Matcher::match_rule_supported(Op_SignumF)) return false; 584 break; 585 case vmIntrinsics::_floatIsInfinite: 586 if (!Matcher::match_rule_supported(Op_IsInfiniteF)) return false; 587 break; 588 case vmIntrinsics::_floatIsFinite: 589 if (!Matcher::match_rule_supported(Op_IsFiniteF)) return false; 590 break; 591 case vmIntrinsics::_doubleIsInfinite: 592 if (!Matcher::match_rule_supported(Op_IsInfiniteD)) return false; 593 break; 594 case vmIntrinsics::_doubleIsFinite: 595 if (!Matcher::match_rule_supported(Op_IsFiniteD)) return false; 596 break; 597 case vmIntrinsics::_hashCode: 598 case vmIntrinsics::_identityHashCode: 599 case vmIntrinsics::_getClass: 600 case vmIntrinsics::_dsin: 601 case vmIntrinsics::_dcos: 602 case vmIntrinsics::_dtan: 603 case vmIntrinsics::_dabs: 604 case vmIntrinsics::_fabs: 605 case vmIntrinsics::_iabs: 606 case vmIntrinsics::_labs: 607 case vmIntrinsics::_datan2: 608 case vmIntrinsics::_dsqrt: 609 case vmIntrinsics::_dsqrt_strict: 610 case vmIntrinsics::_dexp: 611 case vmIntrinsics::_dlog: 612 case vmIntrinsics::_dlog10: 613 case vmIntrinsics::_dpow: 614 case vmIntrinsics::_roundD: 615 case vmIntrinsics::_roundF: 616 case vmIntrinsics::_min: 617 case vmIntrinsics::_max: 618 case vmIntrinsics::_min_strict: 619 case vmIntrinsics::_max_strict: 620 case vmIntrinsics::_arraycopy: 621 case vmIntrinsics::_arraySort: 622 case vmIntrinsics::_arrayPartition: 623 case vmIntrinsics::_indexOfL: 624 case vmIntrinsics::_indexOfU: 625 case vmIntrinsics::_indexOfUL: 626 case vmIntrinsics::_indexOfIL: 627 case vmIntrinsics::_indexOfIU: 628 case vmIntrinsics::_indexOfIUL: 629 case vmIntrinsics::_indexOfU_char: 630 case vmIntrinsics::_indexOfL_char: 631 case vmIntrinsics::_toBytesStringU: 632 case vmIntrinsics::_getCharsStringU: 633 case vmIntrinsics::_getCharStringU: 634 case vmIntrinsics::_putCharStringU: 635 case vmIntrinsics::_getReference: 636 case vmIntrinsics::_getBoolean: 637 case vmIntrinsics::_getByte: 638 case vmIntrinsics::_getShort: 639 case vmIntrinsics::_getChar: 640 case vmIntrinsics::_getInt: 641 case vmIntrinsics::_getLong: 642 case vmIntrinsics::_getFloat: 643 case vmIntrinsics::_getDouble: 644 case vmIntrinsics::_putReference: 645 case vmIntrinsics::_putBoolean: 646 case vmIntrinsics::_putByte: 647 case vmIntrinsics::_putShort: 648 case vmIntrinsics::_putChar: 649 case vmIntrinsics::_putInt: 650 case vmIntrinsics::_putLong: 651 case vmIntrinsics::_putFloat: 652 case vmIntrinsics::_putDouble: 653 case vmIntrinsics::_getReferenceVolatile: 654 case vmIntrinsics::_getBooleanVolatile: 655 case vmIntrinsics::_getByteVolatile: 656 case vmIntrinsics::_getShortVolatile: 657 case vmIntrinsics::_getCharVolatile: 658 case vmIntrinsics::_getIntVolatile: 659 case vmIntrinsics::_getLongVolatile: 660 case vmIntrinsics::_getFloatVolatile: 661 case vmIntrinsics::_getDoubleVolatile: 662 case vmIntrinsics::_putReferenceVolatile: 663 case vmIntrinsics::_putBooleanVolatile: 664 case vmIntrinsics::_putByteVolatile: 665 case vmIntrinsics::_putShortVolatile: 666 case vmIntrinsics::_putCharVolatile: 667 case vmIntrinsics::_putIntVolatile: 668 case vmIntrinsics::_putLongVolatile: 669 case vmIntrinsics::_putFloatVolatile: 670 case vmIntrinsics::_putDoubleVolatile: 671 case vmIntrinsics::_getReferenceAcquire: 672 case vmIntrinsics::_getBooleanAcquire: 673 case vmIntrinsics::_getByteAcquire: 674 case vmIntrinsics::_getShortAcquire: 675 case vmIntrinsics::_getCharAcquire: 676 case vmIntrinsics::_getIntAcquire: 677 case vmIntrinsics::_getLongAcquire: 678 case vmIntrinsics::_getFloatAcquire: 679 case vmIntrinsics::_getDoubleAcquire: 680 case vmIntrinsics::_putReferenceRelease: 681 case vmIntrinsics::_putBooleanRelease: 682 case vmIntrinsics::_putByteRelease: 683 case vmIntrinsics::_putShortRelease: 684 case vmIntrinsics::_putCharRelease: 685 case vmIntrinsics::_putIntRelease: 686 case vmIntrinsics::_putLongRelease: 687 case vmIntrinsics::_putFloatRelease: 688 case vmIntrinsics::_putDoubleRelease: 689 case vmIntrinsics::_getReferenceOpaque: 690 case vmIntrinsics::_getBooleanOpaque: 691 case vmIntrinsics::_getByteOpaque: 692 case vmIntrinsics::_getShortOpaque: 693 case vmIntrinsics::_getCharOpaque: 694 case vmIntrinsics::_getIntOpaque: 695 case vmIntrinsics::_getLongOpaque: 696 case vmIntrinsics::_getFloatOpaque: 697 case vmIntrinsics::_getDoubleOpaque: 698 case vmIntrinsics::_putReferenceOpaque: 699 case vmIntrinsics::_putBooleanOpaque: 700 case vmIntrinsics::_putByteOpaque: 701 case vmIntrinsics::_putShortOpaque: 702 case vmIntrinsics::_putCharOpaque: 703 case vmIntrinsics::_putIntOpaque: 704 case vmIntrinsics::_putLongOpaque: 705 case vmIntrinsics::_putFloatOpaque: 706 case vmIntrinsics::_putDoubleOpaque: 707 case vmIntrinsics::_getShortUnaligned: 708 case vmIntrinsics::_getCharUnaligned: 709 case vmIntrinsics::_getIntUnaligned: 710 case vmIntrinsics::_getLongUnaligned: 711 case vmIntrinsics::_putShortUnaligned: 712 case vmIntrinsics::_putCharUnaligned: 713 case vmIntrinsics::_putIntUnaligned: 714 case vmIntrinsics::_putLongUnaligned: 715 case vmIntrinsics::_loadFence: 716 case vmIntrinsics::_storeFence: 717 case vmIntrinsics::_storeStoreFence: 718 case vmIntrinsics::_fullFence: 719 case vmIntrinsics::_currentCarrierThread: 720 case vmIntrinsics::_currentThread: 721 case vmIntrinsics::_setCurrentThread: 722 case vmIntrinsics::_scopedValueCache: 723 case vmIntrinsics::_setScopedValueCache: 724 #ifdef JFR_HAVE_INTRINSICS 725 case vmIntrinsics::_counterTime: 726 case vmIntrinsics::_getEventWriter: 727 case vmIntrinsics::_jvm_commit: 728 #endif 729 case vmIntrinsics::_currentTimeMillis: 730 case vmIntrinsics::_nanoTime: 731 case vmIntrinsics::_allocateInstance: 732 case vmIntrinsics::_allocateUninitializedArray: 733 case vmIntrinsics::_newArray: 734 case vmIntrinsics::_getLength: 735 case vmIntrinsics::_copyOf: 736 case vmIntrinsics::_copyOfRange: 737 case vmIntrinsics::_clone: 738 case vmIntrinsics::_isAssignableFrom: 739 case vmIntrinsics::_isInstance: 740 case vmIntrinsics::_getModifiers: 741 case vmIntrinsics::_isInterface: 742 case vmIntrinsics::_isArray: 743 case vmIntrinsics::_isPrimitive: 744 case vmIntrinsics::_isHidden: 745 case vmIntrinsics::_getSuperclass: 746 case vmIntrinsics::_getClassAccessFlags: 747 case vmIntrinsics::_floatToRawIntBits: 748 case vmIntrinsics::_floatToIntBits: 749 case vmIntrinsics::_intBitsToFloat: 750 case vmIntrinsics::_doubleToRawLongBits: 751 case vmIntrinsics::_doubleToLongBits: 752 case vmIntrinsics::_longBitsToDouble: 753 case vmIntrinsics::_Reference_get: 754 case vmIntrinsics::_Reference_refersTo0: 755 case vmIntrinsics::_PhantomReference_refersTo0: 756 case vmIntrinsics::_Class_cast: 757 case vmIntrinsics::_aescrypt_encryptBlock: 758 case vmIntrinsics::_aescrypt_decryptBlock: 759 case vmIntrinsics::_cipherBlockChaining_encryptAESCrypt: 760 case vmIntrinsics::_cipherBlockChaining_decryptAESCrypt: 761 case vmIntrinsics::_counterMode_AESCrypt: 762 case vmIntrinsics::_md5_implCompress: 763 case vmIntrinsics::_sha_implCompress: 764 case vmIntrinsics::_sha2_implCompress: 765 case vmIntrinsics::_sha5_implCompress: 766 case vmIntrinsics::_sha3_implCompress: 767 case vmIntrinsics::_digestBase_implCompressMB: 768 case vmIntrinsics::_multiplyToLen: 769 case vmIntrinsics::_squareToLen: 770 case vmIntrinsics::_mulAdd: 771 case vmIntrinsics::_montgomeryMultiply: 772 case vmIntrinsics::_montgomerySquare: 773 case vmIntrinsics::_vectorizedMismatch: 774 case vmIntrinsics::_ghash_processBlocks: 775 case vmIntrinsics::_chacha20Block: 776 case vmIntrinsics::_base64_encodeBlock: 777 case vmIntrinsics::_base64_decodeBlock: 778 case vmIntrinsics::_poly1305_processBlocks: 779 case vmIntrinsics::_updateCRC32: 780 case vmIntrinsics::_updateBytesCRC32: 781 case vmIntrinsics::_updateByteBufferCRC32: 782 case vmIntrinsics::_updateBytesCRC32C: 783 case vmIntrinsics::_updateDirectByteBufferCRC32C: 784 case vmIntrinsics::_updateBytesAdler32: 785 case vmIntrinsics::_updateByteBufferAdler32: 786 case vmIntrinsics::_profileBoolean: 787 case vmIntrinsics::_isCompileConstant: 788 case vmIntrinsics::_Preconditions_checkIndex: 789 case vmIntrinsics::_Preconditions_checkLongIndex: 790 case vmIntrinsics::_getObjectSize: 791 break; 792 case vmIntrinsics::_VectorCompressExpand: 793 case vmIntrinsics::_VectorUnaryOp: 794 case vmIntrinsics::_VectorBinaryOp: 795 case vmIntrinsics::_VectorTernaryOp: 796 case vmIntrinsics::_VectorFromBitsCoerced: 797 case vmIntrinsics::_VectorShuffleIota: 798 case vmIntrinsics::_VectorShuffleToVector: 799 case vmIntrinsics::_VectorLoadOp: 800 case vmIntrinsics::_VectorLoadMaskedOp: 801 case vmIntrinsics::_VectorStoreOp: 802 case vmIntrinsics::_VectorStoreMaskedOp: 803 case vmIntrinsics::_VectorGatherOp: 804 case vmIntrinsics::_VectorScatterOp: 805 case vmIntrinsics::_VectorReductionCoerced: 806 case vmIntrinsics::_VectorTest: 807 case vmIntrinsics::_VectorBlend: 808 case vmIntrinsics::_VectorRearrange: 809 case vmIntrinsics::_VectorCompare: 810 case vmIntrinsics::_VectorBroadcastInt: 811 case vmIntrinsics::_VectorConvert: 812 case vmIntrinsics::_VectorInsert: 813 case vmIntrinsics::_VectorExtract: 814 case vmIntrinsics::_VectorMaskOp: 815 case vmIntrinsics::_IndexVector: 816 case vmIntrinsics::_IndexPartiallyInUpperRange: 817 return EnableVectorSupport; 818 case vmIntrinsics::_blackhole: 819 #if INCLUDE_JVMTI 820 case vmIntrinsics::_notifyJvmtiVThreadStart: 821 case vmIntrinsics::_notifyJvmtiVThreadEnd: 822 case vmIntrinsics::_notifyJvmtiVThreadMount: 823 case vmIntrinsics::_notifyJvmtiVThreadUnmount: 824 case vmIntrinsics::_notifyJvmtiVThreadHideFrames: 825 #endif 826 break; 827 828 default: 829 return false; 830 } 831 return true; 832 } 833 834 int C2Compiler::initial_code_buffer_size(int const_size) { 835 // See Compile::init_scratch_buffer_blob 836 int locs_size = sizeof(relocInfo) * PhaseOutput::MAX_locs_size; 837 int slop = 2 * CodeSection::end_slop(); // space between sections 838 return PhaseOutput::MAX_inst_size + PhaseOutput::MAX_stubs_size + const_size + slop + locs_size; 839 }