From: Richard Guenther Date: Tue, 26 Jan 2010 15:09:43 +0000 (+0000) Subject: re PR tree-optimization/42806 ("-fcompare-debug failure (length)" at -O1 in recent... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3333cd50b87db95a83b3afebee66d2b8321f1fa1;p=gcc.git re PR tree-optimization/42806 ("-fcompare-debug failure (length)" at -O1 in recent builds) 2010-01-26 Richard Guenther PR middle-end/42806 * tree-eh.c (unsplit_eh): Skip debug insns. * g++.dg/other/pr42806.C: New testcase. From-SVN: r156249 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index da237e7e57d..5d34ebb7ebf 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2010-01-26 Richard Guenther + + PR middle-end/42806 + * tree-eh.c (unsplit_eh): Skip debug insns. + 2010-01-26 Richard Guenther PR tree-optimization/42250 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 3cdaee3ea39..0238f4c71f7 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-01-26 Richard Guenther + + PR middle-end/42806 + * g++.dg/other/pr42806.C: New testcase. + 2010-01-26 Richard Guenther PR tree-optimization/42250 diff --git a/gcc/testsuite/g++.dg/other/pr42806.C b/gcc/testsuite/g++.dg/other/pr42806.C new file mode 100644 index 00000000000..9823238d5d4 --- /dev/null +++ b/gcc/testsuite/g++.dg/other/pr42806.C @@ -0,0 +1,22 @@ +// { dg-do compile } +// { dg-options "-O -fcompare-debug" } + +struct S1 { + ~S1() { } +}; + +struct S2 { + S1 s1; + void m(); + ~S2() { m(); } +}; + +struct S3 { + S3(int, S2); +}; + +void foo() +{ + S3(0, S2()); +} + diff --git a/gcc/tree-eh.c b/gcc/tree-eh.c index 1a9e7b50e6a..2cb334ff0d4 100644 --- a/gcc/tree-eh.c +++ b/gcc/tree-eh.c @@ -3350,8 +3350,11 @@ unsplit_eh (eh_landing_pad lp) if ((e_in->flags & EDGE_EH) == 0 || (e_out->flags & EDGE_EH) != 0) return false; - /* The block must be empty except for the labels. */ - if (!gsi_end_p (gsi_after_labels (bb))) + /* The block must be empty except for the labels and debug insns. */ + gsi = gsi_after_labels (bb); + if (!gsi_end_p (gsi) && is_gimple_debug (gsi_stmt (gsi))) + gsi_next_nondebug (&gsi); + if (!gsi_end_p (gsi)) return false; /* The destination block must not already have a landing pad