Module: Mesa
Branch: main
Commit: 827b0fa1efd734f76364ac5cd72ae1537062eb71
URL:    
http://cgit.freedesktop.org/mesa/mesa/commit/?id=827b0fa1efd734f76364ac5cd72ae1537062eb71

Author: Konstantin Seurer <konstantin.seu...@gmail.com>
Date:   Sat Nov 18 18:18:47 2023 +0100

nir/lower_vars_to_scratch: Remove all unused derefs

If the shader passed to nir_lower_vars_to_scratch contains some unused
derefs to a variable that will be lowered, validation will fail because
the variable is not part of the shader after the pass.

cc: mesa-stable

Reviewed-by: Rhys Perry <pendingchao...@gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/26271>

---

 src/compiler/nir/nir_lower_scratch.c | 11 +++++++++--
 1 file changed, 9 insertions(+), 2 deletions(-)

diff --git a/src/compiler/nir/nir_lower_scratch.c 
b/src/compiler/nir/nir_lower_scratch.c
index 55e58688171..98bb30ee8cb 100644
--- a/src/compiler/nir/nir_lower_scratch.c
+++ b/src/compiler/nir/nir_lower_scratch.c
@@ -145,13 +145,21 @@ nir_lower_vars_to_scratch(nir_shader *shader,
       return false;
    }
 
+   bool progress = false;
+
    nir_foreach_function_impl(impl, shader) {
       nir_foreach_block(block, impl) {
-         nir_foreach_instr(instr, block) {
+         nir_foreach_instr_safe(instr, block) {
             if (instr->type != nir_instr_type_deref)
                continue;
 
             nir_deref_instr *deref = nir_instr_as_deref(instr);
+
+            if (nir_deref_instr_remove_if_unused(deref)) {
+               progress = true;
+               continue;
+            }
+
             if (deref->deref_type != nir_deref_type_var)
                continue;
 
@@ -178,7 +186,6 @@ nir_lower_vars_to_scratch(nir_shader *shader,
       var->data.location = INT_MAX;
    }
 
-   bool progress = false;
    nir_foreach_function_impl(impl, shader) {
       nir_builder build = nir_builder_create(impl);
 

Reply via email to