Jit64: subfic - Optimize constants for d != a

These optimizations were already present, but only when d == a. They
also make sense when this condition does not hold.

- imm == 0
Before:
41 BB 00 00 00 00    mov         r11d,0
45 2B DF             sub         r11d,r15d

After:
45 8B DF             mov         r11d,r15d
41 F7 DB             neg         r11d

- imm == -1
Before:
41 BD FF FF FF FF    mov         r13d,0FFFFFFFFh
44 2B EE             sub         r13d,esi
0F 93 45 68          setae       byte ptr [rbp+68h]

After:
44 8B EE             mov         r13d,esi
41 F7 D5             not         r13d
C6 45 68 01          mov         byte ptr [rbp+68h],1
This commit is contained in:
Sintendo 2021-06-15 18:25:55 +02:00
parent 4c37cc7e5e
commit 18aaf488b0
1 changed files with 24 additions and 21 deletions

View File

@ -898,10 +898,11 @@ void Jit64::subfic(UGeckoInstruction inst)
RCX64Reg Rd = gpr.Bind(d, RCMode::Write); RCX64Reg Rd = gpr.Bind(d, RCMode::Write);
RegCache::Realize(Ra, Rd); RegCache::Realize(Ra, Rd);
if (d == a)
{
if (imm == 0) if (imm == 0)
{ {
if (d != a)
MOV(32, Rd, Ra);
// Flags act exactly like subtracting from 0 // Flags act exactly like subtracting from 0
NEG(32, Rd); NEG(32, Rd);
// Output carry is inverted // Output carry is inverted
@ -909,18 +910,20 @@ void Jit64::subfic(UGeckoInstruction inst)
} }
else if (imm == -1) else if (imm == -1)
{ {
if (d != a)
MOV(32, Rd, Ra);
NOT(32, Rd); NOT(32, Rd);
// CA is always set in this case // CA is always set in this case
FinalizeCarry(true); FinalizeCarry(true);
} }
else else if (d == a)
{ {
NOT(32, Rd); NOT(32, Rd);
ADD(32, Rd, Imm32(imm + 1)); ADD(32, Rd, Imm32(imm + 1));
// Output carry is normal // Output carry is normal
FinalizeCarry(CC_C); FinalizeCarry(CC_C);
} }
}
else else
{ {
MOV(32, Rd, Imm32(imm)); MOV(32, Rd, Imm32(imm));