aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2012-01-30 14:47:38 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2012-01-30 14:47:38 +0100
commitdd44dcb02211b31660a9688878d39ae9bf41aa52 (patch)
treecd9ec4475d15f4f5effcf1dd180b2e4ab2d7c523 /gcc
parentab448cfa68bc2686ba6fcf54e1ee40acd5e403a8 (diff)
downloadgcc-dd44dcb02211b31660a9688878d39ae9bf41aa52.zip
gcc-dd44dcb02211b31660a9688878d39ae9bf41aa52.tar.gz
gcc-dd44dcb02211b31660a9688878d39ae9bf41aa52.tar.bz2
re PR debug/52048 (-fcompare-debug failure with -O2 -fcompare-debug -fnon-call-exceptions -fno-tree-dominator-opts)
PR debug/52048 * tree-ssa-tail-merge.c (local_def): Ignore debug uses. * g++.dg/other/pr52048.C: New test. From-SVN: r183723
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/other/pr52048.C79
-rw-r--r--gcc/tree-ssa-tail-merge.c2
4 files changed, 91 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index e62c447..2bec9cb 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2012-01-30 Jakub Jelinek <jakub@redhat.com>
+
+ PR debug/52048
+ * tree-ssa-tail-merge.c (local_def): Ignore debug uses.
+
2012-01-30 Richard Guenther <rguenther@suse.de>
PR tree-optimization/52045
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 65a9a7a..e543e9a 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2012-01-30 Jakub Jelinek <jakub@redhat.com>
+
+ PR debug/52048
+ * g++.dg/other/pr52048.C: New test.
+
2012-01-30 Richard Guenther <rguenther@suse.de>
PR tree-optimization/52045
diff --git a/gcc/testsuite/g++.dg/other/pr52048.C b/gcc/testsuite/g++.dg/other/pr52048.C
new file mode 100644
index 0000000..6bf51f1
--- /dev/null
+++ b/gcc/testsuite/g++.dg/other/pr52048.C
@@ -0,0 +1,79 @@
+// PR debug/52048
+// { dg-do compile }
+// { dg-options "-fcompare-debug -fnon-call-exceptions -fno-tree-dominator-opts -O2" }
+
+template <typename T> struct A;
+template <typename T>
+struct A <T *>
+{
+ typedef T &a;
+};
+template <typename T>
+struct B
+{
+ typedef typename A <T>::a a;
+ a operator *() {}
+};
+template <typename T, typename U>
+bool operator != (B <T>, B <U>)
+{
+}
+template <typename T>
+struct C
+{
+ typedef T *c;
+ template <typename>
+ struct D { typedef C d; };
+};
+template <typename T, typename U> struct E
+{
+ typedef typename U::template D <T>::d e;
+};
+template <typename T, typename U = C <T> >
+struct F
+{
+ typedef E <T, U> b;
+ typedef typename b::e e;
+ typedef typename e::c c;
+ typedef B <c> i;
+ i begin ();
+ i end ();
+};
+class G;
+class H;
+struct I
+{
+ void *i;
+ template <typename T> T foo ();
+};
+struct J : public I
+{
+ virtual bool bar ();
+};
+class K {};
+struct L
+{
+ bool baz () {}
+};
+struct M
+{
+ K m1 (K);
+ K m2 (H *) {}
+};
+struct N : J
+{
+ bool bar (G &);
+};
+bool
+N::bar (G &)
+{
+ M m = foo <M> ();
+ F <H *> f;
+ for (F <H *>::i I = f.begin (), E = f.end (); I != E;)
+ {
+ H *h = *I;
+ L l;
+ if (l.baz ())
+ m.m1 (m.m2 (h));
+ }
+}
diff --git a/gcc/tree-ssa-tail-merge.c b/gcc/tree-ssa-tail-merge.c
index 47dc0a6..1f46b10 100644
--- a/gcc/tree-ssa-tail-merge.c
+++ b/gcc/tree-ssa-tail-merge.c
@@ -371,6 +371,8 @@ local_def (tree val)
res = true;
FOR_EACH_IMM_USE_STMT (stmt, iter, val)
{
+ if (is_gimple_debug (stmt))
+ continue;
bb = gimple_bb (stmt);
if (bb == def_bb)
continue;