JitArm64: Port some crXXX optimizations from Jit64

This commit is contained in:
JosJuice 2024-05-25 16:23:37 +02:00
parent bbe271eec6
commit 7fddd39d97

View File

@ -591,19 +591,44 @@ void JitArm64::crXXX(UGeckoInstruction inst)
INSTRUCTION_START INSTRUCTION_START
JITDISABLE(bJITSystemRegistersOff); JITDISABLE(bJITSystemRegistersOff);
// Special case: crclr if (inst.CRBA == inst.CRBB)
if (inst.CRBA == inst.CRBB && inst.CRBA == inst.CRBD && inst.SUBOP10 == 193) {
switch (inst.SUBOP10)
{
// crclr
case 129: // crandc: A && ~B => 0
case 193: // crxor: A ^ B => 0
{ {
ClearCRFieldBit(inst.CRBD >> 2, 3 - (inst.CRBD & 3)); ClearCRFieldBit(inst.CRBD >> 2, 3 - (inst.CRBD & 3));
return; return;
} }
// crset
// Special case: crset case 289: // creqv: ~(A ^ B) => 1
if (inst.CRBA == inst.CRBB && inst.CRBA == inst.CRBD && inst.SUBOP10 == 289) case 417: // crorc: A || ~B => 1
{ {
SetCRFieldBit(inst.CRBD >> 2, 3 - (inst.CRBD & 3)); SetCRFieldBit(inst.CRBD >> 2, 3 - (inst.CRBD & 3));
return; return;
} }
case 257: // crand: A && B => A
case 449: // cror: A || B => A
{
auto WA = gpr.GetScopedReg();
ARM64Reg XA = EncodeRegTo64(WA);
GetCRFieldBit(inst.CRBA >> 2, 3 - (inst.CRBA & 3), XA, false);
SetCRFieldBit(inst.CRBD >> 2, 3 - (inst.CRBD & 3), XA);
return;
}
case 33: // crnor: ~(A || B) => ~A
case 225: // crnand: ~(A && B) => ~A
{
auto WA = gpr.GetScopedReg();
ARM64Reg XA = EncodeRegTo64(WA);
GetCRFieldBit(inst.CRBA >> 2, 3 - (inst.CRBA & 3), XA, true);
SetCRFieldBit(inst.CRBD >> 2, 3 - (inst.CRBD & 3), XA);
return;
}
}
}
auto WA = gpr.GetScopedReg(); auto WA = gpr.GetScopedReg();
ARM64Reg XA = EncodeRegTo64(WA); ARM64Reg XA = EncodeRegTo64(WA);