From: Samuel Pitoiset Date: Fri, 22 Apr 2022 07:50:16 +0000 (+0200) Subject: nir: fix marking XFB varyings as always active IO X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=26f74f17d9be014e70f297a0af4143970347008e;p=platform%2Fupstream%2Fmesa.git nir: fix marking XFB varyings as always active IO Components need to be handled, otherwise if a shader has two XFB varyings at the same location, only one will be marked as always active. Cc: mesa-stable Signed-off-by: Samuel Pitoiset Reviewed-by: Timothy Arceri Part-of: --- diff --git a/src/compiler/nir/nir_linking_helpers.c b/src/compiler/nir/nir_linking_helpers.c index 187098c..b0ddb36 100644 --- a/src/compiler/nir/nir_linking_helpers.c +++ b/src/compiler/nir/nir_linking_helpers.c @@ -957,14 +957,14 @@ nir_compact_varyings(nir_shader *producer, nir_shader *consumer, void nir_link_xfb_varyings(nir_shader *producer, nir_shader *consumer) { - nir_variable *input_vars[MAX_VARYING] = { 0 }; + nir_variable *input_vars[MAX_VARYING][4] = { 0 }; nir_foreach_shader_in_variable(var, consumer) { if (var->data.location >= VARYING_SLOT_VAR0 && var->data.location - VARYING_SLOT_VAR0 < MAX_VARYING) { unsigned location = var->data.location - VARYING_SLOT_VAR0; - input_vars[location] = var; + input_vars[location][var->data.location_frac] = var; } } @@ -976,8 +976,8 @@ nir_link_xfb_varyings(nir_shader *producer, nir_shader *consumer) continue; unsigned location = var->data.location - VARYING_SLOT_VAR0; - if (input_vars[location]) { - input_vars[location]->data.always_active_io = true; + if (input_vars[location][var->data.location_frac]) { + input_vars[location][var->data.location_frac]->data.always_active_io = true; } } }