aboutsummaryrefslogtreecommitdiff
path: root/gcc/cgraphclones.c
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2013-02-05 10:11:53 +0100
committerJan Hubicka <hubicka@gcc.gnu.org>2013-02-05 09:11:53 +0000
commit39f9719e9a6a8f061c8654f4e54d804f61a6f982 (patch)
treeb2b8022d4fdc5470327f550cf4205f9bf4a1fe20 /gcc/cgraphclones.c
parent956d3b33b5a2a578be54ce8f41fd553e94bdaf2f (diff)
downloadgcc-39f9719e9a6a8f061c8654f4e54d804f61a6f982.zip
gcc-39f9719e9a6a8f061c8654f4e54d804f61a6f982.tar.gz
gcc-39f9719e9a6a8f061c8654f4e54d804f61a6f982.tar.bz2
PR tree-optimization/r55789
* cgraphclones.c (cgraph_remove_node_and_inline_clones): Remove the dead call anyway. * g++.dg/torture/pr55789.C: New testcase. From-SVN: r195750
Diffstat (limited to 'gcc/cgraphclones.c')
-rw-r--r--gcc/cgraphclones.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/gcc/cgraphclones.c b/gcc/cgraphclones.c
index 30d02d1..3a2e3d6 100644
--- a/gcc/cgraphclones.c
+++ b/gcc/cgraphclones.c
@@ -570,7 +570,10 @@ cgraph_remove_node_and_inline_clones (struct cgraph_node *node, struct cgraph_no
bool found = false;
if (node == forbidden_node)
- return true;
+ {
+ cgraph_remove_edge (node->callers);
+ return true;
+ }
for (e = node->callees; e; e = next)
{
next = e->next_callee;