From f9129c0e08aff295a3718c718840dcc2dd118506 Mon Sep 17 00:00:00 2001 From: Tillmann Karras Date: Fri, 14 Aug 2015 05:51:31 +0200 Subject: [PATCH] Jit64: use BMI1's ANDN for andcx --- .../Core/Core/PowerPC/Jit64/Jit_Integer.cpp | 21 +++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/Source/Core/Core/PowerPC/Jit64/Jit_Integer.cpp b/Source/Core/Core/PowerPC/Jit64/Jit_Integer.cpp index 407a39b8671d..f98afc83f30b 100644 --- a/Source/Core/Core/PowerPC/Jit64/Jit_Integer.cpp +++ b/Source/Core/Core/PowerPC/Jit64/Jit_Integer.cpp @@ -676,7 +676,12 @@ void Jit64::boolX(UGeckoInstruction inst) } else if (inst.SUBOP10 == 60) // andcx { - if (a == b) + if (cpu_info.bBMI1 && (gpr.R(b).IsSimpleReg() || a == s)) + { + gpr.BindToRegister(b, true, false); + ANDN(32, gpr.RX(a), gpr.RX(b), gpr.R(s)); + } + else if (a == b) { NOT(32, gpr.R(a)); AND(32, gpr.R(a), operand); @@ -745,9 +750,17 @@ void Jit64::boolX(UGeckoInstruction inst) } else if (inst.SUBOP10 == 60) // andcx { - MOV(32, gpr.R(a), gpr.R(b)); - NOT(32, gpr.R(a)); - AND(32, gpr.R(a), gpr.R(s)); + if (cpu_info.bBMI1) + { + gpr.BindToRegister(b, true, false); + ANDN(32, gpr.RX(a), gpr.RX(b), gpr.R(s)); + } + else + { + MOV(32, gpr.R(a), gpr.R(b)); + NOT(32, gpr.R(a)); + AND(32, gpr.R(a), gpr.R(s)); + } } else if (inst.SUBOP10 == 444) // orx {