Merge pull request #9851 from JosJuice/jitarm64-mfcr

JitArm64: Handle SO and LT simultaneously in mfcr
This commit is contained in:
Tilka 2021-06-29 02:01:31 +01:00 committed by GitHub
commit 856c82aa24
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -613,6 +613,7 @@ void JitArm64::mfcr(UGeckoInstruction inst)
gpr.BindToRegister(inst.RD, false); gpr.BindToRegister(inst.RD, false);
ARM64Reg WA = gpr.R(inst.RD); ARM64Reg WA = gpr.R(inst.RD);
ARM64Reg WB = gpr.GetReg();
ARM64Reg WC = gpr.GetReg(); ARM64Reg WC = gpr.GetReg();
ARM64Reg XA = EncodeRegTo64(WA); ARM64Reg XA = EncodeRegTo64(WA);
ARM64Reg XC = EncodeRegTo64(WC); ARM64Reg XC = EncodeRegTo64(WC);
@ -622,33 +623,34 @@ void JitArm64::mfcr(UGeckoInstruction inst)
ARM64Reg CR = gpr.CR(i); ARM64Reg CR = gpr.CR(i);
ARM64Reg WCR = EncodeRegTo32(CR); ARM64Reg WCR = EncodeRegTo32(CR);
// SO // SO and LT
static_assert(PowerPC::CR_SO_BIT == 0);
static_assert(PowerPC::CR_LT_BIT == 3);
static_assert(PowerPC::CR_EMU_LT_BIT - PowerPC::CR_EMU_SO_BIT == 3);
UBFX(XC, CR, PowerPC::CR_EMU_SO_BIT, 4);
if (i == 0) if (i == 0)
{ {
UBFX(XA, CR, PowerPC::CR_EMU_SO_BIT, 1); MOVI2R(WB, PowerPC::CR_SO | PowerPC::CR_LT);
AND(WA, WC, WB);
} }
else else
{ {
UBFX(XC, CR, PowerPC::CR_EMU_SO_BIT, 1); AND(WC, WC, WB);
ORR(XA, XC, XA, ArithOption(XA, ShiftType::LSL, 4)); ORR(XA, XC, XA, ArithOption(XA, ShiftType::LSL, 4));
} }
// EQ // EQ
ORR(WC, WA, 32 - 1, 0); // WA | 1<<1 ORR(WC, WA, 32 - PowerPC::CR_EQ_BIT, 0);
CMP(WCR, ARM64Reg::WZR); CMP(WCR, ARM64Reg::WZR);
CSEL(WA, WC, WA, CC_EQ); CSEL(WA, WC, WA, CC_EQ);
// GT // GT
ORR(WC, WA, 32 - 2, 0); // WA | 1<<2 ORR(WC, WA, 32 - PowerPC::CR_GT_BIT, 0);
CMP(CR, ARM64Reg::ZR); CMP(CR, ARM64Reg::ZR);
CSEL(WA, WC, WA, CC_GT); CSEL(WA, WC, WA, CC_GT);
// LT
UBFX(XC, CR, PowerPC::CR_EMU_LT_BIT, 1);
ORR(WA, WA, WC, ArithOption(WC, ShiftType::LSL, 3));
} }
gpr.Unlock(WC); gpr.Unlock(WB, WC);
} }
void JitArm64::mtcrf(UGeckoInstruction inst) void JitArm64::mtcrf(UGeckoInstruction inst)