8341862: PPC64: C1 unwind_handler fails to unlock synchronized methods with LM_MONITOR
Reviewed-by: mdoerr, mbaesken
This commit is contained in:
parent
d4f0ba73f6
commit
ed6809666b
@ -213,7 +213,11 @@ int LIR_Assembler::emit_unwind_handler() {
|
|||||||
if (method()->is_synchronized()) {
|
if (method()->is_synchronized()) {
|
||||||
monitor_address(0, FrameMap::R4_opr);
|
monitor_address(0, FrameMap::R4_opr);
|
||||||
stub = new MonitorExitStub(FrameMap::R4_opr, true, 0);
|
stub = new MonitorExitStub(FrameMap::R4_opr, true, 0);
|
||||||
__ unlock_object(R5, R6, R4, *stub->entry());
|
if (LockingMode == LM_MONITOR) {
|
||||||
|
__ b(*stub->entry());
|
||||||
|
} else {
|
||||||
|
__ unlock_object(R5, R6, R4, *stub->entry());
|
||||||
|
}
|
||||||
__ bind(*stub->continuation());
|
__ bind(*stub->continuation());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,6 +114,8 @@ void C1_MacroAssembler::lock_object(Register Rmark, Register Roop, Register Rbox
|
|||||||
/*check without membar and ldarx first*/true);
|
/*check without membar and ldarx first*/true);
|
||||||
// If compare/exchange succeeded we found an unlocked object and we now have locked it
|
// If compare/exchange succeeded we found an unlocked object and we now have locked it
|
||||||
// hence we are done.
|
// hence we are done.
|
||||||
|
} else {
|
||||||
|
assert(false, "Unhandled LockingMode:%d", LockingMode);
|
||||||
}
|
}
|
||||||
b(done);
|
b(done);
|
||||||
|
|
||||||
@ -168,6 +170,8 @@ void C1_MacroAssembler::unlock_object(Register Rmark, Register Roop, Register Rb
|
|||||||
MacroAssembler::cmpxchgx_hint_release_lock(),
|
MacroAssembler::cmpxchgx_hint_release_lock(),
|
||||||
noreg,
|
noreg,
|
||||||
&slow_int);
|
&slow_int);
|
||||||
|
} else {
|
||||||
|
assert(false, "Unhandled LockingMode:%d", LockingMode);
|
||||||
}
|
}
|
||||||
b(done);
|
b(done);
|
||||||
bind(slow_int);
|
bind(slow_int);
|
||||||
|
Loading…
Reference in New Issue
Block a user