From 91b112b984ec8d460bd15fc64129411ee633d5a5 Mon Sep 17 00:00:00 2001 From: JosJuice Date: Sat, 21 Aug 2021 18:59:55 +0200 Subject: [PATCH] JitArm64: divwx - Optimize division by 2 ...and let's optimize a divisor of 2 ever so slightly for good measure. Most GameCube games seem to hit this on launch. --- .../Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp b/Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp index a6b88a8cb1..f61fbe49a5 100644 --- a/Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp +++ b/Source/Core/Core/PowerPC/JitArm64/JitArm64_Integer.cpp @@ -1394,6 +1394,18 @@ void JitArm64::divwx(UGeckoInstruction inst) gpr.Unlock(WA); } + else if (divisor == 2 || divisor == -2) + { + ARM64Reg RA = gpr.R(a); + ARM64Reg RD = gpr.R(d); + + ADD(RD, RA, RA, ArithOption(RA, ShiftType::LSR, 31)); + + if (divisor < 0) + NEG(RD, RD, ArithOption(RD, ShiftType::ASR, 1)); + else + ASR(RD, RD, 1); + } else if (MathUtil::IsPow2(divisor) || MathUtil::IsPow2(-static_cast(divisor))) { const u32 abs_val = static_cast(std::abs(static_cast(divisor)));