Revert "JitArm64: Optimize a few tail calls"
This reverts commit 351d095fff
.
In hindsight, my attempted optimization messes with the return
predictor, unlike real tail calls. So I think it does more bad than
good.
This commit is contained in:
parent
000c6c4813
commit
64bc150b8c
|
@ -350,9 +350,8 @@ void JitArm64::IntializeSpeculativeConstants()
|
||||||
STR(IndexType::Unsigned, DISPATCHER_PC, PPC_REG, PPCSTATE_OFF(pc));
|
STR(IndexType::Unsigned, DISPATCHER_PC, PPC_REG, PPCSTATE_OFF(pc));
|
||||||
MOVP2R(ARM64Reg::X8, &JitInterface::CompileExceptionCheck);
|
MOVP2R(ARM64Reg::X8, &JitInterface::CompileExceptionCheck);
|
||||||
MOVI2R(ARM64Reg::W0, static_cast<u32>(JitInterface::ExceptionType::SpeculativeConstants));
|
MOVI2R(ARM64Reg::W0, static_cast<u32>(JitInterface::ExceptionType::SpeculativeConstants));
|
||||||
// Write dispatcher_no_check to LR for tail call
|
BLR(ARM64Reg::X8);
|
||||||
MOVP2R(ARM64Reg::X30, dispatcher_no_check);
|
B(dispatcher_no_check);
|
||||||
BR(ARM64Reg::X8);
|
|
||||||
SwitchToNearCode();
|
SwitchToNearCode();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -844,11 +843,10 @@ bool JitArm64::DoJit(u32 em_address, JitBlock* b, u32 nextPC)
|
||||||
SetJumpTarget(fail);
|
SetJumpTarget(fail);
|
||||||
MOVI2R(DISPATCHER_PC, js.blockStart);
|
MOVI2R(DISPATCHER_PC, js.blockStart);
|
||||||
STR(IndexType::Unsigned, DISPATCHER_PC, PPC_REG, PPCSTATE_OFF(pc));
|
STR(IndexType::Unsigned, DISPATCHER_PC, PPC_REG, PPCSTATE_OFF(pc));
|
||||||
MOVP2R(ARM64Reg::X8, &JitInterface::CompileExceptionCheck);
|
|
||||||
MOVI2R(ARM64Reg::W0, static_cast<u32>(JitInterface::ExceptionType::PairedQuantize));
|
MOVI2R(ARM64Reg::W0, static_cast<u32>(JitInterface::ExceptionType::PairedQuantize));
|
||||||
// Write dispatcher_no_check to LR for tail call
|
MOVP2R(ARM64Reg::X1, &JitInterface::CompileExceptionCheck);
|
||||||
MOVP2R(ARM64Reg::X30, dispatcher_no_check);
|
BLR(ARM64Reg::X1);
|
||||||
BR(ARM64Reg::X8);
|
B(dispatcher_no_check);
|
||||||
SwitchToNearCode();
|
SwitchToNearCode();
|
||||||
SetJumpTarget(no_fail);
|
SetJumpTarget(no_fail);
|
||||||
js.assumeNoPairedQuantize = true;
|
js.assumeNoPairedQuantize = true;
|
||||||
|
|
Loading…
Reference in New Issue