[ARM] Fix the JITILArm and JITArm dispatchers from comex's recent changes.
This commit is contained in:
parent
0556193442
commit
2f0aca2055
|
@ -135,13 +135,12 @@ void JitArmAsmRoutineManager::Generate()
|
||||||
|
|
||||||
LDR(R12, R14, R12); // R12 contains iCache[PC & JIT_ICACHE_MASK] here
|
LDR(R12, R14, R12); // R12 contains iCache[PC & JIT_ICACHE_MASK] here
|
||||||
// R12 Confirmed this is the correct iCache Location loaded.
|
// R12 Confirmed this is the correct iCache Location loaded.
|
||||||
TST(R12, 0xFC); // Test to see if it is a JIT block.
|
TST(R12, 0x80); // Test to see if it is a JIT block.
|
||||||
|
|
||||||
SetCC(CC_EQ);
|
SetCC(CC_EQ);
|
||||||
// Success, it is our Jitblock.
|
// Success, it is our Jitblock.
|
||||||
MOVI2R(R14, (u32)jit->GetBlockCache()->GetCodePointers());
|
MOVI2R(R14, (u32)jit->GetBlockCache()->GetCodePointers());
|
||||||
// LDR R14 right here to get CodePointers()[0] pointer.
|
// LDR R14 right here to get CodePointers()[0] pointer.
|
||||||
REV(R12, R12); // Reversing this gives us our JITblock.
|
|
||||||
LSL(R12, R12, 2); // Multiply by four because address locations are u32 in size
|
LSL(R12, R12, 2); // Multiply by four because address locations are u32 in size
|
||||||
LDR(R14, R14, R12); // Load the block address in to R14
|
LDR(R14, R14, R12); // Load the block address in to R14
|
||||||
|
|
||||||
|
|
|
@ -53,13 +53,12 @@ void JitArmILAsmRoutineManager::Generate()
|
||||||
|
|
||||||
LDR(R12, R14, R12); // R12 contains iCache[PC & JIT_ICACHE_MASK] here
|
LDR(R12, R14, R12); // R12 contains iCache[PC & JIT_ICACHE_MASK] here
|
||||||
// R12 Confirmed this is the correct iCache Location loaded.
|
// R12 Confirmed this is the correct iCache Location loaded.
|
||||||
TST(R12, 0xFC); // Test to see if it is a JIT block.
|
TST(R12, 0x80); // Test to see if it is a JIT block.
|
||||||
|
|
||||||
SetCC(CC_EQ);
|
SetCC(CC_EQ);
|
||||||
// Success, it is our Jitblock.
|
// Success, it is our Jitblock.
|
||||||
MOVI2R(R14, (u32)jit->GetBlockCache()->GetCodePointers());
|
MOVI2R(R14, (u32)jit->GetBlockCache()->GetCodePointers());
|
||||||
// LDR R14 right here to get CodePointers()[0] pointer.
|
// LDR R14 right here to get CodePointers()[0] pointer.
|
||||||
REV(R12, R12); // Reversing this gives us our JITblock.
|
|
||||||
LSL(R12, R12, 2); // Multiply by four because address locations are u32 in size
|
LSL(R12, R12, 2); // Multiply by four because address locations are u32 in size
|
||||||
LDR(R14, R14, R12); // Load the block address in to R14
|
LDR(R14, R14, R12); // Load the block address in to R14
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue