]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR tree-optimization/25315 (testsuite failure:27_io/basic_ostream/inserters_charac...
authorAndrew Pinski <pinskia@physics.uc.edu>
Mon, 23 Jan 2006 15:19:29 +0000 (15:19 +0000)
committerAndrew Pinski <pinskia@gcc.gnu.org>
Mon, 23 Jan 2006 15:19:29 +0000 (07:19 -0800)
2006-01-23  Andrew Pinski  <pinskia@physics.uc.edu>
            Daniel Berlin  <dberlin@dberlin.org>

        PR tree-opt/25315
        PR tree-opt/25857
        * tree-ssa-pre.c (insert_extra_phis): If an incomming edge is abnormal
        return from the function.

2006-01-23  Andrew Pinski  <pinskia@physics.uc.edu>

        PR tree-opt/25857
        * g++.dg/opt/pr25857.C: New test.

Co-Authored-By: Daniel Berlin <dberlin@dberlin.org>
From-SVN: r110127

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/opt/pr25857.C [new file with mode: 0644]
gcc/tree-ssa-pre.c

index eaaf2d87fe01e77e0447e285b08f5970e381b62a..2a85326102fcd7fcdf41a99e5cd5102c4ff1e488 100644 (file)
@@ -1,3 +1,11 @@
+2006-01-23  Andrew Pinski  <pinskia@physics.uc.edu>
+            Daniel Berlin  <dberlin@dberlin.org>
+
+       PR tree-opt/25315
+       PR tree-opt/25857
+       * tree-ssa-pre.c (insert_extra_phis): If an incomming edge is abnormal 
+       return from the function.
+
 2006-01-22  Zack Weinberg  <zackw@panix.com>
 
        * rtl.def (match_code): Add second argument.
index eb289c61b23e71008b8a73c3b2f7e1586bec274c..461ad4c080352c2ab5baf9a77502db3f52c820fb 100644 (file)
@@ -1,3 +1,8 @@
+2006-01-23  Andrew Pinski  <pinskia@physics.uc.edu>
+
+       PR tree-opt/25857
+       * g++.dg/opt/pr25857.C: New test.
+
 2006-01-23  Steven Bosscher  <stevenb.gcc@gmail.com>
        Jan Hubicka  <jh@suse.cz>
        Richard Guenther  <rguenther@suse.de>
diff --git a/gcc/testsuite/g++.dg/opt/pr25857.C b/gcc/testsuite/g++.dg/opt/pr25857.C
new file mode 100644 (file)
index 0000000..4e6858f
--- /dev/null
@@ -0,0 +1,18 @@
+/* { dg-do compile } */
+/* { dg-options "-O2" } */
+
+int foo();
+int i;
+
+struct A
+{
+  ~A() { if (this != (A*)(&i)) foo(); }
+};
+
+struct B
+{
+  A a1, a2, a3, a4;
+  ~B() { foo(); }
+};
+
+B b;
index ada654b17c1d1225616358c088c1434c4e6e0baa..a695e90807bcd98e3070df2d53dd4781a96cfc0e 100644 (file)
@@ -2745,6 +2745,10 @@ insert_extra_phis (basic_block block, basic_block dom)
 
       FOR_EACH_EDGE (e, ei, block->preds)
        {
+         /* We cannot handle abnormal incomming edges correctly.  */
+         if (e->flags & EDGE_ABNORMAL)
+           return;
+
          if (first)
            {
              bitmap_set_copy (tempset, AVAIL_OUT (e->src));