Jit_LoadStore: Name indexed condition

inst.OPCD == 31 represents an indexed instruction
This commit is contained in:
MerryMage 2018-10-07 20:29:47 +01:00
parent daed09f7f0
commit 8e3846d844

View File

@ -159,6 +159,9 @@ void Jit64::lXXx(UGeckoInstruction inst)
else else
update = ((inst.OPCD & 1) != 0) && inst.SIMM_16 != 0; update = ((inst.OPCD & 1) != 0) && inst.SIMM_16 != 0;
// Determine whether this instruction indexes with inst.RB
const bool indexed = inst.OPCD == 31;
bool storeAddress = false; bool storeAddress = false;
s32 loadOffset = 0; s32 loadOffset = 0;
@ -166,7 +169,7 @@ void Jit64::lXXx(UGeckoInstruction inst)
OpArg opAddress; OpArg opAddress;
if (!update && !a) if (!update && !a)
{ {
if (inst.OPCD == 31) if (indexed)
{ {
if (!gpr.R(b).IsImm()) if (!gpr.R(b).IsImm())
gpr.BindToRegister(b, true, false); gpr.BindToRegister(b, true, false);
@ -183,14 +186,14 @@ void Jit64::lXXx(UGeckoInstruction inst)
} }
else else
{ {
if ((inst.OPCD != 31) && gpr.R(a).IsImm() && !jo.memcheck) if (!indexed && gpr.R(a).IsImm() && !jo.memcheck)
{ {
u32 val = gpr.R(a).Imm32() + inst.SIMM_16; u32 val = gpr.R(a).Imm32() + inst.SIMM_16;
opAddress = Imm32(val); opAddress = Imm32(val);
if (update) if (update)
gpr.SetImmediate32(a, val); gpr.SetImmediate32(a, val);
} }
else if ((inst.OPCD == 31) && gpr.R(a).IsImm() && gpr.R(b).IsImm() && !jo.memcheck) else if (indexed && gpr.R(a).IsImm() && gpr.R(b).IsImm() && !jo.memcheck)
{ {
u32 val = gpr.R(a).Imm32() + gpr.R(b).Imm32(); u32 val = gpr.R(a).Imm32() + gpr.R(b).Imm32();
opAddress = Imm32(val); opAddress = Imm32(val);
@ -200,11 +203,11 @@ void Jit64::lXXx(UGeckoInstruction inst)
else else
{ {
// If we're using reg+reg mode and b is an immediate, pretend we're using constant offset mode // If we're using reg+reg mode and b is an immediate, pretend we're using constant offset mode
bool use_constant_offset = inst.OPCD != 31 || gpr.R(b).IsImm(); bool use_constant_offset = !indexed || gpr.R(b).IsImm();
s32 offset = 0; s32 offset = 0;
if (use_constant_offset) if (use_constant_offset)
offset = inst.OPCD == 31 ? gpr.R(b).SImm32() : (s32)inst.SIMM_16; offset = indexed ? gpr.R(b).SImm32() : (s32)inst.SIMM_16;
// Depending on whether we have an immediate and/or update, find the optimum way to calculate // Depending on whether we have an immediate and/or update, find the optimum way to calculate
// the load address. // the load address.
if ((update || use_constant_offset) && !jo.memcheck) if ((update || use_constant_offset) && !jo.memcheck)