[vlc-commits] direct3d11: do an extra copy when using AMD RX Vega 56/64 chips

2018-12-03 Thread Steve Lhomme
vlc/vlc-3.0 | branch: master | Steve Lhomme  | Thu Nov 29 
12:29:07 2018 +0100| [476079cf6f34d00ba5403730dcebdf1766dee8b0] | committer: 
Steve Lhomme

direct3d11: do an extra copy when using AMD RX Vega 56/64 chips

They display garbage otherwise

(cherry picked from commit 1882a005d9607bea702a2b4ea8b95c8f467f855a)

> http://git.videolan.org/gitweb.cgi/vlc/vlc-3.0.git/?a=commit;h=476079cf6f34d00ba5403730dcebdf1766dee8b0
---

 modules/video_output/win32/direct3d11.c | 26 +-
 1 file changed, 25 insertions(+), 1 deletion(-)

diff --git a/modules/video_output/win32/direct3d11.c 
b/modules/video_output/win32/direct3d11.c
index 32d06caa00..2bd2523897 100644
--- a/modules/video_output/win32/direct3d11.c
+++ b/modules/video_output/win32/direct3d11.c
@@ -1481,6 +1481,29 @@ static bool CanUseTextureArray(vout_display_t *vd)
 #endif
 }
 
+static bool BogusZeroCopy(vout_display_t *vd)
+{
+IDXGIAdapter *p_adapter = D3D11DeviceAdapter(vd->sys->d3d_dev.d3ddevice);
+if (!p_adapter)
+return false;
+
+DXGI_ADAPTER_DESC adapterDesc;
+if (FAILED(IDXGIAdapter_GetDesc(p_adapter, )))
+return false;
+IDXGIAdapter_Release(p_adapter);
+
+if (adapterDesc.VendorId != GPU_MANUFACTURER_AMD)
+return false;
+
+switch (adapterDesc.DeviceId)
+{
+case 0x687F: // RX Vega 56/64
+return true;
+default:
+return false;
+}
+}
+
 /* TODO : handle errors better
TODO : seperate out into smaller functions like createshaders */
 static int Direct3D11CreateFormatResources(vout_display_t *vd, const 
video_format_t *fmt)
@@ -1488,7 +1511,8 @@ static int Direct3D11CreateFormatResources(vout_display_t 
*vd, const video_forma
 vout_display_sys_t *sys = vd->sys;
 HRESULT hr;
 
-sys->legacy_shader = sys->d3d_dev.feature_level < D3D_FEATURE_LEVEL_10_0 
|| !CanUseTextureArray(vd);
+sys->legacy_shader = sys->d3d_dev.feature_level < D3D_FEATURE_LEVEL_10_0 
|| !CanUseTextureArray(vd) ||
+BogusZeroCopy(vd);
 
 hr = D3D11_CompilePixelShader(vd, >hd3d, sys->legacy_shader, 
>d3d_dev,
   sys->picQuad.formatInfo, >display, 
fmt->transfer, fmt->primaries,

___
vlc-commits mailing list
vlc-commits@videolan.org
https://mailman.videolan.org/listinfo/vlc-commits


[vlc-commits] direct3d11: do an extra copy when using AMD RX Vega 56/64 chips

2018-11-29 Thread Steve Lhomme
vlc | branch: master | Steve Lhomme  | Thu Nov 29 12:29:07 
2018 +0100| [1882a005d9607bea702a2b4ea8b95c8f467f855a] | committer: Steve Lhomme

direct3d11: do an extra copy when using AMD RX Vega 56/64 chips

They display garbage otherwise

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=1882a005d9607bea702a2b4ea8b95c8f467f855a
---

 modules/video_output/win32/direct3d11.c | 26 +-
 1 file changed, 25 insertions(+), 1 deletion(-)

diff --git a/modules/video_output/win32/direct3d11.c 
b/modules/video_output/win32/direct3d11.c
index ad5235a76b..c2d6c7d1ed 100644
--- a/modules/video_output/win32/direct3d11.c
+++ b/modules/video_output/win32/direct3d11.c
@@ -1447,6 +1447,29 @@ static bool CanUseTextureArray(vout_display_t *vd)
 #endif
 }
 
+static bool BogusZeroCopy(vout_display_t *vd)
+{
+IDXGIAdapter *p_adapter = D3D11DeviceAdapter(vd->sys->d3d_dev.d3ddevice);
+if (!p_adapter)
+return false;
+
+DXGI_ADAPTER_DESC adapterDesc;
+if (FAILED(IDXGIAdapter_GetDesc(p_adapter, )))
+return false;
+IDXGIAdapter_Release(p_adapter);
+
+if (adapterDesc.VendorId != GPU_MANUFACTURER_AMD)
+return false;
+
+switch (adapterDesc.DeviceId)
+{
+case 0x687F: // RX Vega 56/64
+return true;
+default:
+return false;
+}
+}
+
 /* TODO : handle errors better
TODO : seperate out into smaller functions like createshaders */
 static int Direct3D11CreateFormatResources(vout_display_t *vd, const 
video_format_t *fmt)
@@ -1454,7 +1477,8 @@ static int Direct3D11CreateFormatResources(vout_display_t 
*vd, const video_forma
 vout_display_sys_t *sys = vd->sys;
 HRESULT hr;
 
-sys->legacy_shader = sys->d3d_dev.feature_level < D3D_FEATURE_LEVEL_10_0 
|| !CanUseTextureArray(vd);
+sys->legacy_shader = sys->d3d_dev.feature_level < D3D_FEATURE_LEVEL_10_0 
|| !CanUseTextureArray(vd) ||
+BogusZeroCopy(vd);
 
 hr = D3D11_CompilePixelShader(vd, >hd3d, sys->legacy_shader, 
>d3d_dev,
   >display, fmt->transfer, fmt->primaries,

___
vlc-commits mailing list
vlc-commits@videolan.org
https://mailman.videolan.org/listinfo/vlc-commits