From: Jan Hubicka Date: Tue, 11 May 2010 08:19:28 +0000 (+0200) Subject: cgraph.c (cgraph_mark_reachable_node): Accept references to optimized out extern... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a2acdf1fb2c4b4c382865c038b18cff6a8ee2dc7;p=gcc.git cgraph.c (cgraph_mark_reachable_node): Accept references to optimized out extern inlines. * cgraph.c (cgraph_mark_reachable_node): Accept references to optimized out extern inlines. From-SVN: r159260 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3abdc3f5b3b..0e02b6c127c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,8 +1,8 @@ 2010-05-11 Jan Hubicka * cgraphbuild.c (cgraph_rebuild_references): New. - (cgraph_mark_reachable_node): Accept references to optimized out - extern inlines. + * cgraph.c (cgraph_mark_reachable_node): Accept references to optimized + out extern inlines. * cgraph.h (cgraph_rebuild_references): Declare. * tree-inline.c (tree_function_versioning): Use it. * ipa-struct-reorg.c (do_reorg_for_func): Likewise. diff --git a/gcc/cgraph.c b/gcc/cgraph.c index 5f609aaf434..a6aed42517a 100644 --- a/gcc/cgraph.c +++ b/gcc/cgraph.c @@ -1643,9 +1643,16 @@ cgraph_mark_reachable_node (struct cgraph_node *node) { if (!node->reachable && node->local.finalized) { - notice_global_symbol (node->decl); + if (cgraph_global_info_ready) + { + /* Verify that function does not appear to be needed out of blue + during the optimization process. This can happen for extern + inlines when bodies was removed after inlining. */ + gcc_assert ((node->analyzed || DECL_EXTERNAL (node->decl))); + } + else + notice_global_symbol (node->decl); node->reachable = 1; - gcc_assert (!cgraph_global_info_ready); node->next_needed = cgraph_nodes_queue; cgraph_nodes_queue = node;