summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2011-10-27 12:10:57 +0000
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2011-10-27 12:10:57 +0000
commiteab22dca0c366b717a9152578d0f2dbd0cf4d636 (patch)
tree1db405a0ac28cf51bf0643b24a3f2e9276c9be9c
parentceb6e523bd21ee863539e8f9a315ad68137f5222 (diff)
downloadgcc-eab22dca0c366b717a9152578d0f2dbd0cf4d636.tar.gz
2010-10-27 Richard Guenther <rguenther@suse.de>
PR middle-end/50731 * tree-vect-generic.c (do_binop): Handle scalar operands. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@180564 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/tree-vect-generic.c6
2 files changed, 9 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 8b8cea78795..fe6f88b37bc 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2010-10-27 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/50731
+ * tree-vect-generic.c (do_binop): Handle scalar operands.
+
2011-08-27 Uros Bizjak <ubizjak@gmail.com>
PR target/37191
diff --git a/gcc/tree-vect-generic.c b/gcc/tree-vect-generic.c
index ccbec6ebac6..6555932a4cc 100644
--- a/gcc/tree-vect-generic.c
+++ b/gcc/tree-vect-generic.c
@@ -125,8 +125,10 @@ static tree
do_binop (gimple_stmt_iterator *gsi, tree inner_type, tree a, tree b,
tree bitpos, tree bitsize, enum tree_code code)
{
- a = tree_vec_extract (gsi, inner_type, a, bitsize, bitpos);
- b = tree_vec_extract (gsi, inner_type, b, bitsize, bitpos);
+ if (TREE_CODE (TREE_TYPE (a)) == VECTOR_TYPE)
+ a = tree_vec_extract (gsi, inner_type, a, bitsize, bitpos);
+ if (TREE_CODE (TREE_TYPE (b)) == VECTOR_TYPE)
+ b = tree_vec_extract (gsi, inner_type, b, bitsize, bitpos);
return gimplify_build2 (gsi, code, inner_type, a, b);
}