Core: get to COP1_S_ROUND_L and COP1_S_CVT_L to use COP1_S_CVT

This commit is contained in:
zilmar 2024-04-25 20:22:47 +09:30
parent d658477cf4
commit b92e6bd752
1 changed files with 22 additions and 8 deletions

View File

@ -7858,6 +7858,12 @@ void CX86RecompilerOps::COP1_S_MOV()
} }
void CX86RecompilerOps::COP1_S_ROUND_L() void CX86RecompilerOps::COP1_S_ROUND_L()
{
if (FpuExceptionInRecompiler())
{
COP1_S_CVT(CRegInfo::RoundNearest, CRegInfo::FPU_FloatLow, CRegInfo::FPU_Qword);
}
else
{ {
CompileCop1Test(); CompileCop1Test();
if (m_Opcode.fd != m_Opcode.fs || !m_RegWorkingSet.RegInStack(m_Opcode.fd, CRegInfo::FPU_Float)) if (m_Opcode.fd != m_Opcode.fs || !m_RegWorkingSet.RegInStack(m_Opcode.fd, CRegInfo::FPU_Float))
@ -7866,6 +7872,7 @@ void CX86RecompilerOps::COP1_S_ROUND_L()
} }
m_RegWorkingSet.ChangeFPURegFormat(m_Opcode.fd, CRegInfo::FPU_Float, CRegInfo::FPU_Qword, CRegInfo::RoundNearest); m_RegWorkingSet.ChangeFPURegFormat(m_Opcode.fd, CRegInfo::FPU_Float, CRegInfo::FPU_Qword, CRegInfo::RoundNearest);
} }
}
void CX86RecompilerOps::COP1_S_TRUNC_L() void CX86RecompilerOps::COP1_S_TRUNC_L()
{ {
@ -8000,6 +8007,12 @@ void CX86RecompilerOps::COP1_S_CVT_W()
} }
void CX86RecompilerOps::COP1_S_CVT_L() void CX86RecompilerOps::COP1_S_CVT_L()
{
if (FpuExceptionInRecompiler())
{
COP1_S_CVT(CRegInfo::RoundDefault, CRegInfo::FPU_FloatLow, CRegInfo::FPU_Qword);
}
else
{ {
CompileCop1Test(); CompileCop1Test();
if (m_Opcode.fd != m_Opcode.fs || !m_RegWorkingSet.RegInStack(m_Opcode.fd, CRegInfo::FPU_Float)) if (m_Opcode.fd != m_Opcode.fs || !m_RegWorkingSet.RegInStack(m_Opcode.fd, CRegInfo::FPU_Float))
@ -8008,6 +8021,7 @@ void CX86RecompilerOps::COP1_S_CVT_L()
} }
m_RegWorkingSet.ChangeFPURegFormat(m_Opcode.fd, CRegInfo::FPU_Float, CRegInfo::FPU_Qword, CRegInfo::RoundDefault); m_RegWorkingSet.ChangeFPURegFormat(m_Opcode.fd, CRegInfo::FPU_Float, CRegInfo::FPU_Qword, CRegInfo::RoundDefault);
} }
}
void CX86RecompilerOps::COP1_S_CMP() void CX86RecompilerOps::COP1_S_CMP()
{ {