Mesa (master): zink: rewrite drawid based on shader key value

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Tue Feb 16 01:00:33 UTC 2021


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

Author: Mike Blumenkrantz <michael.blumenkrantz at gmail.com>
Date:   Fri Jan 29 17:10:03 2021 -0500

zink: rewrite drawid based on shader key value

same as basevertex

Reviewed-by: Dave Airlie <airlied at redhat.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/8971>

---

 src/gallium/drivers/zink/zink_compiler.c | 55 ++++++++++++++++++++++++++++++++
 1 file changed, 55 insertions(+)

diff --git a/src/gallium/drivers/zink/zink_compiler.c b/src/gallium/drivers/zink/zink_compiler.c
index 71273abc0ce..8e76c01215a 100644
--- a/src/gallium/drivers/zink/zink_compiler.c
+++ b/src/gallium/drivers/zink/zink_compiler.c
@@ -272,6 +272,56 @@ lower_basevertex(nir_shader *shader)
    return progress;
 }
 
+
+static bool
+lower_drawid_instr(nir_intrinsic_instr *instr, nir_builder *b)
+{
+   if (instr->intrinsic != nir_intrinsic_load_draw_id)
+      return false;
+
+   b->cursor = nir_before_instr(&instr->instr);
+   nir_intrinsic_instr *load = nir_intrinsic_instr_create(b->shader, nir_intrinsic_load_push_constant);
+   load->src[0] = nir_src_for_ssa(nir_imm_int(b, 1));
+   nir_intrinsic_set_range(load, 4);
+   load->num_components = 1;
+   nir_ssa_dest_init(&load->instr, &load->dest, 1, 32, "draw_id");
+   nir_builder_instr_insert(b, &load->instr);
+
+   nir_ssa_def_rewrite_uses(&instr->dest.ssa, nir_src_for_ssa(&load->dest.ssa));
+
+   return true;
+}
+
+static bool
+lower_drawid(nir_shader *shader)
+{
+   bool progress = false;
+
+   if (shader->info.stage != MESA_SHADER_VERTEX)
+      return false;
+
+   if (!BITSET_TEST(shader->info.system_values_read, SYSTEM_VALUE_DRAW_ID))
+      return false;
+
+   nir_foreach_function(function, shader) {
+      if (function->impl) {
+         nir_builder builder;
+         nir_builder_init(&builder, function->impl);
+         nir_foreach_block(block, function->impl) {
+            nir_foreach_instr_safe(instr, block) {
+               if (instr->type == nir_instr_type_intrinsic)
+                  progress |= lower_drawid_instr(nir_instr_as_intrinsic(instr),
+                                                     &builder);
+            }
+         }
+
+         nir_metadata_preserve(function->impl, nir_metadata_dominance);
+      }
+   }
+
+   return progress;
+}
+
 void
 zink_screen_init_compiler(struct zink_screen *screen)
 {
@@ -405,6 +455,11 @@ zink_shader_compile(struct zink_screen *screen, struct zink_shader *zs, struct z
             nir = nir_shader_clone(NULL, zs->nir);
             NIR_PASS_V(nir, nir_lower_clip_halfz);
          }
+         if (zink_vs_key(key)->push_drawid) {
+            if (nir == zs->nir)
+               nir = nir_shader_clone(NULL, zs->nir);
+            NIR_PASS_V(nir, lower_drawid);
+         }
       }
    } else if (zs->nir->info.stage == MESA_SHADER_FRAGMENT) {
       if (!zink_fs_key(key)->samples &&



More information about the mesa-commit mailing list