From dd44dcb02211b31660a9688878d39ae9bf41aa52 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Mon, 30 Jan 2012 14:47:38 +0100 Subject: [PATCH] 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 --- gcc/ChangeLog | 5 ++ gcc/testsuite/ChangeLog | 5 ++ gcc/testsuite/g++.dg/other/pr52048.C | 79 ++++++++++++++++++++++++++++ gcc/tree-ssa-tail-merge.c | 2 + 4 files changed, 91 insertions(+) create mode 100644 gcc/testsuite/g++.dg/other/pr52048.C diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e62c447b7b6..2bec9cb82ae 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2012-01-30 Jakub Jelinek + + PR debug/52048 + * tree-ssa-tail-merge.c (local_def): Ignore debug uses. + 2012-01-30 Richard Guenther PR tree-optimization/52045 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 65a9a7a0f54..e543e9a630a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2012-01-30 Jakub Jelinek + + PR debug/52048 + * g++.dg/other/pr52048.C: New test. + 2012-01-30 Richard Guenther 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 00000000000..6bf51f1e288 --- /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 struct A; +template +struct A +{ + typedef T &a; +}; +template +struct B +{ + typedef typename A ::a a; + a operator *() {} +}; +template +bool operator != (B , B ) +{ +} +template +struct C +{ + typedef T *c; + template + struct D { typedef C d; }; +}; +template struct E +{ + typedef typename U::template D ::d e; +}; +template > +struct F +{ + typedef E b; + typedef typename b::e e; + typedef typename e::c c; + typedef B i; + i begin (); + i end (); +}; +class G; +class H; +struct I +{ + void *i; + template 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 (); + F f; + for (F ::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 47dc0a6ffc8..1f46b10a64e 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;