[ARM] Fix the JITILArm and JITArm dispatchers from comex's recent changes.

This commit is contained in:
Ryan Houdek 2013-10-12 08:30:26 +00:00
parent 0556193442
commit 2f0aca2055
2 changed files with 2 additions and 4 deletions

View File

@ -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

View File

@ -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