aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.Graphics.Shader/Instructions/InstEmitMove.cs
diff options
context:
space:
mode:
Diffstat (limited to 'src/Ryujinx.Graphics.Shader/Instructions/InstEmitMove.cs')
-rw-r--r--src/Ryujinx.Graphics.Shader/Instructions/InstEmitMove.cs22
1 files changed, 8 insertions, 14 deletions
diff --git a/src/Ryujinx.Graphics.Shader/Instructions/InstEmitMove.cs b/src/Ryujinx.Graphics.Shader/Instructions/InstEmitMove.cs
index 9992ac37..e12177f7 100644
--- a/src/Ryujinx.Graphics.Shader/Instructions/InstEmitMove.cs
+++ b/src/Ryujinx.Graphics.Shader/Instructions/InstEmitMove.cs
@@ -209,21 +209,15 @@ namespace Ryujinx.Graphics.Shader.Instructions
return context.ICompareNotEqual(context.BitwiseAnd(value, Const(1 << bit)), Const(0));
}
- if (ccpr)
+ int count = ccpr ? RegisterConsts.FlagsCount : RegisterConsts.PredsCount;
+ RegisterType type = ccpr ? RegisterType.Flag : RegisterType.Predicate;
+ int shift = (int)byteSel * 8;
+
+ for (int bit = 0; bit < count; bit++)
{
- // TODO: Support Register to condition code flags copy.
- context.Config.GpuAccessor.Log("R2P.CC not implemented.");
- }
- else
- {
- int shift = (int)byteSel * 8;
-
- for (int bit = 0; bit < RegisterConsts.PredsCount; bit++)
- {
- Operand pred = Register(bit, RegisterType.Predicate);
- Operand res = context.ConditionalSelect(Test(mask, bit), Test(value, bit + shift), pred);
- context.Copy(pred, res);
- }
+ Operand flag = Register(bit, type);
+ Operand res = context.ConditionalSelect(Test(mask, bit), Test(value, bit + shift), flag);
+ context.Copy(flag, res);
}
}