JitArm64: Improve srawx special case carry calculation

At a first glance it may look like a part of the code I added to
srawx in efeda3b has a bug when a == s. The code actually happens
to work correctly, but in the interest of making the code easier
to reason about, I'd like to change the way it's implemented. This
change should improve the pipelining a little in the a == s case too.
This commit is contained in:
JosJuice 2021-03-14 18:46:00 +01:00
parent 72a6fff36c
commit c0f840525f
1 changed files with 3 additions and 2 deletions

View File

@ -1401,13 +1401,14 @@ void JitArm64::srawx(UGeckoInstruction inst)
{ {
gpr.BindToRegister(a, a == s); gpr.BindToRegister(a, a == s);
ASR(gpr.R(a), gpr.R(s), 31);
if (js.op->wantsCA) if (js.op->wantsCA)
{ {
// Set the carry flag to the sign bit of s
CMN(gpr.R(s), gpr.R(s)); CMN(gpr.R(s), gpr.R(s));
ComputeCarry(); ComputeCarry();
} }
ASR(gpr.R(a), gpr.R(s), 31);
} }
else if (amount == 0) else if (amount == 0)
{ {