diff options
Diffstat (limited to 'gcc/lto-cgraph.c')
| -rw-r--r-- | gcc/lto-cgraph.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/gcc/lto-cgraph.c b/gcc/lto-cgraph.c index a7c0947af37..df4d2446a12 100644 --- a/gcc/lto-cgraph.c +++ b/gcc/lto-cgraph.c @@ -312,12 +312,10 @@ referenced_from_other_partition_p (struct ipa_ref_list *list, cgraph_node_set se /* Return true when node is reachable from other partition. */ -static bool +bool reachable_from_other_partition_p (struct cgraph_node *node, cgraph_node_set set) { struct cgraph_edge *e; - if (node->needed) - return true; if (!node->analyzed) return false; if (node->global.inlined_to) @@ -339,6 +337,7 @@ reachable_from_other_partition_p (struct cgraph_node *node, cgraph_node_set set) static void lto_output_node (struct lto_simple_output_block *ob, struct cgraph_node *node, lto_cgraph_encoder_t encoder, cgraph_node_set set, + varpool_node_set vset, bitmap written_decls) { unsigned int tag; @@ -400,7 +399,9 @@ lto_output_node (struct lto_simple_output_block *ob, struct cgraph_node *node, bp_pack_value (bp, node->address_taken, 1); bp_pack_value (bp, node->abstract_and_needed, 1); bp_pack_value (bp, tag == LTO_cgraph_analyzed_node - && reachable_from_other_partition_p (node, set), 1); + && !DECL_EXTERNAL (node->decl) + && (reachable_from_other_partition_p (node, set) + || referenced_from_other_partition_p (&node->ref_list, set, vset)), 1); bp_pack_value (bp, node->lowered, 1); bp_pack_value (bp, in_other_partition, 1); bp_pack_value (bp, node->alias, 1); @@ -767,7 +768,7 @@ output_cgraph (cgraph_node_set set, varpool_node_set vset) for (i = 0; i < n_nodes; i++) { node = lto_cgraph_encoder_deref (encoder, i); - lto_output_node (ob, node, encoder, set, written_decls); + lto_output_node (ob, node, encoder, set, vset, written_decls); } lto_bitmap_free (written_decls); |

