The previous reorg missed a guard around the else clause access.

Committed as obvious.

2020-06-12  Richard Biener  <rguent...@suse.de>

        PR tree-optimization/95633
        * tree-vect-stmts.c (vectorizable_condition): Properly
        guard the vec_else_clause access with EXTRACT_LAST_REDUCTION.
---
 gcc/tree-vect-stmts.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/gcc/tree-vect-stmts.c b/gcc/tree-vect-stmts.c
index cdd6f6c5e5d..cf2d979fea1 100644
--- a/gcc/tree-vect-stmts.c
+++ b/gcc/tree-vect-stmts.c
@@ -9925,7 +9925,8 @@ vectorizable_condition (vec_info *vinfo,
   FOR_EACH_VEC_ELT (vec_oprnds0, i, vec_cond_lhs)
     {
       vec_then_clause = vec_oprnds2[i];
-      vec_else_clause = vec_oprnds3[i];
+      if (reduction_type != EXTRACT_LAST_REDUCTION)
+       vec_else_clause = vec_oprnds3[i];
 
       if (swap_cond_operands)
        std::swap (vec_then_clause, vec_else_clause);
-- 
2.16.4

Reply via email to