From 743de44f0326d87997b82aec0720a367afcbadc6 Mon Sep 17 00:00:00 2001 From: JosJuice Date: Sun, 5 Sep 2021 11:38:39 +0200 Subject: [PATCH 1/2] JitArm64: Move psq_stXX GetCallerSavedUsed calls later This is a proper fix for the issue that 3071a1d was a workaround for. It wasn't some kind of bug in the register cache that had laid dormant, it was a simple mistake made in b24b79e. --- .../PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/Source/Core/Core/PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp b/Source/Core/Core/PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp index 4eb27de32f..f5e3177aac 100644 --- a/Source/Core/Core/PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp +++ b/Source/Core/Core/PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp @@ -168,13 +168,6 @@ void JitArm64::psq_stXX(UGeckoInstruction inst) constexpr ARM64Reg addr_reg = ARM64Reg::W1; constexpr ARM64Reg type_reg = ARM64Reg::W2; - BitSet32 gprs_in_use = gpr.GetCallerSavedUsed(); - BitSet32 fprs_in_use = fpr.GetCallerSavedUsed(); - - // Wipe the registers we are using as temporaries - gprs_in_use &= BitSet32(~7); - fprs_in_use &= BitSet32(~3); - if (inst.RA || update) // Always uses the register on update { if (indexed) @@ -198,6 +191,13 @@ void JitArm64::psq_stXX(UGeckoInstruction inst) MOV(arm_addr, addr_reg); } + BitSet32 gprs_in_use = gpr.GetCallerSavedUsed(); + BitSet32 fprs_in_use = fpr.GetCallerSavedUsed(); + + // Wipe the registers we are using as temporaries + gprs_in_use &= BitSet32(~7); + fprs_in_use &= BitSet32(~3); + if (js.assumeNoPairedQuantize) { u32 flags = BackPatchInfo::FLAG_STORE; From 23f6fdebcbfee44977c8e5ae5a831d069c6d881e Mon Sep 17 00:00:00 2001 From: JosJuice Date: Mon, 30 Aug 2021 17:04:09 +0200 Subject: [PATCH 2/2] Revert "JitArm64: Indexed paired loadstores workaround, attempt 2" This reverts commit 3071a1d13bdb34d6aa63e085556157ff67b5248d. --- .../JitArm64/JitArm64_LoadStorePaired.cpp | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/Source/Core/Core/PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp b/Source/Core/Core/PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp index f5e3177aac..aafda1845b 100644 --- a/Source/Core/Core/PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp +++ b/Source/Core/Core/PowerPC/JitArm64/JitArm64_LoadStorePaired.cpp @@ -39,7 +39,6 @@ void JitArm64::psq_lXX(UGeckoInstruction inst) gpr.Lock(ARM64Reg::W0, ARM64Reg::W1, ARM64Reg::W2, ARM64Reg::W30); fpr.Lock(ARM64Reg::Q0, ARM64Reg::Q1); - const ARM64Reg arm_addr = gpr.R(inst.RA); constexpr ARM64Reg scale_reg = ARM64Reg::W0; constexpr ARM64Reg addr_reg = ARM64Reg::W1; constexpr ARM64Reg type_reg = ARM64Reg::W2; @@ -48,11 +47,11 @@ void JitArm64::psq_lXX(UGeckoInstruction inst) if (inst.RA || update) // Always uses the register on update { if (indexed) - ADD(addr_reg, arm_addr, gpr.R(inst.RB)); + ADD(addr_reg, gpr.R(inst.RA), gpr.R(inst.RB)); else if (offset >= 0) - ADD(addr_reg, arm_addr, offset); + ADD(addr_reg, gpr.R(inst.RA), offset); else - SUB(addr_reg, arm_addr, std::abs(offset)); + SUB(addr_reg, gpr.R(inst.RA), std::abs(offset)); } else { @@ -65,7 +64,7 @@ void JitArm64::psq_lXX(UGeckoInstruction inst) if (update) { gpr.BindToRegister(inst.RA, false); - MOV(arm_addr, addr_reg); + MOV(gpr.R(inst.RA), addr_reg); } if (js.assumeNoPairedQuantize) @@ -163,7 +162,6 @@ void JitArm64::psq_stXX(UGeckoInstruction inst) gpr.Lock(ARM64Reg::W0, ARM64Reg::W1, ARM64Reg::W2, ARM64Reg::W30); - const ARM64Reg arm_addr = gpr.R(inst.RA); constexpr ARM64Reg scale_reg = ARM64Reg::W0; constexpr ARM64Reg addr_reg = ARM64Reg::W1; constexpr ARM64Reg type_reg = ARM64Reg::W2; @@ -171,11 +169,11 @@ void JitArm64::psq_stXX(UGeckoInstruction inst) if (inst.RA || update) // Always uses the register on update { if (indexed) - ADD(addr_reg, arm_addr, gpr.R(inst.RB)); + ADD(addr_reg, gpr.R(inst.RA), gpr.R(inst.RB)); else if (offset >= 0) - ADD(addr_reg, arm_addr, offset); + ADD(addr_reg, gpr.R(inst.RA), offset); else - SUB(addr_reg, arm_addr, std::abs(offset)); + SUB(addr_reg, gpr.R(inst.RA), std::abs(offset)); } else { @@ -188,7 +186,7 @@ void JitArm64::psq_stXX(UGeckoInstruction inst) if (update) { gpr.BindToRegister(inst.RA, false); - MOV(arm_addr, addr_reg); + MOV(gpr.R(inst.RA), addr_reg); } BitSet32 gprs_in_use = gpr.GetCallerSavedUsed();