aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Ryujinx.Graphics.Shader/Instructions/InstEmitFArith.cs8
1 files changed, 6 insertions, 2 deletions
diff --git a/Ryujinx.Graphics.Shader/Instructions/InstEmitFArith.cs b/Ryujinx.Graphics.Shader/Instructions/InstEmitFArith.cs
index 522875e5..1a7d4251 100644
--- a/Ryujinx.Graphics.Shader/Instructions/InstEmitFArith.cs
+++ b/Ryujinx.Graphics.Shader/Instructions/InstEmitFArith.cs
@@ -87,7 +87,9 @@ namespace Ryujinx.Graphics.Shader.Instructions
{
IOpCodeFArith op = (IOpCodeFArith)context.CurrOp;
- bool negateB = !(op is OpCodeFArithImm32) && op.RawOpCode.Extract(48);
+ bool isImm32 = op is OpCodeFArithImm32;
+
+ bool negateB = !isImm32 && op.RawOpCode.Extract(48);
Operand srcA = GetSrcA(context);
@@ -109,7 +111,9 @@ namespace Ryujinx.Graphics.Shader.Instructions
Operand dest = GetDest(context);
- context.Copy(dest, context.FPSaturate(context.FPMultiply(srcA, srcB), op.Saturate));
+ bool saturate = isImm32 ? op.RawOpCode.Extract(55) : op.Saturate;
+
+ context.Copy(dest, context.FPSaturate(context.FPMultiply(srcA, srcB), saturate));
SetFPZnFlags(context, dest, op.SetCondCode);
}