From: Tapani Pälli Date: Thu, 19 Nov 2015 11:12:13 +0000 (+0200) Subject: glsl: handle case where index is array deref in optimize_split_arrays X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=315c4c315e311674c840069174244eef97c92705;p=mesa.git glsl: handle case where index is array deref in optimize_split_arrays Previously pass did not traverse to those array dereferences which were used as indices to arrays. This fixes Synmark2 Gl42CSCloth application issues. Signed-off-by: Tapani Pälli Reviewed-by: Juha-Pekka Heikkila --- diff --git a/src/glsl/opt_array_splitting.cpp b/src/glsl/opt_array_splitting.cpp index 9e73f3c44bb..89ce76bed2b 100644 --- a/src/glsl/opt_array_splitting.cpp +++ b/src/glsl/opt_array_splitting.cpp @@ -188,6 +188,10 @@ ir_array_reference_visitor::visit_enter(ir_dereference_array *ir) if (entry && !ir->array_index->as_constant()) entry->split = false; + /* If the index is also array dereference, visit index. */ + if (ir->array_index->as_dereference_array()) + visit_enter(ir->array_index->as_dereference_array()); + return visit_continue_with_parent; }