From dcf57abbc11efbaf3fbcd55432c9429d0be3b8cd Mon Sep 17 00:00:00 2001 From: Pengfei Li Date: Wed, 31 Jul 2019 09:52:28 +0800 Subject: [PATCH] 8228601: AArch64: Fix interpreter code at JVMCI deoptimization entry Reviewed-by: adinn, aph --- .../cpu/aarch64/templateInterpreterGenerator_aarch64.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/hotspot/cpu/aarch64/templateInterpreterGenerator_aarch64.cpp b/src/hotspot/cpu/aarch64/templateInterpreterGenerator_aarch64.cpp index e30b9a70ef2..4c59b197caa 100644 --- a/src/hotspot/cpu/aarch64/templateInterpreterGenerator_aarch64.cpp +++ b/src/hotspot/cpu/aarch64/templateInterpreterGenerator_aarch64.cpp @@ -514,7 +514,7 @@ address TemplateInterpreterGenerator::generate_deopt_entry_for(TosState state, // only occur on method entry so emit it only for vtos with step 0. if ((EnableJVMCI || UseAOT) && state == vtos && step == 0) { Label L; - __ ldr(rscratch1, Address(rthread, Thread::pending_exception_offset())); + __ ldrb(rscratch1, Address(rthread, JavaThread::pending_monitorenter_offset())); __ cbz(rscratch1, L); // Clear flag. __ strb(zr, Address(rthread, JavaThread::pending_monitorenter_offset())); @@ -525,7 +525,7 @@ address TemplateInterpreterGenerator::generate_deopt_entry_for(TosState state, #ifdef ASSERT if (EnableJVMCI) { Label L; - __ ldr(rscratch1, Address(rthread, Thread::pending_exception_offset())); + __ ldrb(rscratch1, Address(rthread, JavaThread::pending_monitorenter_offset())); __ cbz(rscratch1, L); __ stop("unexpected pending monitor in deopt entry"); __ bind(L);