diff options
| author | gdkchan <gab.dark.100@gmail.com> | 2023-02-21 19:21:57 -0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-02-21 19:21:57 -0300 |
| commit | c3a5716a95ea93cba9488189fb36d594db5083bc (patch) | |
| tree | de4a15d2b88bf069193c30f09f19bd7ab139135a /Ryujinx.Graphics.Vulkan/TextureView.cs | |
| parent | 1f1e2a7f03aad988cb04045eee18a360a807d13f (diff) | |
Add copy dependency for some incompatible texture formats (#4380)
* Add copy dependency for some incompatible texture formats
* Simplify compatibility check
Diffstat (limited to 'Ryujinx.Graphics.Vulkan/TextureView.cs')
| -rw-r--r-- | Ryujinx.Graphics.Vulkan/TextureView.cs | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/Ryujinx.Graphics.Vulkan/TextureView.cs b/Ryujinx.Graphics.Vulkan/TextureView.cs index aa050c01..264ecf5d 100644 --- a/Ryujinx.Graphics.Vulkan/TextureView.cs +++ b/Ryujinx.Graphics.Vulkan/TextureView.cs @@ -199,6 +199,12 @@ namespace Ryujinx.Graphics.Vulkan int layers = Math.Min(Info.GetLayers(), dst.Info.GetLayers() - firstLayer); _gd.HelperShader.CopyNonMSToMS(_gd, cbs, src, dst, 0, firstLayer, layers); } + else if (dst.Info.BytesPerPixel != Info.BytesPerPixel) + { + int layers = Math.Min(Info.GetLayers(), dst.Info.GetLayers() - firstLayer); + int levels = Math.Min(Info.Levels, dst.Info.Levels - firstLevel); + _gd.HelperShader.CopyIncompatibleFormats(_gd, cbs, src, dst, 0, firstLayer, 0, firstLevel, layers, levels); + } else { TextureCopy.Copy( @@ -244,6 +250,10 @@ namespace Ryujinx.Graphics.Vulkan { _gd.HelperShader.CopyNonMSToMS(_gd, cbs, src, dst, srcLayer, dstLayer, 1); } + else if (dst.Info.BytesPerPixel != Info.BytesPerPixel) + { + _gd.HelperShader.CopyIncompatibleFormats(_gd, cbs, src, dst, srcLayer, dstLayer, srcLevel, dstLevel, 1, 1); + } else { TextureCopy.Copy( |
