aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2017-05-11 14:08:07 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2017-05-11 14:08:07 +0000
commit43b883a99006138770d42067d385347fbae21334 (patch)
tree60aa0326b74bb6c26cb4ebb65d8f8152f48b53f1
parentf8cba3aaaef329e00f8af4364765274205402be9 (diff)
downloadgcc-43b883a99006138770d42067d385347fbae21334.zip
gcc-43b883a99006138770d42067d385347fbae21334.tar.gz
gcc-43b883a99006138770d42067d385347fbae21334.tar.bz2
re PR tree-optimization/80705 (Incorrect code generated for profile counter updates due to SLP+LIM)
2017-05-11 Richard Biener <rguenther@suse.de> PR tree-optimization/80705 * tree-vect-data-refs.c (vect_analyze_data_refs): DECL_NONALIASED bases are not vectorizable. * gcc.dg/vect/bb-slp-pr80705.c: New testcase. From-SVN: r247906
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/vect/bb-slp-pr80705.c44
-rw-r--r--gcc/tree-vect-data-refs.c21
4 files changed, 76 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 3430b1e..a317c21 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2017-05-11 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/80705
+ * tree-vect-data-refs.c (vect_analyze_data_refs): DECL_NONALIASED
+ bases are not vectorizable.
+
2017-05-11 Bin Cheng <bin.cheng@arm.com>
* tree-ssa-loop-ivopts.c (determine_set_costs): Skip non-interger
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 832eba3..1af2958 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2017-05-11 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/80705
+ * gcc.dg/vect/bb-slp-pr80705.c: New testcase.
+
2017-05-11 Nathan Sidwell <nathan@acm.org>
* lib/scanlang.exp: New.
diff --git a/gcc/testsuite/gcc.dg/vect/bb-slp-pr80705.c b/gcc/testsuite/gcc.dg/vect/bb-slp-pr80705.c
new file mode 100644
index 0000000..189e3d1
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/vect/bb-slp-pr80705.c
@@ -0,0 +1,44 @@
+/* { dg-do compile } */
+/* { dg-require-profiling "-fprofile-generate" } */
+/* { dg-additional-options "-fprofile-generate" } */
+
+extern int isspace (int);
+
+int foo(const char *txt, char *buf)
+{
+ const char *s;
+ char *d;
+ int ws = 1;
+ for (s=txt, d=buf; *s; )
+ {
+ if (*s=='/' && *(s+1)=='/') {
+
+ s += 2;
+ while (*s && *s!='\r' && *s!='\n')
+ s++;
+ }
+ else if (*s=='"') {
+
+ s++;
+ while (*s && *s!='\r' && *s!='\n' && *s!='"')
+ if (*s++=='\\')
+ s++;
+ if (*s=='"')
+ s++;
+ }
+ else {
+ if (*s && !isspace(*s))
+ ws = 0;
+
+
+ *d++ = *s++;
+
+ }
+ }
+ *d = '\0';
+
+ return ws;
+}
+
+/* { dg-final { scan-tree-dump "base object not addressable" "slp1" } } */
+/* { dg-final { scan-tree-dump-not "MEM\[^\r\n\]*__gcov\[^\r\n\]* = vect_cst" "slp1" } } */
diff --git a/gcc/tree-vect-data-refs.c b/gcc/tree-vect-data-refs.c
index c974268..67cc969 100644
--- a/gcc/tree-vect-data-refs.c
+++ b/gcc/tree-vect-data-refs.c
@@ -3957,6 +3957,27 @@ again:
datarefs[i] = dr;
}
+ if (TREE_CODE (DR_BASE_ADDRESS (dr)) == ADDR_EXPR
+ && VAR_P (TREE_OPERAND (DR_BASE_ADDRESS (dr), 0))
+ && DECL_NONALIASED (TREE_OPERAND (DR_BASE_ADDRESS (dr), 0)))
+ {
+ if (dump_enabled_p ())
+ {
+ dump_printf_loc (MSG_MISSED_OPTIMIZATION, vect_location,
+ "not vectorized: base object not addressable "
+ "for stmt: ");
+ dump_gimple_stmt (MSG_MISSED_OPTIMIZATION, TDF_SLIM, stmt, 0);
+ }
+ if (is_a <bb_vec_info> (vinfo))
+ {
+ /* In BB vectorization the ref can still participate
+ in dependence analysis, we just can't vectorize it. */
+ STMT_VINFO_VECTORIZABLE (stmt_info) = false;
+ continue;
+ }
+ return false;
+ }
+
/* Set vectype for STMT. */
scalar_type = TREE_TYPE (DR_REF (dr));
STMT_VINFO_VECTYPE (stmt_info)