aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2024-09-19 21:23:09 -0300
committerGitHub <noreply@github.com>2024-09-19 21:23:09 -0300
commitd717aef2be6043ef5a5f064e13db444ef873f6bb (patch)
treeecbdf5505c24701d58cb09137e38a666bc7ddca5
parent24ee8c39f1fd8ae2dc2d92cda1cdb41e8af45f0a (diff)
Shader: Assume the only remaining source is the right one when all others are undefined (#7331)1.1.1397
* Shader: Assume the only remaining source is the right one when all other are undefined * Shader cache version bump * Improve comment
-rw-r--r--src/Ryujinx.Graphics.Gpu/Shader/DiskCache/DiskCacheHostStorage.cs2
-rw-r--r--src/Ryujinx.Graphics.Shader/Translation/Optimizations/Utils.cs22
2 files changed, 23 insertions, 1 deletions
diff --git a/src/Ryujinx.Graphics.Gpu/Shader/DiskCache/DiskCacheHostStorage.cs b/src/Ryujinx.Graphics.Gpu/Shader/DiskCache/DiskCacheHostStorage.cs
index e1e696ca..a5c5abd4 100644
--- a/src/Ryujinx.Graphics.Gpu/Shader/DiskCache/DiskCacheHostStorage.cs
+++ b/src/Ryujinx.Graphics.Gpu/Shader/DiskCache/DiskCacheHostStorage.cs
@@ -22,7 +22,7 @@ namespace Ryujinx.Graphics.Gpu.Shader.DiskCache
private const ushort FileFormatVersionMajor = 1;
private const ushort FileFormatVersionMinor = 2;
private const uint FileFormatVersionPacked = ((uint)FileFormatVersionMajor << 16) | FileFormatVersionMinor;
- private const uint CodeGenVersion = 7320;
+ private const uint CodeGenVersion = 7331;
private const string SharedTocFileName = "shared.toc";
private const string SharedDataFileName = "shared.data";
diff --git a/src/Ryujinx.Graphics.Shader/Translation/Optimizations/Utils.cs b/src/Ryujinx.Graphics.Shader/Translation/Optimizations/Utils.cs
index 23180ff8..6ec90fa3 100644
--- a/src/Ryujinx.Graphics.Shader/Translation/Optimizations/Utils.cs
+++ b/src/Ryujinx.Graphics.Shader/Translation/Optimizations/Utils.cs
@@ -138,6 +138,8 @@ namespace Ryujinx.Graphics.Shader.Translation.Optimizations
// Ensure that conditions met for that branch are also met for the current one.
// Prefer the latest sources for the phi node.
+ int undefCount = 0;
+
for (int i = phiNode.SourcesCount - 1; i >= 0; i--)
{
BasicBlock phiBlock = phiNode.GetBlock(i);
@@ -159,6 +161,26 @@ namespace Ryujinx.Graphics.Shader.Translation.Optimizations
return match;
}
}
+ else if (phiSource.Type == OperandType.Undefined)
+ {
+ undefCount++;
+ }
+ }
+
+ // If all sources but one are undefined, we can assume that the one
+ // that is not undefined is the right one.
+
+ if (undefCount == phiNode.SourcesCount - 1)
+ {
+ for (int i = phiNode.SourcesCount - 1; i >= 0; i--)
+ {
+ Operand phiSource = phiNode.GetSource(i);
+
+ if (phiSource.Type != OperandType.Undefined)
+ {
+ return phiSource;
+ }
+ }
}
}