diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 612e0205399..cf3a172ea66 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-09-03 Jan Hubicka + + PR lto/44812 + * lto-cgraph.c (intput_node, input_varpool_node): Set DECL_EXTERNAL + on functions/variables in other partition. + 2010-09-03 Jan Hubicka * cgraph.h (struct varpool_node): Add const_value_known. diff --git a/gcc/lto-cgraph.c b/gcc/lto-cgraph.c index dac5c321814..78c809b5520 100644 --- a/gcc/lto-cgraph.c +++ b/gcc/lto-cgraph.c @@ -953,6 +953,11 @@ input_overwrite_node (struct lto_file_decl_data *file_data, node->lowered = bp_unpack_value (bp, 1); node->analyzed = tag == LTO_cgraph_analyzed_node; node->in_other_partition = bp_unpack_value (bp, 1); + if (node->in_other_partition) + { + DECL_EXTERNAL (node->decl) = 1; + TREE_STATIC (node->decl) = 0; + } node->alias = bp_unpack_value (bp, 1); node->finalized_by_frontend = bp_unpack_value (bp, 1); node->frequency = (enum node_frequency)bp_unpack_value (bp, 2); @@ -1111,6 +1116,11 @@ input_varpool_node (struct lto_file_decl_data *file_data, node->analyzed = node->finalized; node->used_from_other_partition = bp_unpack_value (&bp, 1); node->in_other_partition = bp_unpack_value (&bp, 1); + if (node->in_other_partition) + { + DECL_EXTERNAL (node->decl) = 1; + TREE_STATIC (node->decl) = 0; + } aliases_p = bp_unpack_value (&bp, 1); if (node->finalized) varpool_mark_needed_node (node);