aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIra Rosen <irar@il.ibm.com>2009-11-29 17:30:20 +0000
committerIra Rosen <irar@gcc.gnu.org>2009-11-29 17:30:20 +0000
commit3533e503479fcbef4ddeb94cda3c9420e16a1152 (patch)
treef4c94864c00f84aa363464ac6d301f6714081c4b
parent6744a6abc335d55f98ba226f4ff169a55cf3fb94 (diff)
downloadgcc-3533e503479fcbef4ddeb94cda3c9420e16a1152.zip
gcc-3533e503479fcbef4ddeb94cda3c9420e16a1152.tar.gz
gcc-3533e503479fcbef4ddeb94cda3c9420e16a1152.tar.bz2
re PR middle-end/42193 (454.calculix in SPEC CPU 2006 failed to compile at -O3)
PR tree-optimization/42193 * tree-vect-stmts.c (vectorizable_operation): Set vectorization factor to 1 in case of basic block SLP. (vectorizable_load): Likewise. From-SVN: r154738
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/vect/pr42193.c28
-rw-r--r--gcc/tree-vect-stmts.c6
4 files changed, 42 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index aedf2ae..05712c0 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2009-11-29 Ira Rosen <irar@il.ibm.com>
+
+ PR tree-optimization/42193
+ * tree-vect-stmts.c (vectorizable_operation): Set vectorization factor
+ to 1 in case of basic block SLP.
+ (vectorizable_load): Likewise.
+
2009-11-28 Jan Hubicka <jh@suse.cz>
* cgraph.c (same_body_alias_1): Break out of
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index cad8b2b..1db2125 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2009-11-29 Ira Rosen <irar@il.ibm.com>
+
+ PR tree-optimization/42193
+ * gcc.dg/vect/pr42193.c: New test.
+
2009-11-28 Dodji Seketeli <dodji@redhat.com>
PR c++/36408
diff --git a/gcc/testsuite/gcc.dg/vect/pr42193.c b/gcc/testsuite/gcc.dg/vect/pr42193.c
new file mode 100644
index 0000000..01609c9
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/vect/pr42193.c
@@ -0,0 +1,28 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target vect_long } */
+
+#include <stdarg.h>
+
+unsigned long in[6], out[6];
+
+void foo ()
+{
+ unsigned long a, b, c, d, e, f;
+
+ a = in[0];
+ b = in[1];
+ c = in[2];
+ d = in[3];
+ e = in[4];
+ f = in[5];
+
+ out[0] = 2 * a + 7 * b + 8 * c + 31 * d + 10 * e + 21 * f;
+ out[1] = 3 * a + 6 * b + 12 * c + 13 * d + 15 * e + 28 * f;
+ out[2] = 4 * a + 5 * b + 72 * c + 23 * d + 14 * e + 24 * f;
+ out[3] = 8 * a + 71 * b + 18 * c + 33 * d + 13 * e + 25 * f;
+ out[4] = 12 * a + 16 * b + 19 * c + 41 * d + 22 * e + 26 * f;
+ out[5] = 17 * a + 15 * b + 13 * c + 14 * d + 11 * e + 9 * f;
+}
+
+/* { dg-final { cleanup-tree-dump "vect" } } */
+
diff --git a/gcc/tree-vect-stmts.c b/gcc/tree-vect-stmts.c
index 92f2198..7ce91ca 100644
--- a/gcc/tree-vect-stmts.c
+++ b/gcc/tree-vect-stmts.c
@@ -1934,8 +1934,7 @@ vectorizable_operation (gimple stmt, gimple_stmt_iterator *gsi,
if (loop_vinfo)
vf = LOOP_VINFO_VECT_FACTOR (loop_vinfo);
else
- /* FORNOW: multiple types are not supported in basic block SLP. */
- vf = nunits_in;
+ vf = 1;
/* Multiple types in SLP are handled by creating the appropriate number of
vectorized stmts for each SLP node. Hence, NCOPIES is always 1 in
@@ -3279,8 +3278,7 @@ vectorizable_load (gimple stmt, gimple_stmt_iterator *gsi, gimple *vec_stmt,
vf = LOOP_VINFO_VECT_FACTOR (loop_vinfo);
}
else
- /* FORNOW: multiple types are not supported in basic block SLP. */
- vf = nunits;
+ vf = 1;
/* Multiple types in SLP are handled by creating the appropriate number of
vectorized stmts for each SLP node. Hence, NCOPIES is always 1 in