tree-cfg.c (tree_flow_call_edges_add): Check for empty basic blocks.
authorAndreas Krebbel <krebbel1@de.ibm.com>
Sun, 18 Dec 2005 15:44:00 +0000 (15:44 +0000)
committerUlrich Weigand <uweigand@gcc.gnu.org>
Sun, 18 Dec 2005 15:44:00 +0000 (15:44 +0000)
2005-12-18  Andreas Krebbel  <krebbel1@de.ibm.com>

* tree-cfg.c (tree_flow_call_edges_add): Check for empty basic blocks.

* gcc.dg/20051201-1.c: New test.

From-SVN: r108755

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/20051201-1.c [new file with mode: 0644]
gcc/tree-cfg.c

index 5a5a591..6e4f1ff 100644 (file)
@@ -1,3 +1,7 @@
+2005-12-18  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * tree-cfg.c (tree_flow_call_edges_add): Check for empty basic blocks.
+
 2005-12-18  Steven Bosscher  <stevenb@suse.de>
 
        * gcse.c (gcse_main, bypass_jumps): Fix non-GNU-isms from
index 5ecdf09..87e1de6 100644 (file)
@@ -1,3 +1,7 @@
+2005-12-18  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * gcc.dg/20051201-1.c: New test.
+
 2005-12-18  Paul Thomas  <pault@gcc.gnu.org>
 
        PR fortran/25018
diff --git a/gcc/testsuite/gcc.dg/20051201-1.c b/gcc/testsuite/gcc.dg/20051201-1.c
new file mode 100644 (file)
index 0000000..8e77986
--- /dev/null
@@ -0,0 +1,26 @@
+/* This failed with profiling due to a missing check in
+   tree_flow_call_edges_add.  */
+
+/* { dg-do compile } */
+/* { dg-options "-O1 -fprofile-generate" } */
+
+static __attribute__ ((always_inline)) void 
+baz ()
+{
+}
+
+static __attribute__ ((always_inline)) int
+bar ()
+{
+ out:
+  baz ();
+  goto out;
+}
+
+int
+foo ()
+{
+  long res;
+  
+  res = bar ();
+}
index 3f925b3..d2e688e 100644 (file)
@@ -4769,7 +4769,7 @@ tree_flow_call_edges_add (sbitmap blocks)
       if (!bsi_end_p (bsi))
        t = bsi_stmt (bsi);
 
-      if (need_fake_edge_p (t))
+      if (t && need_fake_edge_p (t))
        {
          edge e;