JIT64: use LEA for the "a = b + imm" case of addi
This commit is contained in:
parent
9977da0550
commit
5b77617069
|
@ -208,8 +208,15 @@ void Jit64::regimmop(int d, int a, bool binary, u32 value, Operation doop, void
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
gpr.BindToRegister(d, false);
|
gpr.BindToRegister(d, false);
|
||||||
MOV(32, gpr.R(d), gpr.R(a));
|
if (doop == Add && gpr.R(a).IsSimpleReg() && !carry)
|
||||||
(this->*op)(32, gpr.R(d), Imm32(value)); //m_GPR[d] = m_GPR[_inst.RA] + _inst.SIMM_16;
|
{
|
||||||
|
LEA(32, gpr.RX(d), MDisp(gpr.RX(a), value));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
MOV(32, gpr.R(d), gpr.R(a));
|
||||||
|
(this->*op)(32, gpr.R(d), Imm32(value)); //m_GPR[d] = m_GPR[_inst.RA] + _inst.SIMM_16;
|
||||||
|
}
|
||||||
if (carry)
|
if (carry)
|
||||||
GenerateCarry();
|
GenerateCarry();
|
||||||
if (Rc)
|
if (Rc)
|
||||||
|
|
Loading…
Reference in New Issue