From 6e4852fc789d6a19d9a3fa7bbc143ff16c036768 Mon Sep 17 00:00:00 2001 From: zilmar Date: Fri, 12 Jul 2024 15:02:46 +0930 Subject: [PATCH] RSP: have Compile_LW handle DMEM overflow better --- .../Project64-rsp-core/Recompiler/RspRecompilerOps.cpp | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/Source/Project64-rsp-core/Recompiler/RspRecompilerOps.cpp b/Source/Project64-rsp-core/Recompiler/RspRecompilerOps.cpp index d22a48daf..5a21380f4 100644 --- a/Source/Project64-rsp-core/Recompiler/RspRecompilerOps.cpp +++ b/Source/Project64-rsp-core/Recompiler/RspRecompilerOps.cpp @@ -924,9 +924,9 @@ void Compile_LW(void) { char Address[32]; sprintf(Address, "DMEM + %Xh", Addr - 2); - MoveVariableToX86regHalf(RSPInfo.DMEM + Addr - 2, Address, x86_EAX); + MoveVariableToX86regHalf(RSPInfo.DMEM + ((Addr - 2) & 0xFFF), Address, x86_EAX); sprintf(Address, "DMEM + %Xh", Addr); - MoveVariableToX86regHalf(RSPInfo.DMEM + Addr + 4, Address, x86_ECX); + MoveVariableToX86regHalf(RSPInfo.DMEM + ((Addr + 4) & 0xFFF), Address, x86_ECX); MoveX86regHalfToVariable(x86_EAX, &RSP_GPR[RSPOpC.rt].UHW[1], GPR_Name(RSPOpC.rt)); MoveX86regHalfToVariable(x86_ECX, &RSP_GPR[RSPOpC.rt].UHW[0], GPR_Name(RSPOpC.rt)); @@ -942,8 +942,10 @@ void Compile_LW(void) } MoveVariableToX86reg(&RSP_GPR[RSPOpC.base].UW, GPR_Name(RSPOpC.base), x86_EBX); - if (Offset != 0) AddConstToX86Reg(x86_EBX, Offset); - + if (Offset != 0) + { + AddConstToX86Reg(x86_EBX, Offset); + } AndConstToX86Reg(x86_EBX, 0x0fff); TestConstToX86Reg(3, x86_EBX); JneLabel32("Unaligned", 0);