mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-23 06:09:50 -06:00
JitArm64: Use ADDI2R for psq_lXX/psq_stXX immediate offsets
This simplifies the source code, and slightly improves the emitted code in some cases.
This commit is contained in:
@ -58,10 +58,8 @@ void JitArm64::psq_lXX(UGeckoInstruction inst)
|
|||||||
{
|
{
|
||||||
if (indexed)
|
if (indexed)
|
||||||
ADD(addr_reg, gpr.R(inst.RA), gpr.R(inst.RB));
|
ADD(addr_reg, gpr.R(inst.RA), gpr.R(inst.RB));
|
||||||
else if (offset >= 0)
|
|
||||||
ADD(addr_reg, gpr.R(inst.RA), offset);
|
|
||||||
else
|
else
|
||||||
SUB(addr_reg, gpr.R(inst.RA), std::abs(offset));
|
ADDI2R(addr_reg, gpr.R(inst.RA), offset, addr_reg);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -217,10 +215,8 @@ void JitArm64::psq_stXX(UGeckoInstruction inst)
|
|||||||
{
|
{
|
||||||
if (indexed)
|
if (indexed)
|
||||||
ADD(addr_reg, gpr.R(inst.RA), gpr.R(inst.RB));
|
ADD(addr_reg, gpr.R(inst.RA), gpr.R(inst.RB));
|
||||||
else if (offset >= 0)
|
|
||||||
ADD(addr_reg, gpr.R(inst.RA), offset);
|
|
||||||
else
|
else
|
||||||
SUB(addr_reg, gpr.R(inst.RA), std::abs(offset));
|
ADDI2R(addr_reg, gpr.R(inst.RA), offset, addr_reg);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user