[Mesa-dev] [PATCH V6 20/27] glsl: add AoA support for an inteface with unsized array members

Ian Romanick idr at freedesktop.org
Tue Oct 6 13:20:22 PDT 2015


This patch is

Reviewed-by: Ian Romanick <ian.d.romanick at intel.com>

On 09/28/2015 07:42 PM, Timothy Arceri wrote:
> Add support for setting the max access of an unsized member
> of an interface array of arrays.
> 
> For example ifc[j][k].foo[i] where foo is unsized.
> ---
>  src/glsl/ast_array_index.cpp | 16 ++++++++++++----
>  1 file changed, 12 insertions(+), 4 deletions(-)
> 
> diff --git a/src/glsl/ast_array_index.cpp b/src/glsl/ast_array_index.cpp
> index 906024f..9585408 100644
> --- a/src/glsl/ast_array_index.cpp
> +++ b/src/glsl/ast_array_index.cpp
> @@ -61,21 +61,29 @@ update_max_array_access(ir_rvalue *ir, int idx, YYLTYPE *loc,
>        }
>     } else if (ir_dereference_record *deref_record =
>                ir->as_dereference_record()) {
> -      /* There are two possibilities we need to consider:
> +      /* There are three possibilities we need to consider:
>         *
>         * - Accessing an element of an array that is a member of a named
>         *   interface block (e.g. ifc.foo[i])
>         *
>         * - Accessing an element of an array that is a member of a named
>         *   interface block array (e.g. ifc[j].foo[i]).
> +       *
> +       * - Accessing an element of an array that is a member of a named
> +       *   interface block array of arrays (e.g. ifc[j][k].foo[i]).
>         */
>        ir_dereference_variable *deref_var =
>           deref_record->record->as_dereference_variable();
>        if (deref_var == NULL) {
> -         if (ir_dereference_array *deref_array =
> -             deref_record->record->as_dereference_array()) {
> -            deref_var = deref_array->array->as_dereference_variable();
> +         ir_dereference_array *deref_array =
> +            deref_record->record->as_dereference_array();
> +         ir_dereference_array *deref_array_prev = NULL;
> +         while (deref_array != NULL) {
> +            deref_array_prev = deref_array;
> +            deref_array = deref_array->array->as_dereference_array();
>           }
> +         if (deref_array_prev != NULL)
> +            deref_var = deref_array_prev->array->as_dereference_variable();
>        }
>  
>        if (deref_var != NULL) {
> 



More information about the mesa-dev mailing list