From 974d1395a2ce42ff06169c37c692eadf55c9d6b8 Mon Sep 17 00:00:00 2001 From: Samuel Pitoiset Date: Thu, 29 Feb 2024 14:25:18 +0100 Subject: [PATCH] radv: allow RADV_PERFTEST=shader_object on GFX10/GFX10.3 VK_EXT_shader_object is now supported on all GPUs! It's still not enabled by default because it needs more testing and more fixing (Renoir still hangs for some reasons and Zink/RADV on Polaris10 still has flakes). Signed-off-by: Samuel Pitoiset Part-of: --- docs/envvars.rst | 2 +- src/amd/vulkan/radv_physical_device.c | 5 ++--- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/docs/envvars.rst b/docs/envvars.rst index 264a8ab1e46..aa6828ef8c2 100644 --- a/docs/envvars.rst +++ b/docs/envvars.rst @@ -1366,7 +1366,7 @@ RADV driver environment variables enable optimizations to move more driver internal objects to VRAM. ``shader_object`` enable experimental implementation of VK_EXT_shader_object (GFX6-8, - VEGA10, and GFX11) + VEGA10, and GFX10-GFX11) ``transfer_queue`` enable experimental transfer queue support (GFX9+, not yet spec compliant) ``video_decode`` diff --git a/src/amd/vulkan/radv_physical_device.c b/src/amd/vulkan/radv_physical_device.c index b1af489f202..0e4ccb8b078 100644 --- a/src/amd/vulkan/radv_physical_device.c +++ b/src/amd/vulkan/radv_physical_device.c @@ -99,9 +99,8 @@ static bool radv_shader_object_enabled(const struct radv_physical_device *pdevice) { /* FIXME: Fix GPU hangs on Renoir. */ - return (pdevice->rad_info.gfx_level < GFX9 || pdevice->rad_info.gfx_level == GFX11 || - pdevice->rad_info.family == CHIP_VEGA10) && - !pdevice->use_llvm && pdevice->instance->perftest_flags & RADV_PERFTEST_SHADER_OBJECT; + return (pdevice->rad_info.gfx_level != GFX9 || pdevice->rad_info.family == CHIP_VEGA10) && !pdevice->use_llvm && + pdevice->instance->perftest_flags & RADV_PERFTEST_SHADER_OBJECT; } bool