diff options
author | Ira Rosen <irar@il.ibm.com> | 2009-08-09 12:13:19 +0000 |
---|---|---|
committer | Ira Rosen <irar@gcc.gnu.org> | 2009-08-09 12:13:19 +0000 |
commit | 6f4454fcabc3449f787b86186accc9a64014242e (patch) | |
tree | 880e263ea8d9289591a085f2218e119f7dc29604 /gcc/tree-vect-loop.c | |
parent | 0a940ddd90f0c10c82ed5c08635d1de80bae4807 (diff) | |
download | gcc-6f4454fcabc3449f787b86186accc9a64014242e.zip gcc-6f4454fcabc3449f787b86186accc9a64014242e.tar.gz gcc-6f4454fcabc3449f787b86186accc9a64014242e.tar.bz2 |
re PR tree-optimization/41008 (ICE in vect_is_simple_reduction, at tree-vect-loop.c:1708)
PR tree-optimization/41008
* tree-vect-loop.c (vect_is_simple_reduction): Get operands
from condition only in case it's a comparison. Adjust checks.
From-SVN: r150591
Diffstat (limited to 'gcc/tree-vect-loop.c')
-rw-r--r-- | gcc/tree-vect-loop.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/gcc/tree-vect-loop.c b/gcc/tree-vect-loop.c index 113dc0f..b322213 100644 --- a/gcc/tree-vect-loop.c +++ b/gcc/tree-vect-loop.c @@ -1705,8 +1705,13 @@ vect_is_simple_reduction (loop_vec_info loop_info, gimple phi, return NULL; } - op3 = TREE_OPERAND (TREE_OPERAND (gimple_assign_rhs1 (def_stmt), 0), 0); - op4 = TREE_OPERAND (TREE_OPERAND (gimple_assign_rhs1 (def_stmt), 0), 1); + op3 = TREE_OPERAND (gimple_assign_rhs1 (def_stmt), 0); + if (COMPARISON_CLASS_P (op3)) + { + op4 = TREE_OPERAND (op3, 1); + op3 = TREE_OPERAND (op3, 0); + } + op1 = TREE_OPERAND (gimple_assign_rhs1 (def_stmt), 1); op2 = TREE_OPERAND (gimple_assign_rhs1 (def_stmt), 2); @@ -1750,10 +1755,14 @@ vect_is_simple_reduction (loop_vec_info loop_info, gimple phi, print_generic_expr (vect_dump, TREE_TYPE (op1), TDF_SLIM); fprintf (vect_dump, ","); print_generic_expr (vect_dump, TREE_TYPE (op2), TDF_SLIM); - if (op3 && op4) + if (op3) { fprintf (vect_dump, ","); print_generic_expr (vect_dump, TREE_TYPE (op3), TDF_SLIM); + } + + if (op4) + { fprintf (vect_dump, ","); print_generic_expr (vect_dump, TREE_TYPE (op4), TDF_SLIM); } |