From fc79cb03442ad8c676872d264964c08b3057cbc6 Mon Sep 17 00:00:00 2001 From: zilmar Date: Thu, 26 Dec 2024 09:35:07 +1030 Subject: [PATCH] Core: Add DwordLower for cvt.w --- .../N64System/Recompiler/x86/x86RecompilerOps.cpp | 6 +++--- .../N64System/Recompiler/x86/x86RegInfo.cpp | 1 + .../N64System/Recompiler/x86/x86RegInfo.h | 11 ++++++----- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/Source/Project64-core/N64System/Recompiler/x86/x86RecompilerOps.cpp b/Source/Project64-core/N64System/Recompiler/x86/x86RecompilerOps.cpp index 08ff58400..97c5fc63e 100644 --- a/Source/Project64-core/N64System/Recompiler/x86/x86RecompilerOps.cpp +++ b/Source/Project64-core/N64System/Recompiler/x86/x86RecompilerOps.cpp @@ -8140,12 +8140,12 @@ void CX86RecompilerOps::COP1_D_CMP() // COP1: W functions void CX86RecompilerOps::COP1_W_CVT_S() { - COP1_S_CVT(CRegInfo::RoundDefault, CRegInfo::FPU_Dword, CRegInfo::FPU_Float); + COP1_S_CVT(CRegInfo::RoundDefault, CRegInfo::FPU_DwordLow, CRegInfo::FPU_Float); } void CX86RecompilerOps::COP1_W_CVT_D() { - COP1_S_CVT(CRegInfo::RoundDefault, CRegInfo::FPU_Dword, CRegInfo::FPU_Double); + COP1_S_CVT(CRegInfo::RoundDefault, CRegInfo::FPU_DwordLow, CRegInfo::FPU_Double); } // COP1: L functions @@ -11581,7 +11581,7 @@ void CX86RecompilerOps::COP1_S_CVT(CRegBase::FPU_ROUND RoundMethod, CRegInfo::FP CompileCheckFPUInput(fsRegPointer, FpuOpSize_64bit, (NewFormat == CRegInfo::FPU_Dword || NewFormat == CRegInfo::FPU_Qword)); m_Assembler.fpuLoadQwordFromX86Reg(m_RegWorkingSet.StackTopPos(), fsRegPointer); } - else if (OldFormat == CRegInfo::FPU_Dword) + else if (OldFormat == CRegInfo::FPU_Dword || OldFormat == CRegInfo::FPU_DwordLow) { m_Assembler.fpuLoadIntegerDwordFromX86Reg(m_RegWorkingSet.StackTopPos(), fsRegPointer); } diff --git a/Source/Project64-core/N64System/Recompiler/x86/x86RegInfo.cpp b/Source/Project64-core/N64System/Recompiler/x86/x86RegInfo.cpp index e06e1ed97..e3eb8a83a 100644 --- a/Source/Project64-core/N64System/Recompiler/x86/x86RegInfo.cpp +++ b/Source/Project64-core/N64System/Recompiler/x86/x86RegInfo.cpp @@ -350,6 +350,7 @@ asmjit::x86::Gp CX86RegInfo::FPRValuePointer(int32_t Reg, FPU_STATE Format) case FPU_UnsignedDoubleWord: m_Assembler.MoveVariableToX86reg(TempReg, &g_Reg->m_FPR_UDW[Reg], stdstr_f("m_FPR_UDW[%d]", Reg).c_str()); break; + case FPU_DwordLow: case FPU_FloatLow: m_Assembler.MoveVariableToX86reg(TempReg, &g_Reg->m_FPR_S_L[Reg], stdstr_f("m_FPR_S_L[%d]", Reg).c_str()); break; diff --git a/Source/Project64-core/N64System/Recompiler/x86/x86RegInfo.h b/Source/Project64-core/N64System/Recompiler/x86/x86RegInfo.h index a3353d0d2..cc2ddab02 100644 --- a/Source/Project64-core/N64System/Recompiler/x86/x86RegInfo.h +++ b/Source/Project64-core/N64System/Recompiler/x86/x86RegInfo.h @@ -59,11 +59,12 @@ public: FPU_Any = -1, FPU_Unknown = 0, FPU_Dword = 1, - FPU_Qword = 2, - FPU_Float = 3, - FPU_FloatLow = 4, - FPU_Double = 5, - FPU_UnsignedDoubleWord = 6, + FPU_DwordLow = 2, + FPU_Qword = 3, + FPU_Float = 4, + FPU_FloatLow = 5, + FPU_Double = 6, + FPU_UnsignedDoubleWord = 7, }; CX86RegInfo(CCodeBlock & CodeBlock, CX86Ops & Assembler);