From 6384ea97f1ac73cb1ac3d03eec69144d1d6d6039 Mon Sep 17 00:00:00 2001 From: JosJuice Date: Wed, 25 Dec 2024 15:15:24 +0100 Subject: [PATCH] JitArm64: Handle rlwinmx with zero mask No games seem to use this, so this isn't useful as a performance optimization, but it's required for correctness because the (sh == 0) case of our implementation doesn't handle zero masks. --- Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp b/Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp index 76f771abe5..727d06c012 100644 --- a/Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp +++ b/Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp @@ -765,6 +765,14 @@ void JitArm64::rlwinmx_internal(UGeckoInstruction inst, u32 sh) return; } + if (mask == 0) + { + gpr.SetImmediate(a, 0); + if (inst.Rc) + ComputeRC0(0); + return; + } + gpr.BindToRegister(a, a == s); if (sh == 0 && mask == 0xFFFFFFFF)