diff --git a/src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp b/src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp index ebf81d4ba0c..1c2bbc03c62 100644 --- a/src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp +++ b/src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp @@ -291,11 +291,13 @@ void LIR_Assembler::return_op(LIR_Opr result) { } int LIR_Assembler::safepoint_poll(LIR_Opr tmp, CodeEmitInfo* info) { - if (info != NULL) { - add_debug_info_for_branch(info); - } + int offset = __ offset(); - __ read_polling_page(Rtemp, relocInfo::poll_type); + __ get_polling_page(Rtemp); + __ relocate(relocInfo::poll_type); + add_debug_info_for_branch(info); // help pc_desc_at to find correct scope for current PC + __ ldr(Rtemp, Address(Rtemp)); + return offset; } diff --git a/src/hotspot/cpu/arm/macroAssembler_arm.cpp b/src/hotspot/cpu/arm/macroAssembler_arm.cpp index 6418cafd58a..675f2651a01 100644 --- a/src/hotspot/cpu/arm/macroAssembler_arm.cpp +++ b/src/hotspot/cpu/arm/macroAssembler_arm.cpp @@ -2054,6 +2054,7 @@ void MacroAssembler::fast_unlock(Register Roop, Register Rbox, Register Rscratch bind(done); } +#endif // COMPILER2 void MacroAssembler::safepoint_poll(Register tmp1, Label& slow_path) { if (SafepointMechanism::uses_thread_local_poll()) { @@ -2081,5 +2082,3 @@ void MacroAssembler::read_polling_page(Register dest, relocInfo::relocType rtype ldr(dest, Address(dest)); } - -#endif // COMPILER2