Mercurial > hg > graal-compiler
diff src/cpu/sparc/vm/templateTable_sparc.cpp @ 3839:3d42f82cd811
7063628: Use cbcond on T4
Summary: Add new short branch instruction to Hotspot sparc assembler.
Reviewed-by: never, twisti, jrose
author | kvn |
---|---|
date | Thu, 21 Jul 2011 11:25:07 -0700 |
parents | ddd894528dbc |
children | fdb992d83a87 |
line wrap: on
line diff
--- a/src/cpu/sparc/vm/templateTable_sparc.cpp Thu Jul 21 08:38:25 2011 -0700 +++ b/src/cpu/sparc/vm/templateTable_sparc.cpp Thu Jul 21 11:25:07 2011 -0700 @@ -159,13 +159,10 @@ if (JvmtiExport::can_post_breakpoint()) { Label fast_patch; __ ldub(at_bcp(0), Rscratch); - __ cmp(Rscratch, Bytecodes::_breakpoint); - __ br(Assembler::notEqual, false, Assembler::pt, fast_patch); - __ delayed()->nop(); // don't bother to hoist the stb here + __ cmp_and_br_short(Rscratch, Bytecodes::_breakpoint, Assembler::notEqual, Assembler::pt, fast_patch); // perform the quickening, slowly, in the bowels of the breakpoint table __ call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::set_original_bytecode_at), Lmethod, Lbcp, Rbyte_code); - __ ba(false, patch_done); - __ delayed()->nop(); + __ ba_short(patch_done); __ bind(fast_patch); } #ifdef ASSERT @@ -281,17 +278,14 @@ // get type from tags __ add(O2, tags_offset, O2); __ ldub(O2, O1, O2); - __ cmp(O2, JVM_CONSTANT_UnresolvedString); // unresolved string? If so, must resolve - __ brx(Assembler::equal, true, Assembler::pt, call_ldc); - __ delayed()->nop(); - - __ cmp(O2, JVM_CONSTANT_UnresolvedClass); // unresolved class? If so, must resolve - __ brx(Assembler::equal, true, Assembler::pt, call_ldc); - __ delayed()->nop(); - - __ cmp(O2, JVM_CONSTANT_UnresolvedClassInError); // unresolved class in error state - __ brx(Assembler::equal, true, Assembler::pn, call_ldc); - __ delayed()->nop(); + // unresolved string? If so, must resolve + __ cmp_and_brx_short(O2, JVM_CONSTANT_UnresolvedString, Assembler::equal, Assembler::pt, call_ldc); + + // unresolved class? If so, must resolve + __ cmp_and_brx_short(O2, JVM_CONSTANT_UnresolvedClass, Assembler::equal, Assembler::pt, call_ldc); + + // unresolved class in error state + __ cmp_and_brx_short(O2, JVM_CONSTANT_UnresolvedClassInError, Assembler::equal, Assembler::pn, call_ldc); __ cmp(O2, JVM_CONSTANT_Class); // need to call vm to get java mirror of the class __ brx(Assembler::notEqual, true, Assembler::pt, notClass); @@ -301,8 +295,7 @@ __ set(wide, O1); call_VM(Otos_i, CAST_FROM_FN_PTR(address, InterpreterRuntime::ldc), O1); __ push(atos); - __ ba(false, exit); - __ delayed()->nop(); + __ ba_short(exit); __ bind(notClass); // __ add(O0, base_offset, O0); @@ -312,8 +305,7 @@ __ delayed()->cmp(O2, JVM_CONSTANT_String); __ ld(O0, O1, Otos_i); __ push(itos); - __ ba(false, exit); - __ delayed()->nop(); + __ ba_short(exit); __ bind(notInt); // __ cmp(O2, JVM_CONSTANT_String); @@ -325,8 +317,7 @@ __ ld_ptr(O0, O1, Otos_i); __ verify_oop(Otos_i); __ push(atos); - __ ba(false, exit); - __ delayed()->nop(); + __ ba_short(exit); __ bind(notString); // __ ldf(FloatRegisterImpl::S, O0, O1, Ftos_f); @@ -365,9 +356,7 @@ __ load_klass(Otos_i, Rcon_klass); AddressLiteral array_klass_addr((address)Universe::systemObjArrayKlassObj_addr()); __ load_contents(array_klass_addr, Rarray_klass); - __ cmp(Rarray_klass, Rcon_klass); - __ brx(Assembler::notEqual, false, Assembler::pt, L_done); - __ delayed()->nop(); + __ cmp_and_brx_short(Rarray_klass, Rcon_klass, Assembler::notEqual, Assembler::pt, L_done); __ ld(Address(Otos_i, arrayOopDesc::length_offset_in_bytes()), Rcon_klass); __ tst(Rcon_klass); __ brx(Assembler::zero, true, Assembler::pt, L_done); @@ -397,9 +386,7 @@ __ sll(O1, LogBytesPerWord, O1); __ add(O0, O1, G3_scratch); - __ cmp(O2, JVM_CONSTANT_Double); - __ brx(Assembler::notEqual, false, Assembler::pt, Long); - __ delayed()->nop(); + __ cmp_and_brx_short(O2, JVM_CONSTANT_Double, Assembler::notEqual, Assembler::pt, Long); // A double can be placed at word-aligned locations in the constant pool. // Check out Conversions.java for an example. // Also constantPoolOopDesc::header_size() is 20, which makes it very difficult @@ -413,8 +400,7 @@ f->successor()); #endif __ push(dtos); - __ ba(false, exit); - __ delayed()->nop(); + __ ba_short(exit); __ bind(Long); #ifdef _LP64 @@ -453,9 +439,7 @@ // last two iloads in a pair. Comparing against fast_iload means that // the next bytecode is neither an iload or a caload, and therefore // an iload pair. - __ cmp(G3_scratch, (int)Bytecodes::_iload); - __ br(Assembler::equal, false, Assembler::pn, done); - __ delayed()->nop(); + __ cmp_and_br_short(G3_scratch, (int)Bytecodes::_iload, Assembler::equal, Assembler::pn, done); __ cmp(G3_scratch, (int)Bytecodes::_fast_iload); __ br(Assembler::equal, false, Assembler::pn, rewrite); @@ -697,9 +681,7 @@ aload(0); // if _getfield then wait with rewrite - __ cmp(G3_scratch, (int)Bytecodes::_getfield); - __ br(Assembler::equal, false, Assembler::pn, done); - __ delayed()->nop(); + __ cmp_and_br_short(G3_scratch, (int)Bytecodes::_getfield, Assembler::equal, Assembler::pn, done); // if _igetfield then rewrite to _fast_iaccess_0 assert(Bytecodes::java_code(Bytecodes::_fast_iaccess_0) == Bytecodes::_aload_0, "adjust fast bytecode def"); @@ -867,8 +849,7 @@ __ index_check_without_pop(O3, O2, UseCompressedOops ? 2 : LogBytesPerWord, G3_scratch, O1); // do array store check - check for NULL value first - __ br_null( Otos_i, false, Assembler::pn, is_null ); - __ delayed()->nop(); + __ br_null_short( Otos_i, Assembler::pn, is_null ); __ load_klass(O3, O4); // get array klass __ load_klass(Otos_i, O5); // get value klass @@ -899,7 +880,7 @@ __ bind(store_ok); do_oop_store(_masm, O1, noreg, arrayOopDesc::base_offset_in_bytes(T_OBJECT), Otos_i, G3_scratch, _bs->kind(), true); - __ ba(false,done); + __ ba(done); __ delayed()->inc(Lesp, 3* Interpreter::stackElementSize); // adj sp (pops array, index and value) __ bind(is_null); @@ -1633,16 +1614,14 @@ if (ProfileInterpreter) { // If no method data exists, go to profile_continue. __ ld_ptr(Lmethod, methodOopDesc::method_data_offset(), G4_scratch); - __ br_null(G4_scratch, false, Assembler::pn, Lno_mdo); - __ delayed()->nop(); + __ br_null_short(G4_scratch, Assembler::pn, Lno_mdo); // Increment backedge counter in the MDO Address mdo_backedge_counter(G4_scratch, in_bytes(methodDataOopDesc::backedge_counter_offset()) + in_bytes(InvocationCounter::counter_offset())); __ increment_mask_and_jump(mdo_backedge_counter, increment, mask, G3_scratch, Lscratch, Assembler::notZero, &Lforward); - __ ba(false, Loverflow); - __ delayed()->nop(); + __ ba_short(Loverflow); } // If there's no MDO, increment counter in methodOop @@ -1658,14 +1637,11 @@ // Was an OSR adapter generated? // O0 = osr nmethod - __ br_null(O0, false, Assembler::pn, Lforward); - __ delayed()->nop(); + __ br_null_short(O0, Assembler::pn, Lforward); // Has the nmethod been invalidated already? __ ld(O0, nmethod::entry_bci_offset(), O2); - __ cmp(O2, InvalidOSREntryBci); - __ br(Assembler::equal, false, Assembler::pn, Lforward); - __ delayed()->nop(); + __ cmp_and_br_short(O2, InvalidOSREntryBci, Assembler::equal, Assembler::pn, Lforward); // migrate the interpreter frame off of the stack @@ -1830,7 +1806,7 @@ __ profile_switch_case(O2, O3, G3_scratch, G4_scratch); __ sll(O2, LogBytesPerInt, O2); __ add(O2, 3 * BytesPerInt, O2); - __ ba(false, continue_execution); + __ ba(continue_execution); __ delayed()->ld(O1, O2, O2); // handle default __ bind(default_case); @@ -1858,7 +1834,7 @@ __ ld(O1, BytesPerInt, O2); __ sll(O2, LogBytesPerInt + 1, O2); // in word-pairs __ add(O1, 2 * BytesPerInt, O3); // set first pair addr - __ ba(false, loop_entry); + __ ba(loop_entry); __ delayed()->add(O3, O2, O2); // counter now points past last pair // table search @@ -1877,8 +1853,7 @@ __ ld(O1, 0, O4); // get default offset if (ProfileInterpreter) { __ profile_switch_default(O3); - __ ba(false, continue_execution); - __ delayed()->nop(); + __ ba_short(continue_execution); } // entry found -> get offset @@ -1944,7 +1919,7 @@ // and start Label entry; - __ ba(false, entry); + __ ba(entry); __ delayed()->ld( Rarray, -BytesPerInt, Rj); // (Rj is already in the native byte-ordering.) @@ -2002,8 +1977,7 @@ // (Rj is already in the native byte-ordering.) if (ProfileInterpreter) { - __ ba(false, continue_execution); - __ delayed()->nop(); + __ ba_short(continue_execution); } __ bind(default_case); // fall through (if not profiling) @@ -2216,9 +2190,7 @@ assert_different_registers(Rcache, index, G1_scratch); AddressLiteral get_field_access_count_addr(JvmtiExport::get_field_access_count_addr()); __ load_contents(get_field_access_count_addr, G1_scratch); - __ tst(G1_scratch); - __ br(Assembler::zero, false, Assembler::pt, Label1); - __ delayed()->nop(); + __ cmp_and_br_short(G1_scratch, 0, Assembler::equal, Assembler::pt, Label1); __ add(Rcache, in_bytes(cp_base_offset), Rcache); @@ -2298,7 +2270,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_agetfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notObj); @@ -2313,7 +2285,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_igetfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notInt); @@ -2329,7 +2301,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_lgetfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notLong); @@ -2344,7 +2316,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_bgetfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notByte); @@ -2359,7 +2331,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_cgetfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notChar); @@ -2374,7 +2346,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_sgetfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notShort); @@ -2390,7 +2362,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_fgetfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notFloat); @@ -2499,9 +2471,7 @@ Label done; AddressLiteral get_field_modification_count_addr(JvmtiExport::get_field_modification_count_addr()); __ load_contents(get_field_modification_count_addr, G4_scratch); - __ tst(G4_scratch); - __ br(Assembler::zero, false, Assembler::pt, done); - __ delayed()->nop(); + __ cmp_and_br_short(G4_scratch, 0, Assembler::equal, Assembler::pt, done); __ pop_ptr(G4_scratch); // copy the object pointer from tos __ verify_oop(G4_scratch); __ push_ptr(G4_scratch); // put the object pointer back on tos @@ -2552,9 +2522,7 @@ assert_different_registers(Rcache, index, G1_scratch); AddressLiteral get_field_modification_count_addr(JvmtiExport::get_field_modification_count_addr()); __ load_contents(get_field_modification_count_addr, G1_scratch); - __ tst(G1_scratch); - __ br(Assembler::zero, false, Assembler::pt, Label1); - __ delayed()->nop(); + __ cmp_and_br_short(G1_scratch, 0, Assembler::zero, Assembler::pt, Label1); // The Rcache and index registers have been already set. // This allows to eliminate this call but the Rcache and index @@ -2584,8 +2552,7 @@ __ br(Assembler::equal, false, Assembler::pt, two_word); __ delayed()->nop(); __ inc(G4_scratch, Interpreter::expr_offset_in_bytes(1)); - __ br(Assembler::always, false, Assembler::pt, valsizeknown); - __ delayed()->nop(); + __ ba_short(valsizeknown); __ bind(two_word); __ inc(G4_scratch, Interpreter::expr_offset_in_bytes(2)); @@ -2636,9 +2603,7 @@ __ and3(Rflags, Lscratch, Lscratch); if (__ membar_has_effect(read_bits)) { - __ tst(Lscratch); - __ br(Assembler::zero, false, Assembler::pt, notVolatile); - __ delayed()->nop(); + __ cmp_and_br_short(Lscratch, 0, Assembler::equal, Assembler::pt, notVolatile); volatile_barrier(read_bits); __ bind(notVolatile); } @@ -2663,7 +2628,7 @@ do_oop_store(_masm, Rclass, Roffset, 0, Otos_i, G1_scratch, _bs->kind(), false); - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notObj); @@ -2675,7 +2640,7 @@ // itos __ pop_i(); __ st(Otos_i, Rclass, Roffset); - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notInt); @@ -2691,7 +2656,7 @@ pop_and_check_object(Rclass); __ st(Otos_i, Rclass, Roffset); patch_bytecode(Bytecodes::_fast_iputfield, G3_scratch, G4_scratch); - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notInt); @@ -2707,7 +2672,7 @@ do_oop_store(_masm, Rclass, Roffset, 0, Otos_i, G1_scratch, _bs->kind(), false); patch_bytecode(Bytecodes::_fast_aputfield, G3_scratch, G4_scratch); - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notObj); @@ -2724,7 +2689,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_bputfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notByte); @@ -2740,7 +2705,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_lputfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notLong); @@ -2756,7 +2721,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_cputfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notChar); @@ -2771,7 +2736,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_sputfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notShort); @@ -2786,7 +2751,7 @@ if (!is_static) { patch_bytecode(Bytecodes::_fast_fputfield, G3_scratch, G4_scratch); } - __ ba(false, checkVolatile); + __ ba(checkVolatile); __ delayed()->tst(Lscratch); __ bind(notFloat); @@ -2833,9 +2798,7 @@ __ set((1 << ConstantPoolCacheEntry::volatileField), Lscratch); __ and3(Rflags, Lscratch, Lscratch); if (__ membar_has_effect(read_bits)) { - __ tst(Lscratch); - __ br(Assembler::zero, false, Assembler::pt, notVolatile); - __ delayed()->nop(); + __ cmp_and_br_short(Lscratch, 0, Assembler::equal, Assembler::pt, notVolatile); volatile_barrier(read_bits); __ bind(notVolatile); } @@ -2864,9 +2827,7 @@ } if (__ membar_has_effect(write_bits)) { - __ tst(Lscratch); - __ br(Assembler::zero, false, Assembler::pt, exit); - __ delayed()->nop(); + __ cmp_and_br_short(Lscratch, 0, Assembler::equal, Assembler::pt, exit); volatile_barrier(Assembler::StoreLoad); __ bind(exit); } @@ -3226,8 +3187,7 @@ // the VM should throw IncompatibleClassChangeError. linkResolver checks // this too but that's only if the entry isn't already resolved, so we // need to check again. - __ br_notnull( Rtemp, false, Assembler::pt, ok); - __ delayed()->nop(); + __ br_notnull_short( Rtemp, Assembler::pt, ok); call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::throw_IncompatibleClassChangeError)); __ should_not_reach_here(); __ bind(ok); @@ -3251,9 +3211,7 @@ // Check for abstract method error. { Label ok; - __ tst(G5_method); - __ brx(Assembler::notZero, false, Assembler::pt, ok); - __ delayed()->nop(); + __ br_notnull_short(G5_method, Assembler::pt, ok); call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::throw_AbstractMethodError)); __ should_not_reach_here(); __ bind(ok); @@ -3408,17 +3366,14 @@ #else __ srl(RfreeValue, LogHeapWordSize, RfreeValue); #endif - __ cmp(RtlabWasteLimitValue, RfreeValue); - __ brx(Assembler::greaterEqualUnsigned, false, Assembler::pt, slow_case); // tlab waste is small - __ delayed()->nop(); + __ cmp_and_brx_short(RtlabWasteLimitValue, RfreeValue, Assembler::greaterEqualUnsigned, Assembler::pt, slow_case); // tlab waste is small // increment waste limit to prevent getting stuck on this slow path __ add(RtlabWasteLimitValue, ThreadLocalAllocBuffer::refill_waste_limit_increment(), RtlabWasteLimitValue); __ st_ptr(RtlabWasteLimitValue, G2_thread, in_bytes(JavaThread::tlab_refill_waste_limit_offset())); } else { // No allocation in the shared eden. - __ br(Assembler::always, false, Assembler::pt, slow_case); - __ delayed()->nop(); + __ ba_short(slow_case); } } @@ -3440,18 +3395,14 @@ // RnewTopValue contains the top address after the new object // has been allocated. - __ cmp(RnewTopValue, RendValue); - __ brx(Assembler::greaterUnsigned, false, Assembler::pn, slow_case); - __ delayed()->nop(); + __ cmp_and_brx_short(RnewTopValue, RendValue, Assembler::greaterUnsigned, Assembler::pn, slow_case); __ casx_under_lock(RtopAddr, RoldTopValue, RnewTopValue, VM_Version::v9_instructions_work() ? NULL : (address)StubRoutines::Sparc::atomic_memory_operation_lock_addr()); // if someone beat us on the allocation, try again, otherwise continue - __ cmp(RoldTopValue, RnewTopValue); - __ brx(Assembler::notEqual, false, Assembler::pn, retry); - __ delayed()->nop(); + __ cmp_and_brx_short(RoldTopValue, RnewTopValue, Assembler::notEqual, Assembler::pn, retry); // bump total bytes allocated by this thread // RoldTopValue and RtopAddr are dead, so can use G1 and G3 @@ -3474,8 +3425,7 @@ __ br(Assembler::notEqual, false, Assembler::pt, loop); __ delayed()->subcc(Roffset, wordSize, Roffset); } - __ br(Assembler::always, false, Assembler::pt, initialize_header); - __ delayed()->nop(); + __ ba_short(initialize_header); } // slow case @@ -3485,8 +3435,7 @@ call_VM(Otos_i, CAST_FROM_FN_PTR(address, InterpreterRuntime::_new), O1, O2); - __ ba(false, done); - __ delayed()->nop(); + __ ba_short(done); // Initialize the header: mark, klass __ bind(initialize_header); @@ -3550,8 +3499,7 @@ Register RspecifiedKlass = O4; // Check for casting a NULL - __ br_null(Otos_i, false, Assembler::pn, is_null); - __ delayed()->nop(); + __ br_null_short(Otos_i, Assembler::pn, is_null); // Get value klass in RobjKlass __ load_klass(Otos_i, RobjKlass); // get value klass @@ -3571,8 +3519,7 @@ call_VM(RspecifiedKlass, CAST_FROM_FN_PTR(address, InterpreterRuntime::quicken_io_cc) ); __ pop_ptr(Otos_i, G3_scratch); // restore receiver - __ br(Assembler::always, false, Assembler::pt, resolved); - __ delayed()->nop(); + __ ba_short(resolved); // Extract target class from constant pool __ bind(quicked); @@ -3591,8 +3538,7 @@ __ bind(cast_ok); if (ProfileInterpreter) { - __ ba(false, done); - __ delayed()->nop(); + __ ba_short(done); } __ bind(is_null); __ profile_null_seen(G3_scratch); @@ -3608,8 +3554,7 @@ Register RspecifiedKlass = O4; // Check for casting a NULL - __ br_null(Otos_i, false, Assembler::pt, is_null); - __ delayed()->nop(); + __ br_null_short(Otos_i, Assembler::pt, is_null); // Get value klass in RobjKlass __ load_klass(Otos_i, RobjKlass); // get value klass @@ -3629,9 +3574,7 @@ call_VM(RspecifiedKlass, CAST_FROM_FN_PTR(address, InterpreterRuntime::quicken_io_cc) ); __ pop_ptr(Otos_i, G3_scratch); // restore receiver - __ br(Assembler::always, false, Assembler::pt, resolved); - __ delayed()->nop(); - + __ ba_short(resolved); // Extract target class from constant pool __ bind(quicked); @@ -3649,8 +3592,7 @@ __ clr( Otos_i ); if (ProfileInterpreter) { - __ ba(false, done); - __ delayed()->nop(); + __ ba_short(done); } __ bind(is_null); __ profile_null_seen(G3_scratch); @@ -3724,7 +3666,7 @@ { Label entry, loop, exit; __ add( __ top_most_monitor(), O2 ); // last one to check - __ ba( false, entry ); + __ ba( entry ); __ delayed()->mov( Lmonitors, O3 ); // first one to check @@ -3757,8 +3699,7 @@ { Label allocated; // found free slot? - __ br_notnull(O1, false, Assembler::pn, allocated); - __ delayed()->nop(); + __ br_notnull_short(O1, Assembler::pn, allocated); __ add_monitor_to_stack( false, O2, O3 ); __ mov(Lmonitors, O1); @@ -3791,7 +3732,7 @@ { Label entry, loop, found; __ add( __ top_most_monitor(), O2 ); // last one to check - __ ba(false, entry ); + __ ba(entry); // use Lscratch to hold monitor elem to check, start with most recent monitor, // By using a local it survives the call to the C routine. __ delayed()->mov( Lmonitors, Lscratch );