From 7f8a3541eb4d4d64390c8dd5d3849ea4606c59fb Mon Sep 17 00:00:00 2001 From: gdkchan Date: Sat, 23 Jul 2022 11:53:14 -0300 Subject: Fix decoding of block after shader BRA.CC instructions without predicate (#3472) * Fix decoding of block after BRA.CC instructions without predicate * Shader cache version bump --- Ryujinx.Graphics.Shader/Decoders/Decoder.cs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'Ryujinx.Graphics.Shader/Decoders/Decoder.cs') diff --git a/Ryujinx.Graphics.Shader/Decoders/Decoder.cs b/Ryujinx.Graphics.Shader/Decoders/Decoder.cs index 60ad540c..69f9a520 100644 --- a/Ryujinx.Graphics.Shader/Decoders/Decoder.cs +++ b/Ryujinx.Graphics.Shader/Decoders/Decoder.cs @@ -340,7 +340,7 @@ namespace Ryujinx.Graphics.Shader.Decoders { InstConditional condOp = new InstConditional(op.RawOpCode); - if (op.Name == InstName.Exit && condOp.Ccc != Ccc.T) + if ((op.Name == InstName.Bra || op.Name == InstName.Exit) && condOp.Ccc != Ccc.T) { return false; } @@ -672,6 +672,7 @@ namespace Ryujinx.Graphics.Shader.Decoders // Make sure we found the correct address, // the push and pop instruction types must match, so: // - BRK can only consume addresses pushed by PBK. + // - CONT can only consume addresses pushed by PCNT. // - SYNC can only consume addresses pushed by SSY. if (found) { -- cgit v1.2.3