mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2025-12-24 00:10:10 +01:00
st/nir: Trim out unused VS input variables.
If we're going to skip setting up vertex input data in them, we should
probably not leave them as vertex inputs with a driver_location that
happens to alias to something else.
Fixes a regression in glsl-mat-attribute on vc4 when enabling GTN.
v2: Change commit message shortlog, lower the new globals away before
handing off to the driver.
Reviewed-by: Kenneth Graunke <kenneth@whitecape.org>
This commit is contained in:
parent
3ef1853f7d
commit
d08f09c24e
1 changed files with 23 additions and 7 deletions
|
|
@ -73,8 +73,7 @@ st_nir_fixup_varying_slots(struct st_context *st, struct exec_list *var_list)
|
|||
* on varying-slot w/ the VS outputs)
|
||||
*/
|
||||
static void
|
||||
st_nir_assign_vs_in_locations(struct gl_program *prog,
|
||||
struct exec_list *var_list, unsigned *size)
|
||||
st_nir_assign_vs_in_locations(struct gl_program *prog, nir_shader *nir)
|
||||
{
|
||||
unsigned attr, num_inputs = 0;
|
||||
unsigned input_to_index[VERT_ATTRIB_MAX] = {0};
|
||||
|
|
@ -88,15 +87,29 @@ st_nir_assign_vs_in_locations(struct gl_program *prog,
|
|||
/* add placeholder for second part of a double attribute */
|
||||
num_inputs++;
|
||||
}
|
||||
} else {
|
||||
input_to_index[attr] = ~0;
|
||||
}
|
||||
}
|
||||
|
||||
*size = 0;
|
||||
nir_foreach_variable(var, var_list) {
|
||||
nir->num_inputs = 0;
|
||||
nir_foreach_variable_safe(var, &nir->inputs) {
|
||||
attr = var->data.location;
|
||||
assert(attr < ARRAY_SIZE(input_to_index));
|
||||
var->data.driver_location = input_to_index[attr];
|
||||
(*size)++;
|
||||
|
||||
if (input_to_index[attr] != ~0u) {
|
||||
var->data.driver_location = input_to_index[attr];
|
||||
nir->num_inputs++;
|
||||
} else {
|
||||
/* Move unused input variables to the globals list (with no
|
||||
* initialization), to avoid confusing drivers looking through the
|
||||
* inputs array and expecting to find inputs with a driver_location
|
||||
* set.
|
||||
*/
|
||||
exec_node_remove(&var->node);
|
||||
var->data.mode = nir_var_global;
|
||||
exec_list_push_tail(&nir->globals, &var->node);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -304,7 +317,10 @@ st_finalize_nir(struct st_context *st, struct gl_program *prog, nir_shader *nir)
|
|||
|
||||
if (nir->stage == MESA_SHADER_VERTEX) {
|
||||
/* Needs special handling so drvloc matches the vbo state: */
|
||||
st_nir_assign_vs_in_locations(prog, &nir->inputs, &nir->num_inputs);
|
||||
st_nir_assign_vs_in_locations(prog, nir);
|
||||
/* Re-lower global vars, to deal with any dead VS inputs. */
|
||||
NIR_PASS_V(nir, nir_lower_global_vars_to_local);
|
||||
|
||||
sort_varyings(&nir->outputs);
|
||||
nir_assign_var_locations(&nir->outputs,
|
||||
&nir->num_outputs,
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue