Core: Add CPO_DMF/CPO_DMT to recompiler
This commit is contained in:
parent
761a1ee52a
commit
a8add093d1
|
@ -489,11 +489,21 @@ void CAarch64RecompilerOps::COP0_MF()
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CAarch64RecompilerOps::COP0_DMF()
|
||||||
|
{
|
||||||
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
}
|
||||||
|
|
||||||
void CAarch64RecompilerOps::COP0_MT()
|
void CAarch64RecompilerOps::COP0_MT()
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CAarch64RecompilerOps::COP0_DMT()
|
||||||
|
{
|
||||||
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
}
|
||||||
|
|
||||||
void CAarch64RecompilerOps::COP0_CO_TLBR()
|
void CAarch64RecompilerOps::COP0_CO_TLBR()
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
|
|
@ -123,7 +123,9 @@ public:
|
||||||
|
|
||||||
// COP0 functions
|
// COP0 functions
|
||||||
void COP0_MF();
|
void COP0_MF();
|
||||||
|
void COP0_DMF();
|
||||||
void COP0_MT();
|
void COP0_MT();
|
||||||
|
void COP0_DMT();
|
||||||
|
|
||||||
// COP0 CO functions
|
// COP0 CO functions
|
||||||
void COP0_CO_TLBR();
|
void COP0_CO_TLBR();
|
||||||
|
|
|
@ -4232,6 +4232,11 @@ void CArmRecompilerOps::COP0_MF()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CArmRecompilerOps::COP0_DMF()
|
||||||
|
{
|
||||||
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
}
|
||||||
|
|
||||||
void CArmRecompilerOps::COP0_MT()
|
void CArmRecompilerOps::COP0_MT()
|
||||||
{
|
{
|
||||||
if (m_Opcode.rt != 0)
|
if (m_Opcode.rt != 0)
|
||||||
|
@ -4285,6 +4290,11 @@ void CArmRecompilerOps::COP0_MT()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CArmRecompilerOps::COP0_DMT()
|
||||||
|
{
|
||||||
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
}
|
||||||
|
|
||||||
void CArmRecompilerOps::COP0_CO_TLBR()
|
void CArmRecompilerOps::COP0_CO_TLBR()
|
||||||
{
|
{
|
||||||
if (g_Settings->LoadBool(Game_32Bit))
|
if (g_Settings->LoadBool(Game_32Bit))
|
||||||
|
|
|
@ -130,7 +130,9 @@ public:
|
||||||
|
|
||||||
// COP0 functions
|
// COP0 functions
|
||||||
void COP0_MF();
|
void COP0_MF();
|
||||||
|
void COP0_DMF();
|
||||||
void COP0_MT();
|
void COP0_MT();
|
||||||
|
void COP0_DMT();
|
||||||
|
|
||||||
// COP0 CO functions
|
// COP0 CO functions
|
||||||
void COP0_CO_TLBR();
|
void COP0_CO_TLBR();
|
||||||
|
|
|
@ -676,7 +676,9 @@ bool CCodeBlock::AnalyzeInstruction(uint32_t PC, uint32_t & TargetPC, uint32_t &
|
||||||
switch (Command.rs)
|
switch (Command.rs)
|
||||||
{
|
{
|
||||||
case R4300i_COP0_MT:
|
case R4300i_COP0_MT:
|
||||||
|
case R4300i_COP0_DMT:
|
||||||
case R4300i_COP0_MF:
|
case R4300i_COP0_MF:
|
||||||
|
case R4300i_COP0_DMF:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if ((Command.rs & 0x10) != 0)
|
if ((Command.rs & 0x10) != 0)
|
||||||
|
|
|
@ -479,7 +479,9 @@ bool CCodeSection::GenerateNativeCode(uint32_t Test)
|
||||||
switch (Opcode.rs)
|
switch (Opcode.rs)
|
||||||
{
|
{
|
||||||
case R4300i_COP0_MF: m_RecompilerOps->COP0_MF(); break;
|
case R4300i_COP0_MF: m_RecompilerOps->COP0_MF(); break;
|
||||||
|
case R4300i_COP0_DMF: m_RecompilerOps->COP0_DMF(); break;
|
||||||
case R4300i_COP0_MT: m_RecompilerOps->COP0_MT(); break;
|
case R4300i_COP0_MT: m_RecompilerOps->COP0_MT(); break;
|
||||||
|
case R4300i_COP0_DMT: m_RecompilerOps->COP0_DMT(); break;
|
||||||
default:
|
default:
|
||||||
if ((Opcode.rs & 0x10) != 0)
|
if ((Opcode.rs & 0x10) != 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -488,11 +488,21 @@ void CX64RecompilerOps::COP0_MF()
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CX64RecompilerOps::COP0_DMF()
|
||||||
|
{
|
||||||
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
}
|
||||||
|
|
||||||
void CX64RecompilerOps::COP0_MT()
|
void CX64RecompilerOps::COP0_MT()
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CX64RecompilerOps::COP0_DMT()
|
||||||
|
{
|
||||||
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
}
|
||||||
|
|
||||||
void CX64RecompilerOps::COP0_CO_TLBR()
|
void CX64RecompilerOps::COP0_CO_TLBR()
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
|
|
@ -123,7 +123,9 @@ public:
|
||||||
|
|
||||||
// COP0 functions
|
// COP0 functions
|
||||||
void COP0_MF();
|
void COP0_MF();
|
||||||
|
void COP0_DMF();
|
||||||
void COP0_MT();
|
void COP0_MT();
|
||||||
|
void COP0_DMT();
|
||||||
|
|
||||||
// COP0 CO functions
|
// COP0 CO functions
|
||||||
void COP0_CO_TLBR();
|
void COP0_CO_TLBR();
|
||||||
|
|
|
@ -7197,166 +7197,93 @@ void CX86RecompilerOps::SPECIAL_DSRA32()
|
||||||
// COP0 functions
|
// COP0 functions
|
||||||
void CX86RecompilerOps::COP0_MF()
|
void CX86RecompilerOps::COP0_MF()
|
||||||
{
|
{
|
||||||
switch (m_Opcode.rd)
|
|
||||||
{
|
|
||||||
case 9: // Count
|
|
||||||
UpdateCounters(m_RegWorkingSet, false, true);
|
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
|
||||||
m_Assembler.CallThis((uint32_t)g_SystemTimer, AddressOf(&CSystemTimer::UpdateTimers), "CSystemTimer::UpdateTimers", 4);
|
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
|
||||||
}
|
|
||||||
Map_GPR_32bit(m_Opcode.rt, true, -1);
|
Map_GPR_32bit(m_Opcode.rt, true, -1);
|
||||||
m_Assembler.MoveVariableToX86reg(&_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd], GetMipsRegMapLo(m_Opcode.rt));
|
m_RegWorkingSet.BeforeCallDirect();
|
||||||
|
m_Assembler.PushImm32(m_Opcode.rd);
|
||||||
|
m_Assembler.CallThis((uint32_t)g_Reg, AddressOf(&CRegisters::Cop0_MF), "CRegisters::Cop0_MF", 8);
|
||||||
|
m_Assembler.MoveX86regToVariable(CX86Ops::x86_EAX, &_GPR[m_Opcode.rt].UW[0], CRegName::GPR_Lo[m_Opcode.rt]);
|
||||||
|
m_RegWorkingSet.AfterCallDirect();
|
||||||
|
m_Assembler.MoveVariableToX86reg(&_GPR[m_Opcode.rt].UW[0], CRegName::GPR_Lo[m_Opcode.rt], GetMipsRegMapLo(m_Opcode.rt));
|
||||||
|
}
|
||||||
|
|
||||||
|
void CX86RecompilerOps::COP0_DMF()
|
||||||
|
{
|
||||||
|
Map_GPR_64bit(m_Opcode.rt, -1);
|
||||||
|
m_RegWorkingSet.BeforeCallDirect();
|
||||||
|
m_Assembler.PushImm32(m_Opcode.rd);
|
||||||
|
m_Assembler.CallThis((uint32_t)g_Reg, AddressOf(&CRegisters::Cop0_MF), "CRegisters::Cop0_MF", 8);
|
||||||
|
m_Assembler.MoveX86regToVariable(CX86Ops::x86_EAX, &_GPR[m_Opcode.rt].UW[0], CRegName::GPR_Lo[m_Opcode.rt]);
|
||||||
|
m_Assembler.MoveX86regToVariable(CX86Ops::x86_EDX, &_GPR[m_Opcode.rt].UW[1], CRegName::GPR_Hi[m_Opcode.rt]);
|
||||||
|
m_RegWorkingSet.AfterCallDirect();
|
||||||
|
m_Assembler.MoveVariableToX86reg(&_GPR[m_Opcode.rt].UW[0], CRegName::GPR_Lo[m_Opcode.rt], GetMipsRegMapLo(m_Opcode.rt));
|
||||||
|
m_Assembler.MoveVariableToX86reg(&_GPR[m_Opcode.rt].UW[1], CRegName::GPR_Hi[m_Opcode.rt], GetMipsRegMapHi(m_Opcode.rt));
|
||||||
}
|
}
|
||||||
|
|
||||||
void CX86RecompilerOps::COP0_MT()
|
void CX86RecompilerOps::COP0_MT()
|
||||||
{
|
{
|
||||||
uint8_t * Jump;
|
m_RegWorkingSet.BeforeCallDirect();
|
||||||
|
if (IsConst(m_Opcode.rt))
|
||||||
switch (m_Opcode.rd)
|
|
||||||
{
|
{
|
||||||
case 0: // Index
|
m_Assembler.PushImm32(GetMipsRegLo_S(m_Opcode.rt) >> 31);
|
||||||
case 2: // EntryLo0
|
m_Assembler.PushImm32(GetMipsRegLo(m_Opcode.rt));
|
||||||
case 3: // EntryLo1
|
}
|
||||||
case 4: // Context
|
else if (IsMapped(m_Opcode.rt))
|
||||||
case 5: // PageMask
|
|
||||||
case 10: // Entry Hi
|
|
||||||
case 14: // EPC
|
|
||||||
case 16: // Config
|
|
||||||
case 18: // WatchLo
|
|
||||||
case 19: // WatchHi
|
|
||||||
case 28: // Tag Lo
|
|
||||||
case 29: // Tag Hi
|
|
||||||
case 30: // ErrEPC
|
|
||||||
if (IsConst(m_Opcode.rt))
|
|
||||||
{
|
|
||||||
m_Assembler.MoveConstToVariable(GetMipsRegLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
else if (IsMapped(m_Opcode.rt))
|
|
||||||
{
|
|
||||||
m_Assembler.MoveX86regToVariable(GetMipsRegMapLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_Assembler.MoveX86regToVariable(Map_TempReg(CX86Ops::x86_Unknown, m_Opcode.rt, false, false), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
if (m_Opcode.rd == 4) // Context
|
|
||||||
{
|
|
||||||
m_Assembler.AndConstToVariable(0xFF800000, &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 11: // Compare
|
|
||||||
UpdateCounters(m_RegWorkingSet, false, true);
|
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
|
||||||
m_Assembler.CallThis((uint32_t)g_SystemTimer, AddressOf(&CSystemTimer::UpdateTimers), "CSystemTimer::UpdateTimers", 4);
|
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
|
||||||
if (IsConst(m_Opcode.rt))
|
|
||||||
{
|
|
||||||
m_Assembler.MoveConstToVariable(GetMipsRegLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
else if (IsMapped(m_Opcode.rt))
|
|
||||||
{
|
|
||||||
m_Assembler.MoveX86regToVariable(GetMipsRegMapLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_Assembler.MoveX86regToVariable(Map_TempReg(CX86Ops::x86_Unknown, m_Opcode.rt, false, false), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
m_Assembler.AndConstToVariable((uint32_t)~CAUSE_IP7, &g_Reg->FAKE_CAUSE_REGISTER, "FAKE_CAUSE_REGISTER");
|
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
|
||||||
m_Assembler.CallThis((uint32_t)g_SystemTimer, AddressOf(&CSystemTimer::UpdateCompareTimer), "CSystemTimer::UpdateCompareTimer", 4);
|
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
|
||||||
break;
|
|
||||||
case 9: // Count
|
|
||||||
UpdateCounters(m_RegWorkingSet, false, true);
|
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
|
||||||
m_Assembler.CallThis((uint32_t)g_SystemTimer, AddressOf(&CSystemTimer::UpdateTimers), "CSystemTimer::UpdateTimers", 4);
|
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
|
||||||
if (IsConst(m_Opcode.rt))
|
|
||||||
{
|
|
||||||
m_Assembler.MoveConstToVariable(GetMipsRegLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
else if (IsMapped(m_Opcode.rt))
|
|
||||||
{
|
|
||||||
m_Assembler.MoveX86regToVariable(GetMipsRegMapLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_Assembler.MoveX86regToVariable(Map_TempReg(CX86Ops::x86_Unknown, m_Opcode.rt, false, false), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
|
||||||
m_Assembler.CallThis((uint32_t)g_SystemTimer, AddressOf(&CSystemTimer::UpdateCompareTimer), "CSystemTimer::UpdateCompareTimer", 4);
|
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
|
||||||
break;
|
|
||||||
case 12: // Status
|
|
||||||
{
|
{
|
||||||
CX86Ops::x86Reg OldStatusReg = Map_TempReg(CX86Ops::x86_Unknown, -1, false, false);
|
CX86Ops::x86Reg HiReg = GetMipsRegMapLo(m_Opcode.rt) != CX86Ops::x86_EDX ? CX86Ops::x86_EDX : CX86Ops::x86_EAX;
|
||||||
m_Assembler.MoveVariableToX86reg(&_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd], OldStatusReg);
|
m_Assembler.MoveX86RegToX86Reg(GetMipsRegMapLo(m_Opcode.rt), HiReg);
|
||||||
if (IsConst(m_Opcode.rt))
|
m_Assembler.ShiftRightSignImmed(HiReg, 0x1F);
|
||||||
{
|
m_Assembler.Push(HiReg);
|
||||||
m_Assembler.MoveConstToVariable(GetMipsRegLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
m_Assembler.Push(GetMipsRegMapLo(m_Opcode.rt));
|
||||||
}
|
}
|
||||||
else if (IsMapped(m_Opcode.rt))
|
else
|
||||||
{
|
{
|
||||||
m_Assembler.MoveX86regToVariable(GetMipsRegMapLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
m_Assembler.MoveVariableToX86reg(&_GPR[m_Opcode.rt].UW[0], CRegName::GPR_Lo[m_Opcode.rt], CX86Ops::x86_EAX);
|
||||||
}
|
m_Assembler.MoveX86RegToX86Reg(CX86Ops::x86_EAX, CX86Ops::x86_EDX);
|
||||||
else
|
m_Assembler.ShiftRightSignImmed(CX86Ops::x86_EDX, 0x1F);
|
||||||
{
|
m_Assembler.Push(CX86Ops::x86_EDX);
|
||||||
m_Assembler.MoveX86regToVariable(Map_TempReg(CX86Ops::x86_Unknown, m_Opcode.rt, false, false), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
m_Assembler.Push(CX86Ops::x86_EAX);
|
||||||
}
|
}
|
||||||
m_Assembler.XorVariableToX86reg(&_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd], OldStatusReg);
|
m_Assembler.PushImm32(m_Opcode.rd);
|
||||||
m_Assembler.TestConstToX86Reg(STATUS_FR, OldStatusReg);
|
m_Assembler.CallThis((uint32_t)g_Reg, AddressOf(&CRegisters::Cop0_MT), "CRegisters::Cop0_MT", 16);
|
||||||
m_Assembler.JeLabel8("FpuFlagFine", 0);
|
m_Assembler.MoveX86regToVariable(CX86Ops::x86_EAX, &_GPR[m_Opcode.rt].UW[0], CRegName::GPR_Lo[m_Opcode.rt]);
|
||||||
Jump = *g_RecompPos - 1;
|
m_RegWorkingSet.AfterCallDirect();
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
}
|
||||||
m_Assembler.CallThis((uint32_t)g_Reg, AddressOf(&CRegisters::FixFpuLocations), "CRegisters::FixFpuLocations", 4);
|
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
|
||||||
m_Assembler.SetJump8(Jump, *g_RecompPos);
|
|
||||||
|
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
void CX86RecompilerOps::COP0_DMT()
|
||||||
m_Assembler.CallThis((uint32_t)g_Reg, AddressOf(&CRegisters::CheckInterrupts), "CRegisters::CheckInterrupts", 4);
|
{
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
m_RegWorkingSet.BeforeCallDirect();
|
||||||
break;
|
if (IsConst(m_Opcode.rt))
|
||||||
|
{
|
||||||
|
m_Assembler.PushImm32(Is64Bit(m_Opcode.rt) ? GetMipsRegHi(m_Opcode.rt) : GetMipsRegLo_S(m_Opcode.rt) >> 31);
|
||||||
|
m_Assembler.PushImm32(GetMipsRegLo(m_Opcode.rt));
|
||||||
}
|
}
|
||||||
case 6: // Wired
|
else if (IsMapped(m_Opcode.rt))
|
||||||
UpdateCounters(m_RegWorkingSet, false, true);
|
{
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
if (Is64Bit(m_Opcode.rt))
|
||||||
m_Assembler.CallThis((uint32_t)g_SystemTimer, AddressOf(&CSystemTimer::UpdateTimers), "CSystemTimer::UpdateTimers", 4);
|
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
|
||||||
if (IsConst(m_Opcode.rt))
|
|
||||||
{
|
{
|
||||||
m_Assembler.MoveConstToVariable(GetMipsRegLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
m_Assembler.Push(GetMipsRegMapHi(m_Opcode.rt));
|
||||||
}
|
|
||||||
else if (IsMapped(m_Opcode.rt))
|
|
||||||
{
|
|
||||||
m_Assembler.MoveX86regToVariable(GetMipsRegMapLo(m_Opcode.rt), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_Assembler.MoveX86regToVariable(Map_TempReg(CX86Ops::x86_Unknown, m_Opcode.rt, false, false), &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
CX86Ops::x86Reg HiReg = GetMipsRegMapLo(m_Opcode.rt) != CX86Ops::x86_EDX ? CX86Ops::x86_EDX : CX86Ops::x86_EAX;
|
||||||
|
m_Assembler.MoveX86RegToX86Reg(GetMipsRegMapLo(m_Opcode.rt), HiReg);
|
||||||
|
m_Assembler.ShiftRightSignImmed(HiReg, 0x1F);
|
||||||
|
m_Assembler.Push(HiReg);
|
||||||
}
|
}
|
||||||
break;
|
m_Assembler.Push(GetMipsRegMapLo(m_Opcode.rt));
|
||||||
case 13: // Cause
|
|
||||||
m_Assembler.AndConstToVariable(0xFFFFCFF, &_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
|
||||||
if (IsConst(m_Opcode.rt))
|
|
||||||
{
|
|
||||||
if ((GetMipsRegLo(m_Opcode.rt) & 0x300) != 0 && HaveDebugger())
|
|
||||||
{
|
|
||||||
g_Notify->DisplayError("Set IP0 or IP1");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/*else if (HaveDebugger())
|
|
||||||
{
|
|
||||||
UnknownOpcode();
|
|
||||||
return;
|
|
||||||
}*/
|
|
||||||
m_RegWorkingSet.BeforeCallDirect();
|
|
||||||
m_Assembler.CallThis((uint32_t)g_Reg, AddressOf(&CRegisters::CheckInterrupts), "CRegisters::CheckInterrupts", 4);
|
|
||||||
m_RegWorkingSet.AfterCallDirect();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
UnknownOpcode();
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_Assembler.MoveVariableToX86reg(&_GPR[m_Opcode.rt].UW[0], CRegName::GPR_Lo[m_Opcode.rt], CX86Ops::x86_EAX);
|
||||||
|
m_Assembler.MoveVariableToX86reg(&_GPR[m_Opcode.rt].UW[1], CRegName::GPR_Hi[m_Opcode.rt], CX86Ops::x86_EDX);
|
||||||
|
m_Assembler.Push(CX86Ops::x86_EDX);
|
||||||
|
m_Assembler.Push(CX86Ops::x86_EAX);
|
||||||
|
}
|
||||||
|
m_Assembler.PushImm32(m_Opcode.rd);
|
||||||
|
m_Assembler.CallThis((uint32_t)g_Reg, AddressOf(&CRegisters::Cop0_MT), "CRegisters::Cop0_MT", 16);
|
||||||
|
m_Assembler.MoveX86regToVariable(CX86Ops::x86_EAX, &_GPR[m_Opcode.rt].UW[0], CRegName::GPR_Lo[m_Opcode.rt]);
|
||||||
|
m_Assembler.MoveX86regToVariable(CX86Ops::x86_EDX, &_GPR[m_Opcode.rt].UW[1], CRegName::GPR_Hi[m_Opcode.rt]);
|
||||||
|
m_RegWorkingSet.AfterCallDirect();
|
||||||
}
|
}
|
||||||
|
|
||||||
// COP0 CO functions
|
// COP0 CO functions
|
||||||
|
|
|
@ -130,7 +130,9 @@ public:
|
||||||
|
|
||||||
// COP0 functions
|
// COP0 functions
|
||||||
void COP0_MF();
|
void COP0_MF();
|
||||||
|
void COP0_DMF();
|
||||||
void COP0_MT();
|
void COP0_MT();
|
||||||
|
void COP0_DMT();
|
||||||
|
|
||||||
// COP0 CO functions
|
// COP0 CO functions
|
||||||
void COP0_CO_TLBR();
|
void COP0_CO_TLBR();
|
||||||
|
|
Loading…
Reference in New Issue