PatchEngine: Apply speedhack per PC, not only per block entry.
This makes speedhacks indepdent of block assembly / inlining / conditional continue.
This commit is contained in:
parent
04c3db8bfa
commit
c2822ef7d3
|
@ -668,9 +668,6 @@ const u8* Jit64::DoJit(u32 em_address, PPCAnalyst::CodeBuffer* code_buf, JitBloc
|
||||||
fpr.Start();
|
fpr.Start();
|
||||||
|
|
||||||
js.downcountAmount = 0;
|
js.downcountAmount = 0;
|
||||||
if (!SConfig::GetInstance().bEnableDebugging)
|
|
||||||
js.downcountAmount += PatchEngine::GetSpeedhackCycles(code_block.m_address);
|
|
||||||
|
|
||||||
js.skipInstructions = 0;
|
js.skipInstructions = 0;
|
||||||
js.carryFlagSet = false;
|
js.carryFlagSet = false;
|
||||||
js.carryFlagInverted = false;
|
js.carryFlagInverted = false;
|
||||||
|
@ -728,6 +725,9 @@ const u8* Jit64::DoJit(u32 em_address, PPCAnalyst::CodeBuffer* code_buf, JitBloc
|
||||||
js.revertGprLoad = -1;
|
js.revertGprLoad = -1;
|
||||||
js.revertFprLoad = -1;
|
js.revertFprLoad = -1;
|
||||||
|
|
||||||
|
if (!SConfig::GetInstance().bEnableDebugging)
|
||||||
|
js.downcountAmount += PatchEngine::GetSpeedhackCycles(js.compilerPC);
|
||||||
|
|
||||||
if (i == (code_block.m_num_instructions - 1))
|
if (i == (code_block.m_num_instructions - 1))
|
||||||
{
|
{
|
||||||
if (Profiler::g_ProfileBlocks)
|
if (Profiler::g_ProfileBlocks)
|
||||||
|
|
|
@ -582,8 +582,6 @@ const u8* JitIL::DoJit(u32 em_address, PPCAnalyst::CodeBuffer* code_buf, JitBloc
|
||||||
ibuild.Reset();
|
ibuild.Reset();
|
||||||
|
|
||||||
js.downcountAmount = 0;
|
js.downcountAmount = 0;
|
||||||
if (!SConfig::GetInstance().bEnableDebugging)
|
|
||||||
js.downcountAmount += PatchEngine::GetSpeedhackCycles(code_block.m_address);
|
|
||||||
|
|
||||||
// Translate instructions
|
// Translate instructions
|
||||||
for (u32 i = 0; i < code_block.m_num_instructions; i++)
|
for (u32 i = 0; i < code_block.m_num_instructions; i++)
|
||||||
|
@ -594,6 +592,9 @@ const u8* JitIL::DoJit(u32 em_address, PPCAnalyst::CodeBuffer* code_buf, JitBloc
|
||||||
const GekkoOPInfo* opinfo = GetOpInfo(ops[i].inst);
|
const GekkoOPInfo* opinfo = GetOpInfo(ops[i].inst);
|
||||||
js.downcountAmount += opinfo->numCycles;
|
js.downcountAmount += opinfo->numCycles;
|
||||||
|
|
||||||
|
if (!SConfig::GetInstance().bEnableDebugging)
|
||||||
|
js.downcountAmount += PatchEngine::GetSpeedhackCycles(js.compilerPC);
|
||||||
|
|
||||||
if (i == (code_block.m_num_instructions - 1))
|
if (i == (code_block.m_num_instructions - 1))
|
||||||
js.isLastInstruction = true;
|
js.isLastInstruction = true;
|
||||||
|
|
||||||
|
|
|
@ -481,9 +481,6 @@ const u8* JitArm64::DoJit(u32 em_address, PPCAnalyst::CodeBuffer* code_buf, JitB
|
||||||
gpr.Start(js.gpa);
|
gpr.Start(js.gpa);
|
||||||
fpr.Start(js.fpa);
|
fpr.Start(js.fpa);
|
||||||
|
|
||||||
if (!SConfig::GetInstance().bEnableDebugging)
|
|
||||||
js.downcountAmount += PatchEngine::GetSpeedhackCycles(em_address);
|
|
||||||
|
|
||||||
// Translate instructions
|
// Translate instructions
|
||||||
for (u32 i = 0; i < code_block.m_num_instructions; i++)
|
for (u32 i = 0; i < code_block.m_num_instructions; i++)
|
||||||
{
|
{
|
||||||
|
@ -493,12 +490,10 @@ const u8* JitArm64::DoJit(u32 em_address, PPCAnalyst::CodeBuffer* code_buf, JitB
|
||||||
js.instructionsLeft = (code_block.m_num_instructions - 1) - 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;
|
||||||
|
js.isLastInstruction = i == (code_block.m_num_instructions - 1);
|
||||||
|
|
||||||
if (i == (code_block.m_num_instructions - 1))
|
if (!SConfig::GetInstance().bEnableDebugging)
|
||||||
{
|
js.downcountAmount += PatchEngine::GetSpeedhackCycles(js.compilerPC);
|
||||||
// WARNING - cmp->branch merging will screw this up.
|
|
||||||
js.isLastInstruction = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Gather pipe writes using a non-immediate address are discovered by profiling.
|
// Gather pipe writes using a non-immediate address are discovered by profiling.
|
||||||
bool gatherPipeIntCheck =
|
bool gatherPipeIntCheck =
|
||||||
|
|
Loading…
Reference in New Issue