JitArm64: divwx - Conditionally skip temp reg allocation

This commit is contained in:
Bram Speeckaert 2024-05-04 17:26:23 +02:00
parent defe97d9f1
commit 0189692ea3
1 changed files with 8 additions and 6 deletions

View File

@ -1675,7 +1675,8 @@ void JitArm64::divwx(UGeckoInstruction inst)
{ {
const s32 divisor = s32(gpr.GetImm(b)); const s32 divisor = s32(gpr.GetImm(b));
gpr.BindToRegister(d, d == a); const bool allocate_reg = a == d;
gpr.BindToRegister(d, allocate_reg);
// Handle 0, 1, and -1 explicitly // Handle 0, 1, and -1 explicitly
if (divisor == 0) if (divisor == 0)
@ -1712,7 +1713,6 @@ void JitArm64::divwx(UGeckoInstruction inst)
ARM64Reg RA = gpr.R(a); ARM64Reg RA = gpr.R(a);
ARM64Reg RD = gpr.R(d); ARM64Reg RD = gpr.R(d);
const bool allocate_reg = a == d;
ARM64Reg WA = allocate_reg ? gpr.GetReg() : RD; ARM64Reg WA = allocate_reg ? gpr.GetReg() : RD;
TST(RA, RA); TST(RA, RA);
@ -1732,13 +1732,13 @@ void JitArm64::divwx(UGeckoInstruction inst)
// Optimize signed 32-bit integer division by a constant // Optimize signed 32-bit integer division by a constant
SignedMagic m = SignedDivisionConstants(divisor); SignedMagic m = SignedDivisionConstants(divisor);
ARM64Reg WA = gpr.GetReg();
ARM64Reg WB = gpr.GetReg();
ARM64Reg RD = gpr.R(d); ARM64Reg RD = gpr.R(d);
ARM64Reg WA = gpr.GetReg();
ARM64Reg WB = allocate_reg ? gpr.GetReg() : RD;
ARM64Reg XD = EncodeRegTo64(RD);
ARM64Reg XA = EncodeRegTo64(WA); ARM64Reg XA = EncodeRegTo64(WA);
ARM64Reg XB = EncodeRegTo64(WB); ARM64Reg XB = EncodeRegTo64(WB);
ARM64Reg XD = EncodeRegTo64(RD);
SXTW(XA, gpr.R(a)); SXTW(XA, gpr.R(a));
MOVI2R(XB, s64(m.multiplier)); MOVI2R(XB, s64(m.multiplier));
@ -1771,7 +1771,9 @@ void JitArm64::divwx(UGeckoInstruction inst)
ADD(RD, WA, RD); ADD(RD, WA, RD);
} }
gpr.Unlock(WA, WB); gpr.Unlock(WA);
if (allocate_reg)
gpr.Unlock(WB);
} }
if (inst.Rc) if (inst.Rc)