Mesa (master): radv/gfx10: add radv_device::use_ngg

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Wed Oct 2 16:10:35 UTC 2019


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

Author: Samuel Pitoiset <samuel.pitoiset at gmail.com>
Date:   Wed Sep 18 09:01:38 2019 +0200

radv/gfx10: add radv_device::use_ngg

Trivial.

Signed-off-by: Samuel Pitoiset <samuel.pitoiset at gmail.com>
Reviewed-by: Bas Nieuwenhuizen <bas at basnieuwenhuizen.nl>

---

 src/amd/vulkan/radv_device.c   | 4 ++++
 src/amd/vulkan/radv_pipeline.c | 4 +---
 src/amd/vulkan/radv_private.h  | 3 +++
 3 files changed, 8 insertions(+), 3 deletions(-)

diff --git a/src/amd/vulkan/radv_device.c b/src/amd/vulkan/radv_device.c
index 1da49cb6093..d3c412558ba 100644
--- a/src/amd/vulkan/radv_device.c
+++ b/src/amd/vulkan/radv_device.c
@@ -372,6 +372,10 @@ radv_physical_device_init(struct radv_physical_device *device,
 	device->use_shader_ballot = device->rad_info.chip_class >= GFX8 &&
 				    (device->use_aco || device->instance->perftest_flags & RADV_PERFTEST_SHADER_BALLOT);
 
+	device->use_ngg = device->rad_info.chip_class >= GFX10 &&
+			  device->rad_info.family != CHIP_NAVI14 &&
+			  !(device->instance->debug_flags & RADV_DEBUG_NO_NGG);
+
 	device->use_ngg_streamout = false;
 
 	/* Determine the number of threads per wave for all stages. */
diff --git a/src/amd/vulkan/radv_pipeline.c b/src/amd/vulkan/radv_pipeline.c
index ddf94625972..1be8d406a43 100644
--- a/src/amd/vulkan/radv_pipeline.c
+++ b/src/amd/vulkan/radv_pipeline.c
@@ -2309,9 +2309,7 @@ radv_fill_shader_keys(struct radv_device *device,
 			keys[MESA_SHADER_VERTEX].vs_common_out.as_es = true;
 	}
 
-	if (device->physical_device->rad_info.chip_class >= GFX10 &&
-	    device->physical_device->rad_info.family != CHIP_NAVI14 &&
-	    !(device->instance->debug_flags & RADV_DEBUG_NO_NGG)) {
+	if (device->physical_device->use_ngg) {
 		if (nir[MESA_SHADER_TESS_CTRL]) {
 			keys[MESA_SHADER_TESS_EVAL].vs_common_out.as_ngg = true;
 		} else {
diff --git a/src/amd/vulkan/radv_private.h b/src/amd/vulkan/radv_private.h
index 0a3e7ca9d88..f4c32659d79 100644
--- a/src/amd/vulkan/radv_private.h
+++ b/src/amd/vulkan/radv_private.h
@@ -288,6 +288,9 @@ struct radv_physical_device {
 	/* Whether to enable the AMD_shader_ballot extension */
 	bool use_shader_ballot;
 
+	/* Whether to enable NGG. */
+	bool use_ngg;
+
 	/* Whether to enable NGG streamout. */
 	bool use_ngg_streamout;
 




More information about the mesa-commit mailing list