aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Graphics.Shader/Instructions/InstEmitHelper.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Ryujinx.Graphics.Shader/Instructions/InstEmitHelper.cs')
-rw-r--r--Ryujinx.Graphics.Shader/Instructions/InstEmitHelper.cs7
1 files changed, 6 insertions, 1 deletions
diff --git a/Ryujinx.Graphics.Shader/Instructions/InstEmitHelper.cs b/Ryujinx.Graphics.Shader/Instructions/InstEmitHelper.cs
index 09d90e15..352d16c0 100644
--- a/Ryujinx.Graphics.Shader/Instructions/InstEmitHelper.cs
+++ b/Ryujinx.Graphics.Shader/Instructions/InstEmitHelper.cs
@@ -173,7 +173,7 @@ namespace Ryujinx.Graphics.Shader.Instructions
return FPAbsNeg(context, operands, absoluteA, negateA);
}
- public static Operand[] GetHalfSrcB(EmitterContext context)
+ public static Operand[] GetHalfSrcB(EmitterContext context, bool isMul = false)
{
OpCode op = context.CurrOp;
@@ -193,6 +193,11 @@ namespace Ryujinx.Graphics.Shader.Instructions
swizzle = FPHalfSwizzle.FP32;
absoluteB = op.RawOpCode.Extract(54);
+
+ if (!isMul)
+ {
+ negateB = op.RawOpCode.Extract(56);
+ }
}
Operand[] operands = GetHalfUnpacked(context, GetSrcB(context), swizzle);