diff options
| author | gdkchan <gab.dark.100@gmail.com> | 2023-05-23 05:41:37 -0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-05-23 10:41:37 +0200 |
| commit | 4ca78eded52f21089400cc28351b9353279b8171 (patch) | |
| tree | c8dd4d78ddc3a6b2f1ffa81b0a15ebd13e7d7a99 /src/Ryujinx.Graphics.Vulkan/TextureStorage.cs | |
| parent | 6cb6b15612a20717c0e98045914b535f582cdc33 (diff) | |
Vulkan: Do not set storage flag for multisample textures if not supported (#5060)
Diffstat (limited to 'src/Ryujinx.Graphics.Vulkan/TextureStorage.cs')
| -rw-r--r-- | src/Ryujinx.Graphics.Vulkan/TextureStorage.cs | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/Ryujinx.Graphics.Vulkan/TextureStorage.cs b/src/Ryujinx.Graphics.Vulkan/TextureStorage.cs index 0582e6ca..4edb6f2f 100644 --- a/src/Ryujinx.Graphics.Vulkan/TextureStorage.cs +++ b/src/Ryujinx.Graphics.Vulkan/TextureStorage.cs @@ -80,7 +80,7 @@ namespace Ryujinx.Graphics.Vulkan var sampleCountFlags = ConvertToSampleCountFlags(gd.Capabilities.SupportedSampleCounts, (uint)info.Samples); - var usage = GetImageUsageFromFormat(info.Format); + var usage = GetImageUsage(info.Format, info.Target, gd.Capabilities.SupportsShaderStorageImageMultisample); var flags = ImageCreateFlags.CreateMutableFormatBit; @@ -293,7 +293,7 @@ namespace Ryujinx.Graphics.Vulkan } } - public static ImageUsageFlags GetImageUsageFromFormat(GAL.Format format) + public static ImageUsageFlags GetImageUsage(GAL.Format format, Target target, bool supportsMsStorage) { var usage = DefaultUsageFlags; @@ -306,7 +306,7 @@ namespace Ryujinx.Graphics.Vulkan usage |= ImageUsageFlags.ColorAttachmentBit; } - if (format.IsImageCompatible()) + if (format.IsImageCompatible() && (supportsMsStorage || !target.IsMultisample())) { usage |= ImageUsageFlags.StorageBit; } |
