aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorUros Bizjak <ubizjak@gmail.com>2016-09-20 19:36:03 +0200
committerUros Bizjak <uros@gcc.gnu.org>2016-09-20 19:36:03 +0200
commit9b1ba33cf61cc1ca76bacd1eb3a41fe0eb5d12e9 (patch)
tree707be5437697970fac022b866b613f03254903f1 /gcc
parentb276eda4b4e09dc1b8b265a30b41e1493abc3031 (diff)
downloadgcc-9b1ba33cf61cc1ca76bacd1eb3a41fe0eb5d12e9.zip
gcc-9b1ba33cf61cc1ca76bacd1eb3a41fe0eb5d12e9.tar.gz
gcc-9b1ba33cf61cc1ca76bacd1eb3a41fe0eb5d12e9.tar.bz2
re PR tree-optimization/77621 (Internal compiler error for mtune=atom + msse2)
PR target/77621 * config/i386/i386.c (ix86_preferred_simd_mode) <case DFmode>: Don't return word_mode for !TARGET_VECTORIZE_DOUBLE. (ix86_add_stmt_cost): Penalize DFmode vector operations for !TARGET_VECTORIZE_DOUBLE. testsuite/ChangeLog: PR target/77621 * gcc.target/i386/pr77621.c: New test. * gcc.target/i386/vect-double-2.c: Update scan-tree-dump-times pattern, loop should vectorize with -mtune=atom. From-SVN: r240277
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog8
-rw-r--r--gcc/config/i386/i386.c11
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/gcc.target/i386/pr77621.c12
-rw-r--r--gcc/testsuite/gcc.target/i386/vect-double-2.c2
5 files changed, 35 insertions, 5 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index ac74265..e92ad38 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,11 @@
+2016-09-20 Uros Bizjak <ubizjak@gmail.com>
+
+ PR target/77621
+ * config/i386/i386.c (ix86_preferred_simd_mode) <case DFmode>:
+ Don't return word_mode for !TARGET_VECTORIZE_DOUBLE.
+ (ix86_add_stmt_cost): Penalize DFmode vector operations
+ for !TARGET_VECTORIZE_DOUBLE.
+
2016-09-20 Gerald Pfeifer <gerald@pfeifer.com>
* doc/invoke.texi (Warning Options): Simplify language.
diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c
index 60b81bb..ff057dc 100644
--- a/gcc/config/i386/i386.c
+++ b/gcc/config/i386/i386.c
@@ -49554,9 +49554,7 @@ ix86_preferred_simd_mode (machine_mode mode)
return V4SFmode;
case DFmode:
- if (!TARGET_VECTORIZE_DOUBLE)
- return word_mode;
- else if (TARGET_AVX512F)
+ if (TARGET_AVX512F)
return V8DFmode;
else if (TARGET_AVX && !TARGET_PREFER_AVX128)
return V4DFmode;
@@ -49647,9 +49645,14 @@ ix86_add_stmt_cost (void *data, int count, enum vect_cost_for_stmt kind,
tree vectype = stmt_info ? stmt_vectype (stmt_info) : NULL_TREE;
int stmt_cost = ix86_builtin_vectorization_cost (kind, vectype, misalign);
+ /* Penalize DFmode vector operations for !TARGET_VECTORIZE_DOUBLE. */
+ if (kind == vector_stmt && !TARGET_VECTORIZE_DOUBLE
+ && vectype && GET_MODE_INNER (TYPE_MODE (vectype)) == DFmode)
+ stmt_cost *= 5; /* FIXME: The value here is arbitrary. */
+
/* Statements in an inner loop relative to the loop being
vectorized are weighted more heavily. The value here is
- arbitrary and could potentially be improved with analysis. */
+ arbitrary and could potentially be improved with analysis. */
if (where == vect_body && stmt_info && stmt_in_inner_loop_p (stmt_info))
count *= 50; /* FIXME. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index d515fdf..89024bb 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+2016-09-20 Uros Bizjak <ubizjak@gmail.com>
+
+ PR target/77621
+ * gcc.target/i386/pr77621.c: New test.
+ * gcc.target/i386/vect-double-2.c: Update scan-tree-dump-times
+ pattern, loop should vectorize with -mtune=atom.
+
2016-09-20 Maxim Ostapenko <m.ostapenko@samsung.com>
Jakub Jelinek <jakub@redhat.com>
diff --git a/gcc/testsuite/gcc.target/i386/pr77621.c b/gcc/testsuite/gcc.target/i386/pr77621.c
new file mode 100644
index 0000000..0de2ef3
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr77621.c
@@ -0,0 +1,12 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -mtune=atom -msse2 -fdump-tree-vect-stats" } */
+
+void
+foo (double *x, int *y)
+{
+ int i;
+ for (i = 0; i < 8; i++)
+ x[i] -= y[i] * x[i + 1];
+}
+
+/* { dg-final { scan-tree-dump-not "Vectorized loops: 1" "vect" } } */
diff --git a/gcc/testsuite/gcc.target/i386/vect-double-2.c b/gcc/testsuite/gcc.target/i386/vect-double-2.c
index b30d848..f6a4374 100644
--- a/gcc/testsuite/gcc.target/i386/vect-double-2.c
+++ b/gcc/testsuite/gcc.target/i386/vect-double-2.c
@@ -31,4 +31,4 @@ sse2_test (void)
}
}
-/* { dg-final { scan-tree-dump-not "vectorized 1 loops" "vect" } } */
+/* { dg-final { scan-tree-dump-times "Vectorized loops: 1" 1 "vect" } } */