Merge pull request #11170 from JosJuice/jit64-dispatcher-no-check
Jit64: Add dispatcher_no_timing_check jump target
This commit is contained in:
commit
b7310a180f
|
@ -598,10 +598,6 @@ void Jit64::JustWriteExit(u32 destination, bool bl, u32 after)
|
||||||
|
|
||||||
MOV(32, PPCSTATE(pc), Imm32(destination));
|
MOV(32, PPCSTATE(pc), Imm32(destination));
|
||||||
|
|
||||||
// Do not skip breakpoint check if debugging.
|
|
||||||
const u8* dispatcher =
|
|
||||||
m_enable_debugging ? asm_routines.dispatcher : asm_routines.dispatcher_no_check;
|
|
||||||
|
|
||||||
// Perform downcount flag check, followed by the requested exit
|
// Perform downcount flag check, followed by the requested exit
|
||||||
if (bl)
|
if (bl)
|
||||||
{
|
{
|
||||||
|
@ -613,7 +609,7 @@ void Jit64::JustWriteExit(u32 destination, bool bl, u32 after)
|
||||||
SwitchToNearCode();
|
SwitchToNearCode();
|
||||||
|
|
||||||
linkData.exitPtrs = GetWritableCodePtr();
|
linkData.exitPtrs = GetWritableCodePtr();
|
||||||
CALL(dispatcher);
|
CALL(asm_routines.dispatcher_no_timing_check);
|
||||||
|
|
||||||
SetJumpTarget(after_fixup);
|
SetJumpTarget(after_fixup);
|
||||||
POP(RSCRATCH);
|
POP(RSCRATCH);
|
||||||
|
@ -624,7 +620,7 @@ void Jit64::JustWriteExit(u32 destination, bool bl, u32 after)
|
||||||
J_CC(CC_LE, asm_routines.do_timing);
|
J_CC(CC_LE, asm_routines.do_timing);
|
||||||
|
|
||||||
linkData.exitPtrs = GetWritableCodePtr();
|
linkData.exitPtrs = GetWritableCodePtr();
|
||||||
JMP(dispatcher, true);
|
JMP(asm_routines.dispatcher_no_timing_check, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
b->linkData.push_back(linkData);
|
b->linkData.push_back(linkData);
|
||||||
|
|
|
@ -83,12 +83,14 @@ void Jit64AsmRoutineManager::Generate()
|
||||||
SUB(32, PPCSTATE(downcount), R(RSCRATCH2));
|
SUB(32, PPCSTATE(downcount), R(RSCRATCH2));
|
||||||
|
|
||||||
dispatcher = GetCodePtr();
|
dispatcher = GetCodePtr();
|
||||||
|
|
||||||
// Expected result of SUB(32, PPCSTATE(downcount), Imm32(block_cycles)) is in RFLAGS.
|
// Expected result of SUB(32, PPCSTATE(downcount), Imm32(block_cycles)) is in RFLAGS.
|
||||||
// Branch if downcount is <= 0 (signed).
|
// Branch if downcount is <= 0 (signed).
|
||||||
FixupBranch bail = J_CC(CC_LE, true);
|
FixupBranch bail = J_CC(CC_LE, true);
|
||||||
|
|
||||||
FixupBranch dbg_exit;
|
dispatcher_no_timing_check = GetCodePtr();
|
||||||
|
|
||||||
|
FixupBranch dbg_exit;
|
||||||
if (enable_debugging)
|
if (enable_debugging)
|
||||||
{
|
{
|
||||||
MOV(64, R(RSCRATCH), ImmPtr(CPU::GetStatePtr()));
|
MOV(64, R(RSCRATCH), ImmPtr(CPU::GetStatePtr()));
|
||||||
|
|
|
@ -13,12 +13,9 @@ JitBlockCache::JitBlockCache(JitBase& jit) : JitBaseBlockCache{jit}
|
||||||
|
|
||||||
void JitBlockCache::WriteLinkBlock(const JitBlock::LinkData& source, const JitBlock* dest)
|
void JitBlockCache::WriteLinkBlock(const JitBlock::LinkData& source, const JitBlock* dest)
|
||||||
{
|
{
|
||||||
// Do not skip breakpoint check if debugging.
|
|
||||||
const u8* dispatcher = m_jit.IsDebuggingEnabled() ? m_jit.GetAsmRoutines()->dispatcher :
|
|
||||||
m_jit.GetAsmRoutines()->dispatcher_no_check;
|
|
||||||
|
|
||||||
u8* location = source.exitPtrs;
|
u8* location = source.exitPtrs;
|
||||||
const u8* address = dest ? dest->checkedEntry : dispatcher;
|
const u8* address =
|
||||||
|
dest ? dest->checkedEntry : m_jit.GetAsmRoutines()->dispatcher_no_timing_check;
|
||||||
if (source.call)
|
if (source.call)
|
||||||
{
|
{
|
||||||
Gen::XEmitter emit(location, location + 5);
|
Gen::XEmitter emit(location, location + 5);
|
||||||
|
|
|
@ -84,6 +84,7 @@ void JitArm64::GenerateAsm()
|
||||||
// The result of slice decrementation should be in flags if somebody jumped here
|
// The result of slice decrementation should be in flags if somebody jumped here
|
||||||
FixupBranch bail = B(CC_LE);
|
FixupBranch bail = B(CC_LE);
|
||||||
|
|
||||||
|
dispatcher_no_timing_check = GetCodePtr();
|
||||||
dispatcher_no_check = GetCodePtr();
|
dispatcher_no_check = GetCodePtr();
|
||||||
|
|
||||||
bool assembly_dispatcher = true;
|
bool assembly_dispatcher = true;
|
||||||
|
|
|
@ -17,6 +17,7 @@ struct CommonAsmRoutinesBase
|
||||||
|
|
||||||
const u8* dispatcher_mispredicted_blr;
|
const u8* dispatcher_mispredicted_blr;
|
||||||
const u8* dispatcher;
|
const u8* dispatcher;
|
||||||
|
const u8* dispatcher_no_timing_check;
|
||||||
const u8* dispatcher_no_check;
|
const u8* dispatcher_no_check;
|
||||||
|
|
||||||
const u8* do_timing;
|
const u8* do_timing;
|
||||||
|
|
Loading…
Reference in New Issue