[Android[ void CArmRecompilerOps::SPECIAL_JR()
This commit is contained in:
parent
75fba4be38
commit
8f6ca9c15a
|
@ -2466,17 +2466,23 @@ void CArmRecompilerOps::SPECIAL_JR()
|
||||||
|
|
||||||
if (DelaySlotEffectsCompare(m_CompilePC, m_Opcode.rs, 0))
|
if (DelaySlotEffectsCompare(m_CompilePC, m_Opcode.rs, 0))
|
||||||
{
|
{
|
||||||
if (IsKnown(m_Opcode.rs))
|
ArmReg PCTempReg = m_RegWorkingSet.Map_TempReg(Arm_Any, -1, false);
|
||||||
|
MoveConstToArmReg(PCTempReg, (uint32_t)_PROGRAM_COUNTER, "PROGRAM_COUNTER");
|
||||||
|
if (IsConst(m_Opcode.rs))
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
return;
|
}
|
||||||
|
else if (IsMapped(m_Opcode.rs))
|
||||||
|
{
|
||||||
|
StoreArmRegToArmRegPointer(GetMipsRegMapLo(m_Opcode.rs), PCTempReg, 0);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
MoveVariableToArmReg(&_GPR[m_Opcode.rs].UW[0], CRegName::GPR_Lo[m_Opcode.rs], Arm_R0);
|
ArmReg ValueTempReg = m_RegWorkingSet.Map_TempReg(Arm_Any, m_Opcode.rs, false);
|
||||||
MoveConstToArmReg(Arm_R1, (uint32_t)_PROGRAM_COUNTER, "PROGRAM_COUNTER");
|
StoreArmRegToArmRegPointer(ValueTempReg, PCTempReg, 0);
|
||||||
StoreArmRegToArmRegPointer(Arm_R0, Arm_R1, 0);
|
m_RegWorkingSet.SetArmRegProtected(ValueTempReg,false);
|
||||||
}
|
}
|
||||||
|
m_RegWorkingSet.SetArmRegProtected(PCTempReg,false);
|
||||||
}
|
}
|
||||||
m_NextInstruction = DO_DELAY_SLOT;
|
m_NextInstruction = DO_DELAY_SLOT;
|
||||||
}
|
}
|
||||||
|
@ -2489,17 +2495,23 @@ void CArmRecompilerOps::SPECIAL_JR()
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
UpdateCounters(m_RegWorkingSet, true, true);
|
UpdateCounters(m_RegWorkingSet, true, true);
|
||||||
if (IsKnown(m_Opcode.rs))
|
ArmReg PCTempReg = m_RegWorkingSet.Map_TempReg(Arm_Any, -1, false);
|
||||||
|
MoveConstToArmReg(PCTempReg, (uint32_t)_PROGRAM_COUNTER, "PROGRAM_COUNTER");
|
||||||
|
if (IsConst(m_Opcode.rs))
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
return;
|
}
|
||||||
|
else if (IsMapped(m_Opcode.rs))
|
||||||
|
{
|
||||||
|
StoreArmRegToArmRegPointer(GetMipsRegMapLo(m_Opcode.rs), PCTempReg, 0);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
MoveVariableToArmReg(&_GPR[m_Opcode.rs].UW[0], CRegName::GPR_Lo[m_Opcode.rs], Arm_R0);
|
ArmReg ValueTempReg = m_RegWorkingSet.Map_TempReg(Arm_Any, m_Opcode.rs, false);
|
||||||
MoveConstToArmReg(Arm_R1, (uint32_t)_PROGRAM_COUNTER, "PROGRAM_COUNTER");
|
StoreArmRegToArmRegPointer(ValueTempReg, PCTempReg, 0);
|
||||||
StoreArmRegToArmRegPointer(Arm_R0, Arm_R1, 0);
|
m_RegWorkingSet.SetArmRegProtected(ValueTempReg,false);
|
||||||
}
|
}
|
||||||
|
m_RegWorkingSet.SetArmRegProtected(PCTempReg,false);
|
||||||
CompileExit((uint32_t)-1, (uint32_t)-1, m_RegWorkingSet, CExitInfo::Normal);
|
CompileExit((uint32_t)-1, (uint32_t)-1, m_RegWorkingSet, CExitInfo::Normal);
|
||||||
if (m_Section->m_JumpSection)
|
if (m_Section->m_JumpSection)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue