diff options
author | Ira Rosen <ira.rosen@linaro.org> | 2011-06-21 11:58:33 +0000 |
---|---|---|
committer | Ira Rosen <irar@gcc.gnu.org> | 2011-06-21 11:58:33 +0000 |
commit | 5181cd6a44e01ef31320f2fd1f1a5c365e98a260 (patch) | |
tree | b9d55e96eaf8895e0cdcf9b66c46d1ba0bccfc9d /gcc/tree-vect-loop.c | |
parent | e4ee3d702b745dfc7890e80be4bf8ad02134e3bb (diff) | |
download | gcc-5181cd6a44e01ef31320f2fd1f1a5c365e98a260.zip gcc-5181cd6a44e01ef31320f2fd1f1a5c365e98a260.tar.gz gcc-5181cd6a44e01ef31320f2fd1f1a5c365e98a260.tar.bz2 |
re PR tree-optimization/49478 (ice in expand_widen_pattern_expr with -O3)
PR tree-optimization/49478
* tree-vect-loop.c (vectorizable_reduction): Handle DOT_PROD_EXPR
with constant operand.
From-SVN: r175255
Diffstat (limited to 'gcc/tree-vect-loop.c')
-rw-r--r-- | gcc/tree-vect-loop.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/gcc/tree-vect-loop.c b/gcc/tree-vect-loop.c index 27305f3..7691267 100644 --- a/gcc/tree-vect-loop.c +++ b/gcc/tree-vect-loop.c @@ -4591,6 +4591,25 @@ vectorizable_reduction (gimple stmt, gimple_stmt_iterator *gsi, return false; } + /* In case of widenning multiplication by a constant, we update the type + of the constant to be the type of the other operand. We check that the + constant fits the type in the pattern recognition pass. */ + if (code == DOT_PROD_EXPR + && !types_compatible_p (TREE_TYPE (ops[0]), TREE_TYPE (ops[1]))) + { + if (TREE_CODE (ops[0]) == INTEGER_CST) + ops[0] = fold_convert (TREE_TYPE (ops[1]), ops[0]); + else if (TREE_CODE (ops[1]) == INTEGER_CST) + ops[1] = fold_convert (TREE_TYPE (ops[0]), ops[1]); + else + { + if (vect_print_dump_info (REPORT_DETAILS)) + fprintf (vect_dump, "invalid types in dot-prod"); + + return false; + } + } + if (!vec_stmt) /* transformation not required. */ { if (!vect_model_reduction_cost (stmt_info, epilog_reduc_code, ncopies)) |