From: Jason Ekstrand Date: Fri, 14 Sep 2018 20:54:19 +0000 (-0500) Subject: nir: Preserve offsets in lower_io_to_scalar_early X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=96fa23bca5ac88e0cd2dd0c45fdef71b2afe888d;p=mesa.git nir: Preserve offsets in lower_io_to_scalar_early Reviewed-by: Lionel Landwerlin Reviewed-by: Alejandro PiƱeiro --- diff --git a/src/compiler/nir/nir_lower_io_to_scalar.c b/src/compiler/nir/nir_lower_io_to_scalar.c index e9135b56ffd..60fd61e006c 100644 --- a/src/compiler/nir/nir_lower_io_to_scalar.c +++ b/src/compiler/nir/nir_lower_io_to_scalar.c @@ -192,6 +192,10 @@ lower_load_to_scalar_early(nir_builder *b, nir_intrinsic_instr *intr, chan_var = nir_variable_clone(var, b->shader); chan_var->data.location_frac = var->data.location_frac + i; chan_var->type = glsl_channel_type(chan_var->type); + if (var->data.explicit_offset) { + unsigned comp_size = glsl_get_bit_size(chan_var->type) / 8; + chan_var->data.offset = var->data.offset + i * comp_size; + } chan_vars[var->data.location_frac + i] = chan_var; @@ -246,6 +250,10 @@ lower_store_output_to_scalar_early(nir_builder *b, nir_intrinsic_instr *intr, chan_var = nir_variable_clone(var, b->shader); chan_var->data.location_frac = var->data.location_frac + i; chan_var->type = glsl_channel_type(chan_var->type); + if (var->data.explicit_offset) { + unsigned comp_size = glsl_get_bit_size(chan_var->type) / 8; + chan_var->data.offset = var->data.offset + i * comp_size; + } chan_vars[var->data.location_frac + i] = chan_var;