aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Graphics.OpenGL/Image/TextureCopy.cs
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2021-04-12 22:09:42 -0300
committerGitHub <noreply@github.com>2021-04-13 03:09:42 +0200
commit001005b3d56d4984399b4baf8e4b7348ecdb5062 (patch)
tree5d478ed3a4d78a20f471751af046dd345cce1f36 /Ryujinx.Graphics.OpenGL/Image/TextureCopy.cs
parentb662a26c7e2b66d916986b1ed9ffae3b918619d1 (diff)
Fix sub-image copies on intel GPUs (#2198)
Diffstat (limited to 'Ryujinx.Graphics.OpenGL/Image/TextureCopy.cs')
-rw-r--r--Ryujinx.Graphics.OpenGL/Image/TextureCopy.cs54
1 files changed, 38 insertions, 16 deletions
diff --git a/Ryujinx.Graphics.OpenGL/Image/TextureCopy.cs b/Ryujinx.Graphics.OpenGL/Image/TextureCopy.cs
index b27403b2..3c0546d2 100644
--- a/Ryujinx.Graphics.OpenGL/Image/TextureCopy.cs
+++ b/Ryujinx.Graphics.OpenGL/Image/TextureCopy.cs
@@ -205,22 +205,44 @@ namespace Ryujinx.Graphics.OpenGL.Image
int copyWidth = sizeInBlocks ? BitUtils.DivRoundUp(width, blockWidth) : width;
int copyHeight = sizeInBlocks ? BitUtils.DivRoundUp(height, blockHeight) : height;
- GL.CopyImageSubData(
- srcHandle,
- srcInfo.Target.ConvertToImageTarget(),
- srcLevel + level,
- 0,
- 0,
- srcLayer,
- dstHandle,
- dstInfo.Target.ConvertToImageTarget(),
- dstLevel + level,
- 0,
- 0,
- dstLayer,
- copyWidth,
- copyHeight,
- depth);
+ if (HwCapabilities.Vendor == HwCapabilities.GpuVendor.Intel)
+ {
+ GL.CopyImageSubData(
+ src.StorageHandle,
+ srcInfo.Target.ConvertToImageTarget(),
+ src.FirstLevel + srcLevel + level,
+ 0,
+ 0,
+ src.FirstLayer + srcLayer,
+ dst.StorageHandle,
+ dstInfo.Target.ConvertToImageTarget(),
+ dst.FirstLevel + dstLevel + level,
+ 0,
+ 0,
+ dst.FirstLayer + dstLayer,
+ copyWidth,
+ copyHeight,
+ depth);
+ }
+ else
+ {
+ GL.CopyImageSubData(
+ srcHandle,
+ srcInfo.Target.ConvertToImageTarget(),
+ srcLevel + level,
+ 0,
+ 0,
+ srcLayer,
+ dstHandle,
+ dstInfo.Target.ConvertToImageTarget(),
+ dstLevel + level,
+ 0,
+ 0,
+ dstLayer,
+ copyWidth,
+ copyHeight,
+ depth);
+ }
}
width = Math.Max(1, width >> 1);