Mesa (master): radv: Hash Wave32 settings in shader key.

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Mon Aug 12 13:50:46 UTC 2019


Module: Mesa
Branch: master
Commit: d062bec48dfd2d79d8eab09218fe9e4bd74a5857
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=d062bec48dfd2d79d8eab09218fe9e4bd74a5857

Author: Bas Nieuwenhuizen <bas at basnieuwenhuizen.nl>
Date:   Sun Aug  4 01:34:19 2019 +0200

radv: Hash Wave32 settings in shader key.

Can result in different shaders.

Fixes: 8a86908e9a7 "radv/gfx10: add Wave32 support for vertex, tessellation and geometry shaders"
Reviewed-by: Dave Airlie <airlied at redhat.com>

---

 src/amd/vulkan/radv_pipeline.c | 6 ++++++
 src/amd/vulkan/radv_private.h  | 3 +++
 2 files changed, 9 insertions(+)

diff --git a/src/amd/vulkan/radv_pipeline.c b/src/amd/vulkan/radv_pipeline.c
index 5e1dae86c11..8e56e2cbd79 100644
--- a/src/amd/vulkan/radv_pipeline.c
+++ b/src/amd/vulkan/radv_pipeline.c
@@ -178,6 +178,12 @@ static uint32_t get_hash_flags(struct radv_device *device)
 		hash_flags |= RADV_HASH_SHADER_NO_NGG;
 	if (device->instance->perftest_flags & RADV_PERFTEST_SISCHED)
 		hash_flags |= RADV_HASH_SHADER_SISCHED;
+	if (device->physical_device->cs_wave_size == 32)
+		hash_flags |= RADV_HASH_SHADER_CS_WAVE32;
+	if (device->physical_device->ps_wave_size == 32)
+		hash_flags |= RADV_HASH_SHADER_PS_WAVE32;
+	if (device->physical_device->ge_wave_size == 32)
+		hash_flags |= RADV_HASH_SHADER_GE_WAVE32;
 	return hash_flags;
 }
 
diff --git a/src/amd/vulkan/radv_private.h b/src/amd/vulkan/radv_private.h
index 8f3615f2f1c..7d7704f69aa 100644
--- a/src/amd/vulkan/radv_private.h
+++ b/src/amd/vulkan/radv_private.h
@@ -1423,6 +1423,9 @@ struct radv_shader_module;
 #define RADV_HASH_SHADER_SISCHED             (1 << 1)
 #define RADV_HASH_SHADER_UNSAFE_MATH         (1 << 2)
 #define RADV_HASH_SHADER_NO_NGG              (1 << 3)
+#define RADV_HASH_SHADER_CS_WAVE32           (1 << 4)
+#define RADV_HASH_SHADER_PS_WAVE32           (1 << 5)
+#define RADV_HASH_SHADER_GE_WAVE32           (1 << 6)
 
 void
 radv_hash_shaders(unsigned char *hash,




More information about the mesa-commit mailing list