From 6a60530dd6117831168a4bb9ea402d14667d9c36 Mon Sep 17 00:00:00 2001 From: Andreas Krebbel Date: Sun, 18 Dec 2005 15:44:00 +0000 Subject: [PATCH] tree-cfg.c (tree_flow_call_edges_add): Check for empty basic blocks. 2005-12-18 Andreas Krebbel * 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 | 4 ++++ gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/gcc.dg/20051201-1.c | 26 ++++++++++++++++++++++++++ gcc/tree-cfg.c | 2 +- 4 files changed, 35 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/gcc.dg/20051201-1.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5a5a5914ae4..6e4f1ffcb8a 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2005-12-18 Andreas Krebbel + + * tree-cfg.c (tree_flow_call_edges_add): Check for empty basic blocks. + 2005-12-18 Steven Bosscher * gcse.c (gcse_main, bypass_jumps): Fix non-GNU-isms from diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5ecdf09c40c..87e1de6186e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2005-12-18 Andreas Krebbel + + * gcc.dg/20051201-1.c: New test. + 2005-12-18 Paul Thomas 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 index 00000000000..8e77986296e --- /dev/null +++ b/gcc/testsuite/gcc.dg/20051201-1.c @@ -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 (); +} diff --git a/gcc/tree-cfg.c b/gcc/tree-cfg.c index 3f925b3b012..d2e688e5afe 100644 --- a/gcc/tree-cfg.c +++ b/gcc/tree-cfg.c @@ -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; -- 2.30.2