Jit_Integer: subfx

This commit is contained in:
MerryMage 2018-10-15 21:00:58 +01:00
parent 64c29ab942
commit 497ac5789d

View File

@ -944,38 +944,40 @@ void Jit64::subfx(UGeckoInstruction inst)
JITDISABLE(bJITIntegerOff); JITDISABLE(bJITIntegerOff);
int a = inst.RA, b = inst.RB, d = inst.RD; int a = inst.RA, b = inst.RB, d = inst.RD;
if (gpr.R(a).IsImm() && gpr.R(b).IsImm()) if (gpr.IsImm(a) && gpr.IsImm(b))
{ {
s32 i = gpr.R(b).SImm32(), j = gpr.R(a).SImm32(); s32 i = gpr.SImm32(b), j = gpr.SImm32(a);
gpr.SetImmediate32(d, i - j); gpr.SetImmediate32(d, i - j);
if (inst.OE) if (inst.OE)
GenerateConstantOverflow((s64)i - (s64)j); GenerateConstantOverflow((s64)i - (s64)j);
} }
else else
{ {
gpr.Lock(a, b, d); RCOpArg Ra = gpr.Use(a, RCMode::Read);
gpr.BindToRegister(d, (d == a || d == b), true); RCOpArg Rb = gpr.Use(b, RCMode::Read);
RCX64Reg Rd = gpr.Bind(d, RCMode::Write);
RegCache::Realize(Ra, Rb, Rd);
if (d == b) if (d == b)
{ {
SUB(32, gpr.R(d), gpr.R(a)); SUB(32, Rd, Ra);
} }
else if (d == a) else if (d == a)
{ {
MOV(32, R(RSCRATCH), gpr.R(a)); MOV(32, R(RSCRATCH), Ra);
MOV(32, gpr.R(d), gpr.R(b)); MOV(32, Rd, Rb);
SUB(32, gpr.R(d), R(RSCRATCH)); SUB(32, Rd, R(RSCRATCH));
} }
else else
{ {
MOV(32, gpr.R(d), gpr.R(b)); MOV(32, Rd, Rb);
SUB(32, gpr.R(d), gpr.R(a)); SUB(32, Rd, Ra);
} }
if (inst.OE) if (inst.OE)
GenerateOverflow(); GenerateOverflow();
} }
if (inst.Rc) if (inst.Rc)
ComputeRC(gpr.R(d)); ComputeRC(d);
gpr.UnlockAll();
} }
void Jit64::MultiplyImmediate(u32 imm, int a, int d, bool overflow) void Jit64::MultiplyImmediate(u32 imm, int a, int d, bool overflow)