aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorTeresa Johnson <tejohnson@google.com>2014-11-13 15:36:48 +0000
committerTeresa Johnson <tejohnson@gcc.gnu.org>2014-11-13 15:36:48 +0000
commit37e10165c13e9860dabbf6eaf85481debec459e9 (patch)
treeb15747ba3fade3c6296ce7777f365b466280d4b7 /gcc
parent6fad471b8f1a62c385624bf4cecbd57c397bbe91 (diff)
downloadgcc-37e10165c13e9860dabbf6eaf85481debec459e9.zip
gcc-37e10165c13e9860dabbf6eaf85481debec459e9.tar.gz
gcc-37e10165c13e9860dabbf6eaf85481debec459e9.tar.bz2
re PR tree-optimization/63841 (Incorrect strlen optimization after complete unroll)
2014-11-13 Teresa Johnson <tejohnson@google.com> gcc: PR tree-optimization/63841 * tree.c (initializer_zerop): A clobber does not zero initialize. gcc/testsuite: PR tree-optimization/63841 * g++.dg/tree-ssa/pr63841.C: New test. From-SVN: r217505
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/g++.dg/tree-ssa/pr63841.C38
-rw-r--r--gcc/tree.c2
4 files changed, 49 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index dca1d5a..c6014e9 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2014-11-13 Teresa Johnson <tejohnson@google.com>
+
+ PR tree-optimization/63841
+ * tree.c (initializer_zerop): A clobber does not zero initialize.
+
2014-11-13 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
* optabs.c (prepare_operand): Gracefully fail if the mode of X
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 279c1b4..b4484b6 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2014-11-13 Teresa Johnson <tejohnson@google.com>
+ PR tree-optimization/63841
+ * g++.dg/tree-ssa/pr63841.C: New test.
+
2014-11-13 Richard Biener <rguenther@suse.de>
* gcc.dg/tree-ssa/forwprop-28.c: Adjust.
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr63841.C b/gcc/testsuite/g++.dg/tree-ssa/pr63841.C
new file mode 100644
index 0000000..466e320
--- /dev/null
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr63841.C
@@ -0,0 +1,38 @@
+/* { dg-do run } */
+/* { dg-options "-O2" } */
+
+#include <cstdio>
+#include <string>
+
+std::string __attribute__ ((noinline)) comp_test_write() {
+ std::string data;
+
+ for (int i = 0; i < 2; ++i) {
+ char b = 1 >> (i * 8);
+ data.append(&b, 1);
+ }
+
+ return data;
+}
+
+std::string __attribute__ ((noinline)) comp_test_write_good() {
+ std::string data;
+
+ char b;
+ for (int i = 0; i < 2; ++i) {
+ b = 1 >> (i * 8);
+ data.append(&b, 1);
+ }
+
+ return data;
+}
+
+int main() {
+ std::string good = comp_test_write_good();
+ printf("expected: %hx\n", *(short*)good.c_str());
+
+ std::string bad = comp_test_write();
+ printf("got: %hx\n", *(short*)bad.c_str());
+
+ return good != bad;
+}
diff --git a/gcc/tree.c b/gcc/tree.c
index 221f0dd..cf37a19 100644
--- a/gcc/tree.c
+++ b/gcc/tree.c
@@ -10330,6 +10330,8 @@ initializer_zerop (const_tree init)
{
unsigned HOST_WIDE_INT idx;
+ if (TREE_CLOBBER_P (init))
+ return false;
FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (init), idx, elt)
if (!initializer_zerop (elt))
return false;