diff options
author | gdkchan <gab.dark.100@gmail.com> | 2022-08-20 16:20:27 -0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-08-20 16:20:27 -0300 |
commit | 88a0e720cbe567aff67b6124aa9e6cfc17599739 (patch) | |
tree | 8ba359b84ae70da47eb17792369760f8f0db94de /Ryujinx.Graphics.Shader/AttributeType.cs | |
parent | 53cc9e0561bcbe7779b12c9e03d93078da2bb2c7 (diff) |
Use RGBA16 vertex format if RGB16 is not supported on Vulkan (#3552)1.1.226
* Use RGBA16 vertex format if RGB16 is not supported on Vulkan
* Catch all shader compilation exceptions
Diffstat (limited to 'Ryujinx.Graphics.Shader/AttributeType.cs')
-rw-r--r-- | Ryujinx.Graphics.Shader/AttributeType.cs | 30 |
1 files changed, 22 insertions, 8 deletions
diff --git a/Ryujinx.Graphics.Shader/AttributeType.cs b/Ryujinx.Graphics.Shader/AttributeType.cs index 466f06cc..1ede1560 100644 --- a/Ryujinx.Graphics.Shader/AttributeType.cs +++ b/Ryujinx.Graphics.Shader/AttributeType.cs @@ -1,9 +1,12 @@ +using Ryujinx.Graphics.Shader.StructuredIr; +using Ryujinx.Graphics.Shader.Translation; using System; namespace Ryujinx.Graphics.Shader { public enum AttributeType : byte { + // Generic types. Float, Sint, Uint @@ -11,24 +14,35 @@ namespace Ryujinx.Graphics.Shader static class AttributeTypeExtensions { - public static string GetScalarType(this AttributeType type) + public static string ToVec4Type(this AttributeType type) { return type switch { - AttributeType.Float => "float", - AttributeType.Sint => "int", - AttributeType.Uint => "uint", + AttributeType.Float => "vec4", + AttributeType.Sint => "ivec4", + AttributeType.Uint => "uvec4", _ => throw new ArgumentException($"Invalid attribute type \"{type}\".") }; } - public static string GetVec4Type(this AttributeType type) + public static VariableType ToVariableType(this AttributeType type) { return type switch { - AttributeType.Float => "vec4", - AttributeType.Sint => "ivec4", - AttributeType.Uint => "uvec4", + AttributeType.Float => VariableType.F32, + AttributeType.Sint => VariableType.S32, + AttributeType.Uint => VariableType.U32, + _ => throw new ArgumentException($"Invalid attribute type \"{type}\".") + }; + } + + public static AggregateType ToAggregateType(this AttributeType type) + { + return type switch + { + AttributeType.Float => AggregateType.FP32, + AttributeType.Sint => AggregateType.S32, + AttributeType.Uint => AggregateType.U32, _ => throw new ArgumentException($"Invalid attribute type \"{type}\".") }; } |