diff options
author | Karol Herbst <kherbst@redhat.com> | 2024-03-22 12:31:19 +0100 |
---|---|---|
committer | Marge Bot <emma+marge@anholt.net> | 2024-04-24 20:18:49 +0000 |
commit | a2c96b8e7f3fc3a6ee7b3df610bce9ce625b943d (patch) | |
tree | 8f7082ad6120b502c4ca4ea8df8ba236f5aba6ef | |
parent | e040a08e5e988703008c412bd31d7c9bbf0c7b20 (diff) |
mesa/st: lower base invoc and workgroup id
Reviewed-by: Alyssa Rosenzweig <alyssa@rosenzweig.io>
Signed-off-by: Karol Herbst <kherbst@redhat.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/26800>
-rw-r--r-- | src/mesa/state_tracker/st_glsl_to_nir.cpp | 4 | ||||
-rw-r--r-- | src/mesa/state_tracker/st_nir_builtins.c | 7 | ||||
-rw-r--r-- | src/mesa/state_tracker/st_program.c | 7 |
3 files changed, 15 insertions, 3 deletions
diff --git a/src/mesa/state_tracker/st_glsl_to_nir.cpp b/src/mesa/state_tracker/st_glsl_to_nir.cpp index a341b3a7723..1802fdec8ed 100644 --- a/src/mesa/state_tracker/st_glsl_to_nir.cpp +++ b/src/mesa/state_tracker/st_glsl_to_nir.cpp @@ -627,8 +627,10 @@ st_link_glsl_to_nir(struct gl_context *ctx, NIR_PASS(_, nir, st_nir_lower_wpos_ytransform, shader->Program, st->screen); + /* needed to lower base_workgroup_id and base_global_invocation_id */ + struct nir_lower_compute_system_values_options cs_options = {}; NIR_PASS(_, nir, nir_lower_system_values); - NIR_PASS(_, nir, nir_lower_compute_system_values, NULL); + NIR_PASS(_, nir, nir_lower_compute_system_values, &cs_options); if (nir->info.io_lowered) continue; /* the rest is for non-lowered IO only */ diff --git a/src/mesa/state_tracker/st_nir_builtins.c b/src/mesa/state_tracker/st_nir_builtins.c index 776ceda04c1..be4dfdb2b63 100644 --- a/src/mesa/state_tracker/st_nir_builtins.c +++ b/src/mesa/state_tracker/st_nir_builtins.c @@ -43,7 +43,12 @@ st_nir_finish_builtin_nir(struct st_context *st, nir_shader *nir) NIR_PASS(_, nir, nir_split_var_copies); NIR_PASS(_, nir, nir_lower_var_copies); NIR_PASS(_, nir, nir_lower_system_values); - NIR_PASS(_, nir, nir_lower_compute_system_values, NULL); + + struct nir_lower_compute_system_values_options cs_options = { + .has_base_global_invocation_id = false, + .has_base_workgroup_id = false, + }; + NIR_PASS(_, nir, nir_lower_compute_system_values, &cs_options); if (nir->options->lower_to_scalar) { nir_variable_mode mask = diff --git a/src/mesa/state_tracker/st_program.c b/src/mesa/state_tracker/st_program.c index 32ed4a4702f..c71a20c58a9 100644 --- a/src/mesa/state_tracker/st_program.c +++ b/src/mesa/state_tracker/st_program.c @@ -382,7 +382,12 @@ st_prog_to_nir_postprocess(struct st_context *st, nir_shader *nir, NIR_PASS(_, nir, st_nir_lower_wpos_ytransform, prog, screen); NIR_PASS(_, nir, nir_lower_system_values); - NIR_PASS(_, nir, nir_lower_compute_system_values, NULL); + + struct nir_lower_compute_system_values_options cs_options = { + .has_base_global_invocation_id = false, + .has_base_workgroup_id = false, + }; + NIR_PASS(_, nir, nir_lower_compute_system_values, &cs_options); /* Optimise NIR */ NIR_PASS(_, nir, nir_opt_constant_folding); |