[Project64] Update CArmRecompilerOps::SPECIAL_JALR
This commit is contained in:
parent
740c13ec79
commit
fec180366b
|
@ -2833,25 +2833,21 @@ void CArmRecompilerOps::SPECIAL_JALR()
|
||||||
MoveConstToVariable(m_CompilePC + 8, &_GPR[m_Opcode.rd].UW[0], CRegName::GPR_Lo[m_Opcode.rd]);
|
MoveConstToVariable(m_CompilePC + 8, &_GPR[m_Opcode.rd].UW[0], CRegName::GPR_Lo[m_Opcode.rd]);
|
||||||
if ((m_CompilePC & 0xFFC) == 0xFFC)
|
if ((m_CompilePC & 0xFFC) == 0xFFC)
|
||||||
{
|
{
|
||||||
|
ArmReg TempRegVar = m_RegWorkingSet.Map_TempReg(Arm_Any, -1, false);
|
||||||
|
MoveConstToArmReg(TempRegVar, (uint32_t)&R4300iOp::m_JumpToLocation, "R4300iOp::m_JumpToLocation");
|
||||||
|
|
||||||
ArmReg TempRegRs = Arm_Unknown;
|
ArmReg TempRegRs = Arm_Unknown;
|
||||||
if (IsKnown(m_Opcode.rs) && IsMapped(m_Opcode.rs))
|
if (IsKnown(m_Opcode.rs) && IsMapped(m_Opcode.rs))
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
StoreArmRegToArmRegPointer(GetMipsRegMapLo(m_Opcode.rs), TempRegVar, 0);
|
||||||
}
|
|
||||||
else if (IsKnown(m_Opcode.rs))
|
|
||||||
{
|
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
TempRegRs = m_RegWorkingSet.Map_TempReg(Arm_Any, m_Opcode.rs, false);
|
TempRegRs = m_RegWorkingSet.Map_TempReg(Arm_Any, m_Opcode.rs, false);
|
||||||
}
|
|
||||||
ArmReg TempRegVar = m_RegWorkingSet.Map_TempReg(Arm_Any, -1, false);
|
|
||||||
MoveConstToArmReg(TempRegVar, (uint32_t)&R4300iOp::m_JumpToLocation, "R4300iOp::m_JumpToLocation");
|
|
||||||
StoreArmRegToArmRegPointer(TempRegRs, TempRegVar, 0);
|
StoreArmRegToArmRegPointer(TempRegRs, TempRegVar, 0);
|
||||||
m_RegWorkingSet.SetArmRegProtected(TempRegRs,false);
|
m_RegWorkingSet.SetArmRegProtected(TempRegRs, false);
|
||||||
m_RegWorkingSet.SetArmRegProtected(TempRegVar,false);
|
}
|
||||||
|
m_RegWorkingSet.SetArmRegProtected(TempRegVar, false);
|
||||||
m_RegWorkingSet.WriteBackRegisters();
|
m_RegWorkingSet.WriteBackRegisters();
|
||||||
OverflowDelaySlot(true);
|
OverflowDelaySlot(true);
|
||||||
return;
|
return;
|
||||||
|
@ -2875,19 +2871,8 @@ void CArmRecompilerOps::SPECIAL_JALR()
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
UpdateCounters(m_RegWorkingSet, true, true);
|
UpdateCounters(m_RegWorkingSet, true, true);
|
||||||
ArmReg ArmRegRs = Arm_Unknown;
|
ArmReg ArmRegRs = ArmRegRs = IsKnown(m_Opcode.rs) && IsMapped(m_Opcode.rs) ? GetMipsRegMapLo(m_Opcode.rs) : m_RegWorkingSet.Map_TempReg(Arm_Any, m_Opcode.rs, false);
|
||||||
if (IsKnown(m_Opcode.rs) && IsMapped(m_Opcode.rs))
|
m_RegWorkingSet.SetArmRegProtected(ArmRegRs, true);
|
||||||
{
|
|
||||||
ArmRegRs = GetMipsRegMapLo(m_Opcode.rs);
|
|
||||||
}
|
|
||||||
else if (IsKnown(m_Opcode.rs))
|
|
||||||
{
|
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ArmRegRs = m_RegWorkingSet.Map_TempReg(Arm_Any, m_Opcode.rs, false);
|
|
||||||
}
|
|
||||||
ArmReg TempRegPC = m_RegWorkingSet.Map_TempReg(Arm_Any, -1, false);
|
ArmReg TempRegPC = m_RegWorkingSet.Map_TempReg(Arm_Any, -1, false);
|
||||||
MoveConstToArmReg(TempRegPC, (uint32_t)_PROGRAM_COUNTER, "PROGRAM_COUNTER");
|
MoveConstToArmReg(TempRegPC, (uint32_t)_PROGRAM_COUNTER, "PROGRAM_COUNTER");
|
||||||
StoreArmRegToArmRegPointer(ArmRegRs, TempRegPC, 0);
|
StoreArmRegToArmRegPointer(ArmRegRs, TempRegPC, 0);
|
||||||
|
|
Loading…
Reference in New Issue