JitArm64: Clean up LWZ idle skipping.
This commit is contained in:
parent
d2db329a42
commit
782c68cf00
|
@ -467,6 +467,7 @@ const u8* JitArm64::DoJit(u32 em_address, PPCAnalyst::CodeBuffer *code_buf, JitB
|
||||||
js.compilerPC = ops[i].address;
|
js.compilerPC = ops[i].address;
|
||||||
js.op = &ops[i];
|
js.op = &ops[i];
|
||||||
js.instructionNumber = i;
|
js.instructionNumber = i;
|
||||||
|
js.instructionsLeft = (code_block.m_num_instructions - 1) - i;
|
||||||
const GekkoOPInfo *opinfo = ops[i].opinfo;
|
const GekkoOPInfo *opinfo = ops[i].opinfo;
|
||||||
js.downcountAmount += opinfo->numCycles;
|
js.downcountAmount += opinfo->numCycles;
|
||||||
|
|
||||||
|
|
|
@ -446,11 +446,11 @@ void JitArm64::lXX(UGeckoInstruction inst)
|
||||||
|
|
||||||
// LWZ idle skipping
|
// LWZ idle skipping
|
||||||
if (SConfig::GetInstance().bSkipIdle &&
|
if (SConfig::GetInstance().bSkipIdle &&
|
||||||
inst.OPCD == 32 &&
|
inst.OPCD == 32 && MergeAllowedNextInstructions(2) &&
|
||||||
(inst.hex & 0xFFFF0000) == 0x800D0000 &&
|
(inst.hex & 0xFFFF0000) == 0x800D0000 && // lwz r0, XXXX(r13)
|
||||||
(PowerPC::HostRead_U32(js.compilerPC + 4) == 0x28000000 ||
|
(js.op[1].inst.hex == 0x28000000 ||
|
||||||
(SConfig::GetInstance().bWii && PowerPC::HostRead_U32(js.compilerPC + 4) == 0x2C000000)) &&
|
(SConfig::GetInstance().bWii && js.op[1].inst.hex == 0x2C000000)) && // cmpXwi r0,0
|
||||||
PowerPC::HostRead_U32(js.compilerPC + 8) == 0x4182fff8)
|
js.op[2].inst.hex == 0x4182fff8) // beq -8
|
||||||
{
|
{
|
||||||
// if it's still 0, we can wait until the next event
|
// if it's still 0, we can wait until the next event
|
||||||
FixupBranch noIdle = CBNZ(gpr.R(d));
|
FixupBranch noIdle = CBNZ(gpr.R(d));
|
||||||
|
|
Loading…
Reference in New Issue