cgraph.h (vector types for symtab_node): Add.
* cgraph.h (vector types for symtab_node): Add. * ipa-reference.c (ipa_reference_write_optimization_summary): Update for new symtab encoder. (ipa_reference_read_optimization_summary): Likewise. * lto-cgraph.c (output_varpool): Remove. (input_cgraph_opt_summary): Take symtab nodes vector as argument. (LTO_cgraph_tags): Rename to ... (LTO_symtab_tags): ... this one; add LTO_symtab_variable. (lto_cgraph_encoder_new): Rename to ... (lto_symtab_encoder_new): ... this on. (lto_cgraph_encoder_encode): Rename to ... (lto_symtab_encoder_encode): ... this one. (lto_cgraph_encoder_delete): Rename to ... (lto_symtab_encoder_delete): ... this one. (lto_cgraph_encoder_deref): Rename to ... (lto_symtab_encoder_deref): ... this one. (lto_cgraph_encoder_encode_body_p): Rename to ... (lto_symtab_encoder_encode_body_p): ... this one. (lto_varpool_encoder_new, lto_varpool_encoder_delete, lto_varpool_encoder_encode, lto_varpool_encoder_lookup, lto_varpool_encoder_deref): Remove. (lto_varpool_encoder_encode_initializer_p): Rename to ... (lto_symtab_encoder_encode_initializer_p): ... this one. (lto_set_varpool_encoder_encode_initializer): Rename to ... (lto_set_symtab_encoder_encode_initializer): ... this one. (lto_output_edge): Update. (lto_output_node): Update. (lto_output_varpool_node): Update; stream out LTO_symtab_variable tag. (lto_output_ref): Drop varpool_encoder; update. (add_node_to): Update. (add_references): Update. (output_outgoing_cgraph_edges): Update. (output_refs): Update. (compute_ltrans_boundary): Update. (output_cgraph): Update; output varpools too. (input_overwrite_node): Update. (output_varpool): Remove. (input_node): Update. (input_ref): Update. (input_edge): Update. (input_cgraph_1): Update; input varpool too; unify fixup code. (input_varpool_1): Remove. (input_refs): Update. (input_cgraph): Update. (output_node_opt_summary): Update. (input_cgraph_opt_section): Update. (input_cgraph_opt_summary): Update. * ipa-pure-const.c (pure_const_write_summary): Update. (pure_const_read_summary): Update. * lto-streamer-out.c (lto_write_tree): Update. (lto_output): Likewise. (produce_symtab): Update. (produce_asm_for_decls): Update. * ipa-inline-analysis.c (inline_read_section): Update. (inline_write_summary): Update. * ipa-prop.c (ipa_write_node_info): Update. (ipa_prop_read_section): Update. * lto-streamer.h (lto_cgraph_encoder_d): Rename to ... (lto_symtab_encoder_d): ... this one; add initializer. (lto_cgraph_encoder_t): Rename to ... (lto_symtab_encoder_t): ... this one. (lto_cgraph_encoder_size): Rename to ... (lto_symtab_encoder_size): ... this one. (lto_varpool_encoder_d): ... remove. (lto_varpool_encoder_t): Remove. (lto_out_decl_state): Remove cgraph_node_encoder, varpool_node_encoder add symtab_node_encoder. (lto_file_decl_data): Likewise. (lto_cgraph_encoder_deref, lto_cgraph_encoder_lookup, lto_cgraph_encoder_new, lto_cgraph_encoder_encode, lto_cgraph_encoder_delete, lto_cgraph_encoder_encode_body_p, lto_varpool_encoder_encode_body_p, lto_varpool_encoder_deref, lto_varpool_encoder_lookup, lto_varpool_encoder_new, lto_varpool_encoder_encode, lto_varpool_encoder_delete, lto_varpool_encoder_encode_initializer_p): Remove. (lto_symtab_encoder_deref, lto_symtab_encoder_lookup, lto_symtab_encoder_t, lto_symtab_encoder_encode, lto_symtab_encoder_delete, lto_symtab_encoder_encode_body_p, lto_symtab_encoder_encode_initializer_p): New. From-SVN: r190309
This commit is contained in:
parent
46b496e997
commit
7380e6efdd
9 changed files with 354 additions and 436 deletions
|
@ -1,3 +1,84 @@
|
|||
2012-08-11 Jan Hubicka <jh@suse.cz>
|
||||
|
||||
* cgraph.h (vector types for symtab_node): Add.
|
||||
* ipa-reference.c (ipa_reference_write_optimization_summary): Update
|
||||
for new symtab encoder.
|
||||
(ipa_reference_read_optimization_summary): Likewise.
|
||||
* lto-cgraph.c (output_varpool): Remove.
|
||||
(input_cgraph_opt_summary): Take symtab nodes vector as argument.
|
||||
(LTO_cgraph_tags): Rename to ...
|
||||
(LTO_symtab_tags): ... this one; add LTO_symtab_variable.
|
||||
(lto_cgraph_encoder_new): Rename to ...
|
||||
(lto_symtab_encoder_new): ... this on.
|
||||
(lto_cgraph_encoder_encode): Rename to ...
|
||||
(lto_symtab_encoder_encode): ... this one.
|
||||
(lto_cgraph_encoder_delete): Rename to ...
|
||||
(lto_symtab_encoder_delete): ... this one.
|
||||
(lto_cgraph_encoder_deref): Rename to ...
|
||||
(lto_symtab_encoder_deref): ... this one.
|
||||
(lto_cgraph_encoder_encode_body_p): Rename to ...
|
||||
(lto_symtab_encoder_encode_body_p): ... this one.
|
||||
(lto_varpool_encoder_new, lto_varpool_encoder_delete,
|
||||
lto_varpool_encoder_encode, lto_varpool_encoder_lookup,
|
||||
lto_varpool_encoder_deref): Remove.
|
||||
(lto_varpool_encoder_encode_initializer_p): Rename to ...
|
||||
(lto_symtab_encoder_encode_initializer_p): ... this one.
|
||||
(lto_set_varpool_encoder_encode_initializer): Rename to ...
|
||||
(lto_set_symtab_encoder_encode_initializer): ... this one.
|
||||
(lto_output_edge): Update.
|
||||
(lto_output_node): Update.
|
||||
(lto_output_varpool_node): Update; stream out LTO_symtab_variable tag.
|
||||
(lto_output_ref): Drop varpool_encoder; update.
|
||||
(add_node_to): Update.
|
||||
(add_references): Update.
|
||||
(output_outgoing_cgraph_edges): Update.
|
||||
(output_refs): Update.
|
||||
(compute_ltrans_boundary): Update.
|
||||
(output_cgraph): Update; output varpools too.
|
||||
(input_overwrite_node): Update.
|
||||
(output_varpool): Remove.
|
||||
(input_node): Update.
|
||||
(input_ref): Update.
|
||||
(input_edge): Update.
|
||||
(input_cgraph_1): Update; input varpool too; unify fixup code.
|
||||
(input_varpool_1): Remove.
|
||||
(input_refs): Update.
|
||||
(input_cgraph): Update.
|
||||
(output_node_opt_summary): Update.
|
||||
(input_cgraph_opt_section): Update.
|
||||
(input_cgraph_opt_summary): Update.
|
||||
* ipa-pure-const.c (pure_const_write_summary): Update.
|
||||
(pure_const_read_summary): Update.
|
||||
* lto-streamer-out.c (lto_write_tree): Update.
|
||||
(lto_output): Likewise.
|
||||
(produce_symtab): Update.
|
||||
(produce_asm_for_decls): Update.
|
||||
* ipa-inline-analysis.c (inline_read_section): Update.
|
||||
(inline_write_summary): Update.
|
||||
* ipa-prop.c (ipa_write_node_info): Update.
|
||||
(ipa_prop_read_section): Update.
|
||||
* lto-streamer.h (lto_cgraph_encoder_d): Rename to ...
|
||||
(lto_symtab_encoder_d): ... this one; add initializer.
|
||||
(lto_cgraph_encoder_t): Rename to ...
|
||||
(lto_symtab_encoder_t): ... this one.
|
||||
(lto_cgraph_encoder_size): Rename to ...
|
||||
(lto_symtab_encoder_size): ... this one.
|
||||
(lto_varpool_encoder_d): ... remove.
|
||||
(lto_varpool_encoder_t): Remove.
|
||||
(lto_out_decl_state): Remove cgraph_node_encoder, varpool_node_encoder
|
||||
add symtab_node_encoder.
|
||||
(lto_file_decl_data): Likewise.
|
||||
(lto_cgraph_encoder_deref, lto_cgraph_encoder_lookup,
|
||||
lto_cgraph_encoder_new, lto_cgraph_encoder_encode, lto_cgraph_encoder_delete,
|
||||
lto_cgraph_encoder_encode_body_p, lto_varpool_encoder_encode_body_p,
|
||||
lto_varpool_encoder_deref, lto_varpool_encoder_lookup, lto_varpool_encoder_new,
|
||||
lto_varpool_encoder_encode, lto_varpool_encoder_delete,
|
||||
lto_varpool_encoder_encode_initializer_p): Remove.
|
||||
(lto_symtab_encoder_deref, lto_symtab_encoder_lookup,
|
||||
lto_symtab_encoder_t, lto_symtab_encoder_encode, lto_symtab_encoder_delete,
|
||||
lto_symtab_encoder_encode_body_p, lto_symtab_encoder_encode_initializer_p):
|
||||
New.
|
||||
|
||||
2012-08-11 Uros Bizjak <ubizjak@gmail.com>
|
||||
|
||||
* config/i386/i386.md (isa): Add fma and fma4.
|
||||
|
|
|
@ -273,6 +273,10 @@ struct GTY(()) cgraph_node {
|
|||
unsigned tm_clone : 1;
|
||||
};
|
||||
|
||||
DEF_VEC_P(symtab_node);
|
||||
DEF_VEC_ALLOC_P(symtab_node,heap);
|
||||
DEF_VEC_ALLOC_P(symtab_node,gc);
|
||||
|
||||
typedef struct cgraph_node *cgraph_node_ptr;
|
||||
|
||||
DEF_VEC_P(cgraph_node_ptr);
|
||||
|
|
|
@ -3053,13 +3053,13 @@ inline_read_section (struct lto_file_decl_data *file_data, const char *data,
|
|||
unsigned int index;
|
||||
struct cgraph_node *node;
|
||||
struct inline_summary *info;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
struct bitpack_d bp;
|
||||
struct cgraph_edge *e;
|
||||
|
||||
index = streamer_read_uhwi (&ib);
|
||||
encoder = file_data->cgraph_node_encoder;
|
||||
node = lto_cgraph_encoder_deref (encoder, index);
|
||||
encoder = file_data->symtab_node_encoder;
|
||||
node = cgraph (lto_symtab_encoder_deref (encoder, index));
|
||||
info = inline_summary (node);
|
||||
|
||||
info->estimated_stack_size
|
||||
|
@ -3186,20 +3186,22 @@ inline_write_summary (cgraph_node_set set,
|
|||
varpool_node_set vset ATTRIBUTE_UNUSED)
|
||||
{
|
||||
struct cgraph_node *node;
|
||||
symtab_node snode;
|
||||
struct output_block *ob = create_output_block (LTO_section_inline_summary);
|
||||
lto_cgraph_encoder_t encoder = ob->decl_state->cgraph_node_encoder;
|
||||
lto_symtab_encoder_t encoder = ob->decl_state->symtab_node_encoder;
|
||||
unsigned int count = 0;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < lto_cgraph_encoder_size (encoder); i++)
|
||||
if (lto_cgraph_encoder_deref (encoder, i)->analyzed)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
if (symtab_function_p (snode = lto_symtab_encoder_deref (encoder, i))
|
||||
&& cgraph (snode)->analyzed)
|
||||
count++;
|
||||
streamer_write_uhwi (ob, count);
|
||||
|
||||
for (i = 0; i < lto_cgraph_encoder_size (encoder); i++)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
{
|
||||
node = lto_cgraph_encoder_deref (encoder, i);
|
||||
if (node->analyzed)
|
||||
if (symtab_function_p (snode = lto_symtab_encoder_deref (encoder, i))
|
||||
&& (node = cgraph (snode))->analyzed)
|
||||
{
|
||||
struct inline_summary *info = inline_summary (node);
|
||||
struct bitpack_d bp;
|
||||
|
@ -3208,7 +3210,7 @@ inline_write_summary (cgraph_node_set set,
|
|||
size_time_entry *e;
|
||||
struct condition *c;
|
||||
|
||||
streamer_write_uhwi (ob, lto_cgraph_encoder_encode (encoder, node));
|
||||
streamer_write_uhwi (ob, lto_symtab_encoder_encode (encoder, (symtab_node)node));
|
||||
streamer_write_hwi (ob, info->estimated_self_stack_size);
|
||||
streamer_write_hwi (ob, info->self_size);
|
||||
streamer_write_hwi (ob, info->self_time);
|
||||
|
|
|
@ -3303,14 +3303,14 @@ static void
|
|||
ipa_write_node_info (struct output_block *ob, struct cgraph_node *node)
|
||||
{
|
||||
int node_ref;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
struct ipa_node_params *info = IPA_NODE_REF (node);
|
||||
int j;
|
||||
struct cgraph_edge *e;
|
||||
struct bitpack_d bp;
|
||||
|
||||
encoder = ob->decl_state->cgraph_node_encoder;
|
||||
node_ref = lto_cgraph_encoder_encode (encoder, node);
|
||||
encoder = ob->decl_state->symtab_node_encoder;
|
||||
node_ref = lto_symtab_encoder_encode (encoder, (symtab_node) node);
|
||||
streamer_write_uhwi (ob, node_ref);
|
||||
|
||||
bp = bitpack_create (ob->main_stream);
|
||||
|
@ -3454,11 +3454,11 @@ ipa_prop_read_section (struct lto_file_decl_data *file_data, const char *data,
|
|||
{
|
||||
unsigned int index;
|
||||
struct cgraph_node *node;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
|
||||
index = streamer_read_uhwi (&ib_main);
|
||||
encoder = file_data->cgraph_node_encoder;
|
||||
node = lto_cgraph_encoder_deref (encoder, index);
|
||||
encoder = file_data->symtab_node_encoder;
|
||||
node = cgraph (lto_symtab_encoder_deref (encoder, index));
|
||||
gcc_assert (node->analyzed);
|
||||
ipa_read_node_info (&ib_main, node, data_in);
|
||||
}
|
||||
|
|
|
@ -962,12 +962,12 @@ pure_const_write_summary (cgraph_node_set set,
|
|||
struct bitpack_d bp;
|
||||
funct_state fs;
|
||||
int node_ref;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
|
||||
fs = get_function_state (node);
|
||||
|
||||
encoder = ob->decl_state->cgraph_node_encoder;
|
||||
node_ref = lto_cgraph_encoder_encode (encoder, node);
|
||||
encoder = ob->decl_state->symtab_node_encoder;
|
||||
node_ref = lto_symtab_encoder_encode (encoder, (symtab_node)node);
|
||||
streamer_write_uhwi_stream (ob->main_stream, node_ref);
|
||||
|
||||
/* Note that flags will need to be read in the opposite
|
||||
|
@ -1015,12 +1015,12 @@ pure_const_read_summary (void)
|
|||
struct cgraph_node *node;
|
||||
struct bitpack_d bp;
|
||||
funct_state fs;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
|
||||
fs = XCNEW (struct funct_state_d);
|
||||
index = streamer_read_uhwi (ib);
|
||||
encoder = file_data->cgraph_node_encoder;
|
||||
node = lto_cgraph_encoder_deref (encoder, index);
|
||||
encoder = file_data->symtab_node_encoder;
|
||||
node = cgraph (lto_symtab_encoder_deref (encoder, index));
|
||||
set_function_state (node, fs);
|
||||
|
||||
/* Note that the flags must be read in the opposite
|
||||
|
|
|
@ -1029,21 +1029,25 @@ ipa_reference_write_optimization_summary (cgraph_node_set set,
|
|||
varpool_node_set vset)
|
||||
{
|
||||
struct cgraph_node *node;
|
||||
symtab_node snode;
|
||||
struct lto_simple_output_block *ob
|
||||
= lto_create_simple_output_block (LTO_section_ipa_reference);
|
||||
unsigned int count = 0;
|
||||
int ltrans_statics_bitcount = 0;
|
||||
lto_cgraph_encoder_t encoder = ob->decl_state->cgraph_node_encoder;
|
||||
lto_varpool_encoder_t varpool_encoder = ob->decl_state->varpool_node_encoder;
|
||||
lto_symtab_encoder_t encoder = ob->decl_state->symtab_node_encoder;
|
||||
bitmap ltrans_statics = BITMAP_ALLOC (NULL);
|
||||
int i;
|
||||
|
||||
reference_vars_to_consider = splay_tree_new (splay_tree_compare_ints, 0, 0);
|
||||
|
||||
/* See what variables we are interested in. */
|
||||
for (i = 0; i < lto_varpool_encoder_size (varpool_encoder); i++)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
{
|
||||
struct varpool_node *vnode = lto_varpool_encoder_deref (varpool_encoder, i);
|
||||
struct varpool_node *vnode;
|
||||
snode = lto_symtab_encoder_deref (encoder, i);
|
||||
if (!symtab_variable_p (snode))
|
||||
continue;
|
||||
vnode = varpool (snode);
|
||||
if (bitmap_bit_p (all_module_statics, DECL_UID (vnode->symbol.decl))
|
||||
&& referenced_from_this_partition_p (&vnode->symbol.ref_list, set, vset))
|
||||
{
|
||||
|
@ -1057,8 +1061,9 @@ ipa_reference_write_optimization_summary (cgraph_node_set set,
|
|||
|
||||
|
||||
if (ltrans_statics_bitcount)
|
||||
for (i = 0; i < lto_cgraph_encoder_size (encoder); i++)
|
||||
if (write_node_summary_p (lto_cgraph_encoder_deref (encoder, i),
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
if (symtab_function_p (snode = lto_symtab_encoder_deref (encoder, i))
|
||||
&& write_node_summary_p (cgraph (snode),
|
||||
set, vset, ltrans_statics))
|
||||
count++;
|
||||
|
||||
|
@ -1069,16 +1074,19 @@ ipa_reference_write_optimization_summary (cgraph_node_set set,
|
|||
|
||||
/* Process all of the functions. */
|
||||
if (ltrans_statics_bitcount)
|
||||
for (i = 0; i < lto_cgraph_encoder_size (encoder); i++)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
{
|
||||
node = lto_cgraph_encoder_deref (encoder, i);
|
||||
snode = lto_symtab_encoder_deref (encoder, i);
|
||||
if (!symtab_function_p (snode))
|
||||
continue;
|
||||
node = cgraph (snode);
|
||||
if (write_node_summary_p (node, set, vset, ltrans_statics))
|
||||
{
|
||||
ipa_reference_optimization_summary_t info;
|
||||
int node_ref;
|
||||
|
||||
info = get_reference_optimization_summary (node);
|
||||
node_ref = lto_cgraph_encoder_encode (encoder, node);
|
||||
node_ref = lto_symtab_encoder_encode (encoder, (symtab_node) node);
|
||||
streamer_write_uhwi_stream (ob->main_stream, node_ref);
|
||||
|
||||
stream_out_bitmap (ob, info->statics_not_read, ltrans_statics,
|
||||
|
@ -1144,11 +1152,11 @@ ipa_reference_read_optimization_summary (void)
|
|||
struct cgraph_node *node;
|
||||
ipa_reference_optimization_summary_t info;
|
||||
int v_count;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
|
||||
index = streamer_read_uhwi (ib);
|
||||
encoder = file_data->cgraph_node_encoder;
|
||||
node = lto_cgraph_encoder_deref (encoder, index);
|
||||
encoder = file_data->symtab_node_encoder;
|
||||
node = cgraph (lto_symtab_encoder_deref (encoder, index));
|
||||
info = XCNEW (struct ipa_reference_optimization_summary_d);
|
||||
set_reference_optimization_summary (node, info);
|
||||
info->statics_not_read = BITMAP_ALLOC (&optimization_summary_obstack);
|
||||
|
|
514
gcc/lto-cgraph.c
514
gcc/lto-cgraph.c
|
@ -46,9 +46,8 @@ along with GCC; see the file COPYING3. If not see
|
|||
#include "tree-streamer.h"
|
||||
#include "gcov-io.h"
|
||||
|
||||
static void output_varpool (cgraph_node_set, varpool_node_set);
|
||||
static void output_cgraph_opt_summary (cgraph_node_set set);
|
||||
static void input_cgraph_opt_summary (VEC (cgraph_node_ptr, heap) * nodes);
|
||||
static void input_cgraph_opt_summary (VEC (symtab_node, heap) * nodes);
|
||||
|
||||
/* Number of LDPR values known to GCC. */
|
||||
#define LDPR_NUM_KNOWN (LDPR_PREVAILING_DEF_IRONLY_EXP + 1)
|
||||
|
@ -58,29 +57,31 @@ static int order_base;
|
|||
|
||||
/* Cgraph streaming is organized as set of record whose type
|
||||
is indicated by a tag. */
|
||||
enum LTO_cgraph_tags
|
||||
enum LTO_symtab_tags
|
||||
{
|
||||
/* Must leave 0 for the stopper. */
|
||||
|
||||
/* Cgraph node without body available. */
|
||||
LTO_cgraph_unavail_node = 1,
|
||||
LTO_symtab_unavail_node = 1,
|
||||
/* Cgraph node with function body. */
|
||||
LTO_cgraph_analyzed_node,
|
||||
LTO_symtab_analyzed_node,
|
||||
/* Cgraph edges. */
|
||||
LTO_cgraph_edge,
|
||||
LTO_cgraph_indirect_edge,
|
||||
LTO_cgraph_last_tag
|
||||
LTO_symtab_edge,
|
||||
LTO_symtab_indirect_edge,
|
||||
LTO_symtab_variable,
|
||||
LTO_symtab_last_tag
|
||||
};
|
||||
|
||||
/* Create a new cgraph encoder. */
|
||||
/* Create a new symtab encoder. */
|
||||
|
||||
lto_cgraph_encoder_t
|
||||
lto_cgraph_encoder_new (void)
|
||||
lto_symtab_encoder_t
|
||||
lto_symtab_encoder_new (void)
|
||||
{
|
||||
lto_cgraph_encoder_t encoder = XCNEW (struct lto_cgraph_encoder_d);
|
||||
lto_symtab_encoder_t encoder = XCNEW (struct lto_symtab_encoder_d);
|
||||
encoder->map = pointer_map_create ();
|
||||
encoder->nodes = NULL;
|
||||
encoder->body = pointer_set_create ();
|
||||
encoder->initializer = pointer_set_create ();
|
||||
return encoder;
|
||||
}
|
||||
|
||||
|
@ -88,22 +89,23 @@ lto_cgraph_encoder_new (void)
|
|||
/* Delete ENCODER and its components. */
|
||||
|
||||
void
|
||||
lto_cgraph_encoder_delete (lto_cgraph_encoder_t encoder)
|
||||
lto_symtab_encoder_delete (lto_symtab_encoder_t encoder)
|
||||
{
|
||||
VEC_free (cgraph_node_ptr, heap, encoder->nodes);
|
||||
VEC_free (symtab_node, heap, encoder->nodes);
|
||||
pointer_map_destroy (encoder->map);
|
||||
pointer_set_destroy (encoder->body);
|
||||
pointer_set_destroy (encoder->initializer);
|
||||
free (encoder);
|
||||
}
|
||||
|
||||
|
||||
/* Return the existing reference number of NODE in the cgraph encoder in
|
||||
/* Return the existing reference number of NODE in the symtab encoder in
|
||||
output block OB. Assign a new reference if this is the first time
|
||||
NODE is encoded. */
|
||||
|
||||
int
|
||||
lto_cgraph_encoder_encode (lto_cgraph_encoder_t encoder,
|
||||
struct cgraph_node *node)
|
||||
lto_symtab_encoder_encode (lto_symtab_encoder_t encoder,
|
||||
symtab_node node)
|
||||
{
|
||||
int ref;
|
||||
void **slot;
|
||||
|
@ -111,10 +113,10 @@ lto_cgraph_encoder_encode (lto_cgraph_encoder_t encoder,
|
|||
slot = pointer_map_contains (encoder->map, node);
|
||||
if (!slot)
|
||||
{
|
||||
ref = VEC_length (cgraph_node_ptr, encoder->nodes);
|
||||
ref = VEC_length (symtab_node, encoder->nodes);
|
||||
slot = pointer_map_insert (encoder->map, node);
|
||||
*slot = (void *) (intptr_t) ref;
|
||||
VEC_safe_push (cgraph_node_ptr, heap, encoder->nodes, node);
|
||||
VEC_safe_push (symtab_node, heap, encoder->nodes, node);
|
||||
}
|
||||
else
|
||||
ref = (int) (intptr_t) *slot;
|
||||
|
@ -128,8 +130,8 @@ lto_cgraph_encoder_encode (lto_cgraph_encoder_t encoder,
|
|||
or LCC_NOT_FOUND if it is not there. */
|
||||
|
||||
int
|
||||
lto_cgraph_encoder_lookup (lto_cgraph_encoder_t encoder,
|
||||
struct cgraph_node *node)
|
||||
lto_symtab_encoder_lookup (lto_symtab_encoder_t encoder,
|
||||
symtab_node node)
|
||||
{
|
||||
void **slot = pointer_map_contains (encoder->map, node);
|
||||
return (slot ? (int) (intptr_t) *slot : LCC_NOT_FOUND);
|
||||
|
@ -138,20 +140,20 @@ lto_cgraph_encoder_lookup (lto_cgraph_encoder_t encoder,
|
|||
|
||||
/* Return the cgraph node corresponding to REF using ENCODER. */
|
||||
|
||||
struct cgraph_node *
|
||||
lto_cgraph_encoder_deref (lto_cgraph_encoder_t encoder, int ref)
|
||||
symtab_node
|
||||
lto_symtab_encoder_deref (lto_symtab_encoder_t encoder, int ref)
|
||||
{
|
||||
if (ref == LCC_NOT_FOUND)
|
||||
return NULL;
|
||||
|
||||
return VEC_index (cgraph_node_ptr, encoder->nodes, ref);
|
||||
return VEC_index (symtab_node, encoder->nodes, ref);
|
||||
}
|
||||
|
||||
|
||||
/* Return TRUE if we should encode initializer of NODE (if any). */
|
||||
|
||||
bool
|
||||
lto_cgraph_encoder_encode_body_p (lto_cgraph_encoder_t encoder,
|
||||
lto_symtab_encoder_encode_body_p (lto_symtab_encoder_t encoder,
|
||||
struct cgraph_node *node)
|
||||
{
|
||||
return pointer_set_contains (encoder->body, node);
|
||||
|
@ -160,91 +162,17 @@ lto_cgraph_encoder_encode_body_p (lto_cgraph_encoder_t encoder,
|
|||
/* Return TRUE if we should encode body of NODE (if any). */
|
||||
|
||||
static void
|
||||
lto_set_cgraph_encoder_encode_body (lto_cgraph_encoder_t encoder,
|
||||
lto_set_symtab_encoder_encode_body (lto_symtab_encoder_t encoder,
|
||||
struct cgraph_node *node)
|
||||
{
|
||||
pointer_set_insert (encoder->body, node);
|
||||
}
|
||||
|
||||
/* Create a new varpool encoder. */
|
||||
|
||||
lto_varpool_encoder_t
|
||||
lto_varpool_encoder_new (void)
|
||||
{
|
||||
lto_varpool_encoder_t encoder = XCNEW (struct lto_varpool_encoder_d);
|
||||
encoder->map = pointer_map_create ();
|
||||
encoder->initializer = pointer_set_create ();
|
||||
encoder->nodes = NULL;
|
||||
return encoder;
|
||||
}
|
||||
|
||||
|
||||
/* Delete ENCODER and its components. */
|
||||
|
||||
void
|
||||
lto_varpool_encoder_delete (lto_varpool_encoder_t encoder)
|
||||
{
|
||||
VEC_free (varpool_node_ptr, heap, encoder->nodes);
|
||||
pointer_map_destroy (encoder->map);
|
||||
pointer_set_destroy (encoder->initializer);
|
||||
free (encoder);
|
||||
}
|
||||
|
||||
|
||||
/* Return the existing reference number of NODE in the varpool encoder in
|
||||
output block OB. Assign a new reference if this is the first time
|
||||
NODE is encoded. */
|
||||
|
||||
int
|
||||
lto_varpool_encoder_encode (lto_varpool_encoder_t encoder,
|
||||
struct varpool_node *node)
|
||||
{
|
||||
int ref;
|
||||
void **slot;
|
||||
|
||||
slot = pointer_map_contains (encoder->map, node);
|
||||
if (!slot)
|
||||
{
|
||||
ref = VEC_length (varpool_node_ptr, encoder->nodes);
|
||||
slot = pointer_map_insert (encoder->map, node);
|
||||
*slot = (void *) (intptr_t) ref;
|
||||
VEC_safe_push (varpool_node_ptr, heap, encoder->nodes, node);
|
||||
}
|
||||
else
|
||||
ref = (int) (intptr_t) *slot;
|
||||
|
||||
return ref;
|
||||
}
|
||||
|
||||
/* Look up NODE in encoder. Return NODE's reference if it has been encoded
|
||||
or LCC_NOT_FOUND if it is not there. */
|
||||
|
||||
int
|
||||
lto_varpool_encoder_lookup (lto_varpool_encoder_t encoder,
|
||||
struct varpool_node *node)
|
||||
{
|
||||
void **slot = pointer_map_contains (encoder->map, node);
|
||||
return (slot ? (int) (intptr_t) *slot : LCC_NOT_FOUND);
|
||||
}
|
||||
|
||||
|
||||
/* Return the varpool node corresponding to REF using ENCODER. */
|
||||
|
||||
struct varpool_node *
|
||||
lto_varpool_encoder_deref (lto_varpool_encoder_t encoder, int ref)
|
||||
{
|
||||
if (ref == LCC_NOT_FOUND)
|
||||
return NULL;
|
||||
|
||||
return VEC_index (varpool_node_ptr, encoder->nodes, ref);
|
||||
}
|
||||
|
||||
|
||||
/* Return TRUE if we should encode initializer of NODE (if any). */
|
||||
|
||||
bool
|
||||
lto_varpool_encoder_encode_initializer_p (lto_varpool_encoder_t encoder,
|
||||
struct varpool_node *node)
|
||||
lto_symtab_encoder_encode_initializer_p (lto_symtab_encoder_t encoder,
|
||||
struct varpool_node *node)
|
||||
{
|
||||
return pointer_set_contains (encoder->initializer, node);
|
||||
}
|
||||
|
@ -252,8 +180,8 @@ lto_varpool_encoder_encode_initializer_p (lto_varpool_encoder_t encoder,
|
|||
/* Return TRUE if we should encode initializer of NODE (if any). */
|
||||
|
||||
static void
|
||||
lto_set_varpool_encoder_encode_initializer (lto_varpool_encoder_t encoder,
|
||||
struct varpool_node *node)
|
||||
lto_set_symtab_encoder_encode_initializer (lto_symtab_encoder_t encoder,
|
||||
struct varpool_node *node)
|
||||
{
|
||||
pointer_set_insert (encoder->initializer, node);
|
||||
}
|
||||
|
@ -262,26 +190,26 @@ lto_set_varpool_encoder_encode_initializer (lto_varpool_encoder_t encoder,
|
|||
|
||||
static void
|
||||
lto_output_edge (struct lto_simple_output_block *ob, struct cgraph_edge *edge,
|
||||
lto_cgraph_encoder_t encoder)
|
||||
lto_symtab_encoder_t encoder)
|
||||
{
|
||||
unsigned int uid;
|
||||
intptr_t ref;
|
||||
struct bitpack_d bp;
|
||||
|
||||
if (edge->indirect_unknown_callee)
|
||||
streamer_write_enum (ob->main_stream, LTO_cgraph_tags, LTO_cgraph_last_tag,
|
||||
LTO_cgraph_indirect_edge);
|
||||
streamer_write_enum (ob->main_stream, LTO_symtab_tags, LTO_symtab_last_tag,
|
||||
LTO_symtab_indirect_edge);
|
||||
else
|
||||
streamer_write_enum (ob->main_stream, LTO_cgraph_tags, LTO_cgraph_last_tag,
|
||||
LTO_cgraph_edge);
|
||||
streamer_write_enum (ob->main_stream, LTO_symtab_tags, LTO_symtab_last_tag,
|
||||
LTO_symtab_edge);
|
||||
|
||||
ref = lto_cgraph_encoder_lookup (encoder, edge->caller);
|
||||
ref = lto_symtab_encoder_lookup (encoder, (symtab_node)edge->caller);
|
||||
gcc_assert (ref != LCC_NOT_FOUND);
|
||||
streamer_write_hwi_stream (ob->main_stream, ref);
|
||||
|
||||
if (!edge->indirect_unknown_callee)
|
||||
{
|
||||
ref = lto_cgraph_encoder_lookup (encoder, edge->callee);
|
||||
ref = lto_symtab_encoder_lookup (encoder, (symtab_node)edge->callee);
|
||||
gcc_assert (ref != LCC_NOT_FOUND);
|
||||
streamer_write_hwi_stream (ob->main_stream, ref);
|
||||
}
|
||||
|
@ -408,7 +336,7 @@ reachable_from_this_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,
|
||||
lto_symtab_encoder_t encoder, cgraph_node_set set,
|
||||
varpool_node_set vset)
|
||||
{
|
||||
unsigned int tag;
|
||||
|
@ -421,11 +349,11 @@ lto_output_node (struct lto_simple_output_block *ob, struct cgraph_node *node,
|
|||
boundary_p = !cgraph_node_in_set_p (node, set);
|
||||
|
||||
if (node->analyzed && !boundary_p)
|
||||
tag = LTO_cgraph_analyzed_node;
|
||||
tag = LTO_symtab_analyzed_node;
|
||||
else
|
||||
tag = LTO_cgraph_unavail_node;
|
||||
tag = LTO_symtab_unavail_node;
|
||||
|
||||
streamer_write_enum (ob->main_stream, LTO_cgraph_tags, LTO_cgraph_last_tag,
|
||||
streamer_write_enum (ob->main_stream, LTO_symtab_tags, LTO_symtab_last_tag,
|
||||
tag);
|
||||
streamer_write_hwi_stream (ob->main_stream, node->symbol.order);
|
||||
|
||||
|
@ -454,13 +382,13 @@ lto_output_node (struct lto_simple_output_block *ob, struct cgraph_node *node,
|
|||
|
||||
clone_of = node->clone_of;
|
||||
while (clone_of
|
||||
&& (ref = lto_cgraph_encoder_lookup (encoder, clone_of)) == LCC_NOT_FOUND)
|
||||
&& (ref = lto_symtab_encoder_lookup (encoder, (symtab_node)clone_of)) == LCC_NOT_FOUND)
|
||||
if (clone_of->prev_sibling_clone)
|
||||
clone_of = clone_of->prev_sibling_clone;
|
||||
else
|
||||
clone_of = clone_of->clone_of;
|
||||
|
||||
if (LTO_cgraph_analyzed_node)
|
||||
if (LTO_symtab_analyzed_node)
|
||||
gcc_assert (clone_of || !node->clone_of);
|
||||
if (!clone_of)
|
||||
streamer_write_hwi_stream (ob->main_stream, LCC_NOT_FOUND);
|
||||
|
@ -472,11 +400,11 @@ lto_output_node (struct lto_simple_output_block *ob, struct cgraph_node *node,
|
|||
streamer_write_hwi_stream (ob->main_stream, node->count);
|
||||
streamer_write_hwi_stream (ob->main_stream, node->count_materialization_scale);
|
||||
|
||||
if (tag == LTO_cgraph_analyzed_node)
|
||||
if (tag == LTO_symtab_analyzed_node)
|
||||
{
|
||||
if (node->global.inlined_to)
|
||||
{
|
||||
ref = lto_cgraph_encoder_lookup (encoder, node->global.inlined_to);
|
||||
ref = lto_symtab_encoder_lookup (encoder, (symtab_node)node->global.inlined_to);
|
||||
gcc_assert (ref != LCC_NOT_FOUND);
|
||||
}
|
||||
else
|
||||
|
@ -487,8 +415,8 @@ lto_output_node (struct lto_simple_output_block *ob, struct cgraph_node *node,
|
|||
|
||||
if (node->symbol.same_comdat_group && !boundary_p)
|
||||
{
|
||||
ref = lto_cgraph_encoder_lookup (encoder,
|
||||
cgraph (node->symbol.same_comdat_group));
|
||||
ref = lto_symtab_encoder_lookup (encoder,
|
||||
node->symbol.same_comdat_group);
|
||||
gcc_assert (ref != LCC_NOT_FOUND);
|
||||
}
|
||||
else
|
||||
|
@ -505,7 +433,7 @@ lto_output_node (struct lto_simple_output_block *ob, struct cgraph_node *node,
|
|||
bp_pack_value (&bp, node->symbol.force_output, 1);
|
||||
bp_pack_value (&bp, node->symbol.address_taken, 1);
|
||||
bp_pack_value (&bp, node->abstract_and_needed, 1);
|
||||
bp_pack_value (&bp, tag == LTO_cgraph_analyzed_node
|
||||
bp_pack_value (&bp, tag == LTO_symtab_analyzed_node
|
||||
&& !DECL_EXTERNAL (node->symbol.decl)
|
||||
&& !DECL_COMDAT (node->symbol.decl)
|
||||
&& (reachable_from_other_partition_p (node, set)
|
||||
|
@ -554,13 +482,15 @@ lto_output_node (struct lto_simple_output_block *ob, struct cgraph_node *node,
|
|||
|
||||
static void
|
||||
lto_output_varpool_node (struct lto_simple_output_block *ob, struct varpool_node *node,
|
||||
lto_varpool_encoder_t varpool_encoder,
|
||||
lto_symtab_encoder_t encoder,
|
||||
cgraph_node_set set, varpool_node_set vset)
|
||||
{
|
||||
bool boundary_p = !varpool_node_in_set_p (node, vset) && node->analyzed;
|
||||
struct bitpack_d bp;
|
||||
int ref;
|
||||
|
||||
streamer_write_enum (ob->main_stream, LTO_symtab_tags, LTO_symtab_last_tag,
|
||||
LTO_symtab_variable);
|
||||
streamer_write_hwi_stream (ob->main_stream, node->symbol.order);
|
||||
lto_output_var_decl_index (ob->decl_state, ob->main_stream, node->symbol.decl);
|
||||
bp = bitpack_create (ob->main_stream);
|
||||
|
@ -593,8 +523,8 @@ lto_output_varpool_node (struct lto_simple_output_block *ob, struct varpool_node
|
|||
lto_output_var_decl_index (ob->decl_state, ob->main_stream, node->alias_of);
|
||||
if (node->symbol.same_comdat_group && !boundary_p)
|
||||
{
|
||||
ref = lto_varpool_encoder_lookup (varpool_encoder,
|
||||
varpool (node->symbol.same_comdat_group));
|
||||
ref = lto_symtab_encoder_lookup (encoder,
|
||||
node->symbol.same_comdat_group);
|
||||
gcc_assert (ref != LCC_NOT_FOUND);
|
||||
}
|
||||
else
|
||||
|
@ -609,27 +539,17 @@ lto_output_varpool_node (struct lto_simple_output_block *ob, struct varpool_node
|
|||
|
||||
static void
|
||||
lto_output_ref (struct lto_simple_output_block *ob, struct ipa_ref *ref,
|
||||
lto_cgraph_encoder_t encoder,
|
||||
lto_varpool_encoder_t varpool_encoder)
|
||||
lto_symtab_encoder_t encoder)
|
||||
{
|
||||
struct bitpack_d bp;
|
||||
int nref;
|
||||
|
||||
bp = bitpack_create (ob->main_stream);
|
||||
bp_pack_value (&bp, symtab_function_p (ref->referred), 1);
|
||||
bp_pack_value (&bp, ref->use, 2);
|
||||
streamer_write_bitpack (&bp);
|
||||
if (symtab_function_p (ref->referred))
|
||||
{
|
||||
int nref = lto_cgraph_encoder_lookup (encoder, ipa_ref_node (ref));
|
||||
gcc_assert (nref != LCC_NOT_FOUND);
|
||||
streamer_write_hwi_stream (ob->main_stream, nref);
|
||||
}
|
||||
else
|
||||
{
|
||||
int nref = lto_varpool_encoder_lookup (varpool_encoder,
|
||||
ipa_ref_varpool_node (ref));
|
||||
gcc_assert (nref != LCC_NOT_FOUND);
|
||||
streamer_write_hwi_stream (ob->main_stream, nref);
|
||||
}
|
||||
nref = lto_symtab_encoder_lookup (encoder, ref->referred);
|
||||
gcc_assert (nref != LCC_NOT_FOUND);
|
||||
streamer_write_hwi_stream (ob->main_stream, nref);
|
||||
}
|
||||
|
||||
/* Stream out profile_summary to OB. */
|
||||
|
@ -654,21 +574,20 @@ output_profile_summary (struct lto_simple_output_block *ob)
|
|||
Do it in a way so clones appear first. */
|
||||
|
||||
static void
|
||||
add_node_to (lto_cgraph_encoder_t encoder, struct cgraph_node *node,
|
||||
add_node_to (lto_symtab_encoder_t encoder, struct cgraph_node *node,
|
||||
bool include_body)
|
||||
{
|
||||
if (node->clone_of)
|
||||
add_node_to (encoder, node->clone_of, include_body);
|
||||
else if (include_body)
|
||||
lto_set_cgraph_encoder_encode_body (encoder, node);
|
||||
lto_cgraph_encoder_encode (encoder, node);
|
||||
lto_set_symtab_encoder_encode_body (encoder, node);
|
||||
lto_symtab_encoder_encode (encoder, (symtab_node)node);
|
||||
}
|
||||
|
||||
/* Add all references in LIST to encoders. */
|
||||
|
||||
static void
|
||||
add_references (lto_cgraph_encoder_t encoder,
|
||||
lto_varpool_encoder_t varpool_encoder,
|
||||
add_references (lto_symtab_encoder_t encoder,
|
||||
struct ipa_ref_list *list)
|
||||
{
|
||||
int i;
|
||||
|
@ -679,7 +598,7 @@ add_references (lto_cgraph_encoder_t encoder,
|
|||
else
|
||||
{
|
||||
struct varpool_node *vnode = ipa_ref_varpool_node (ref);
|
||||
lto_varpool_encoder_encode (varpool_encoder, vnode);
|
||||
lto_symtab_encoder_encode (encoder, (symtab_node)vnode);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -689,7 +608,7 @@ add_references (lto_cgraph_encoder_t encoder,
|
|||
static void
|
||||
output_outgoing_cgraph_edges (struct cgraph_edge *edge,
|
||||
struct lto_simple_output_block *ob,
|
||||
lto_cgraph_encoder_t encoder)
|
||||
lto_symtab_encoder_t encoder)
|
||||
{
|
||||
if (!edge)
|
||||
return;
|
||||
|
@ -706,8 +625,7 @@ output_outgoing_cgraph_edges (struct cgraph_edge *edge,
|
|||
|
||||
static void
|
||||
output_refs (cgraph_node_set set, varpool_node_set vset,
|
||||
lto_cgraph_encoder_t encoder,
|
||||
lto_varpool_encoder_t varpool_encoder)
|
||||
lto_symtab_encoder_t encoder)
|
||||
{
|
||||
cgraph_node_set_iterator csi;
|
||||
varpool_node_set_iterator vsi;
|
||||
|
@ -727,10 +645,11 @@ output_refs (cgraph_node_set set, varpool_node_set vset,
|
|||
{
|
||||
streamer_write_uhwi_stream (ob->main_stream, count);
|
||||
streamer_write_uhwi_stream (ob->main_stream,
|
||||
lto_cgraph_encoder_lookup (encoder, node));
|
||||
lto_symtab_encoder_lookup (encoder,
|
||||
(symtab_node)node));
|
||||
for (i = 0; ipa_ref_list_reference_iterate (&node->symbol.ref_list,
|
||||
i, ref); i++)
|
||||
lto_output_ref (ob, ref, encoder, varpool_encoder);
|
||||
lto_output_ref (ob, ref, encoder);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -745,11 +664,11 @@ output_refs (cgraph_node_set set, varpool_node_set vset,
|
|||
{
|
||||
streamer_write_uhwi_stream (ob->main_stream, count);
|
||||
streamer_write_uhwi_stream (ob->main_stream,
|
||||
lto_varpool_encoder_lookup (varpool_encoder,
|
||||
node));
|
||||
lto_symtab_encoder_lookup (encoder,
|
||||
(symtab_node)node));
|
||||
for (i = 0; ipa_ref_list_reference_iterate (&node->symbol.ref_list,
|
||||
i, ref); i++)
|
||||
lto_output_ref (ob, ref, encoder, varpool_encoder);
|
||||
lto_output_ref (ob, ref, encoder);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -769,43 +688,45 @@ compute_ltrans_boundary (struct lto_out_decl_state *state,
|
|||
varpool_node_set_iterator vsi;
|
||||
struct cgraph_edge *edge;
|
||||
int i;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_varpool_encoder_t varpool_encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
|
||||
encoder = state->cgraph_node_encoder = lto_cgraph_encoder_new ();
|
||||
varpool_encoder = state->varpool_node_encoder = lto_varpool_encoder_new ();
|
||||
encoder = state->symtab_node_encoder = lto_symtab_encoder_new ();
|
||||
|
||||
/* Go over all the nodes in SET and assign references. */
|
||||
for (csi = csi_start (set); !csi_end_p (csi); csi_next (&csi))
|
||||
{
|
||||
node = csi_node (csi);
|
||||
add_node_to (encoder, node, true);
|
||||
add_references (encoder, varpool_encoder, &node->symbol.ref_list);
|
||||
add_references (encoder, &node->symbol.ref_list);
|
||||
}
|
||||
for (vsi = vsi_start (vset); !vsi_end_p (vsi); vsi_next (&vsi))
|
||||
{
|
||||
struct varpool_node *vnode = vsi_node (vsi);
|
||||
gcc_assert (!vnode->alias || vnode->alias_of);
|
||||
lto_varpool_encoder_encode (varpool_encoder, vnode);
|
||||
lto_set_varpool_encoder_encode_initializer (varpool_encoder, vnode);
|
||||
add_references (encoder, varpool_encoder, &vnode->symbol.ref_list);
|
||||
lto_symtab_encoder_encode (encoder, (symtab_node)vnode);
|
||||
lto_set_symtab_encoder_encode_initializer (encoder, vnode);
|
||||
add_references (encoder, &vnode->symbol.ref_list);
|
||||
}
|
||||
/* Pickle in also the initializer of all referenced readonly variables
|
||||
to help folding. Constant pool variables are not shared, so we must
|
||||
pickle those too. */
|
||||
for (i = 0; i < lto_varpool_encoder_size (varpool_encoder); i++)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
{
|
||||
struct varpool_node *vnode = lto_varpool_encoder_deref (varpool_encoder, i);
|
||||
if (DECL_INITIAL (vnode->symbol.decl)
|
||||
&& !lto_varpool_encoder_encode_initializer_p (varpool_encoder,
|
||||
vnode)
|
||||
&& const_value_known_p (vnode->symbol.decl))
|
||||
symtab_node node = lto_symtab_encoder_deref (encoder, i);
|
||||
if (symtab_variable_p (node))
|
||||
{
|
||||
lto_set_varpool_encoder_encode_initializer (varpool_encoder, vnode);
|
||||
add_references (encoder, varpool_encoder, &vnode->symbol.ref_list);
|
||||
}
|
||||
else if (vnode->alias || vnode->alias_of)
|
||||
add_references (encoder, varpool_encoder, &vnode->symbol.ref_list);
|
||||
struct varpool_node *vnode = varpool (node);
|
||||
if (DECL_INITIAL (vnode->symbol.decl)
|
||||
&& !lto_symtab_encoder_encode_initializer_p (encoder,
|
||||
vnode)
|
||||
&& const_value_known_p (vnode->symbol.decl))
|
||||
{
|
||||
lto_set_symtab_encoder_encode_initializer (encoder, vnode);
|
||||
add_references (encoder, &vnode->symbol.ref_list);
|
||||
}
|
||||
else if (vnode->alias || vnode->alias_of)
|
||||
add_references (encoder, &vnode->symbol.ref_list);
|
||||
}
|
||||
}
|
||||
|
||||
/* Go over all the nodes again to include callees that are not in
|
||||
|
@ -835,8 +756,7 @@ output_cgraph (cgraph_node_set set, varpool_node_set vset)
|
|||
struct lto_simple_output_block *ob;
|
||||
cgraph_node_set_iterator csi;
|
||||
int i, n_nodes;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_varpool_encoder_t varpool_encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
static bool asm_nodes_output = false;
|
||||
|
||||
if (flag_wpa)
|
||||
|
@ -848,19 +768,22 @@ output_cgraph (cgraph_node_set set, varpool_node_set vset)
|
|||
|
||||
/* An encoder for cgraph nodes should have been created by
|
||||
ipa_write_summaries_1. */
|
||||
gcc_assert (ob->decl_state->cgraph_node_encoder);
|
||||
gcc_assert (ob->decl_state->varpool_node_encoder);
|
||||
encoder = ob->decl_state->cgraph_node_encoder;
|
||||
varpool_encoder = ob->decl_state->varpool_node_encoder;
|
||||
gcc_assert (ob->decl_state->symtab_node_encoder);
|
||||
encoder = ob->decl_state->symtab_node_encoder;
|
||||
|
||||
/* Write out the nodes. We must first output a node and then its clones,
|
||||
otherwise at a time reading back the node there would be nothing to clone
|
||||
from. */
|
||||
n_nodes = lto_cgraph_encoder_size (encoder);
|
||||
n_nodes = lto_symtab_encoder_size (encoder);
|
||||
for (i = 0; i < n_nodes; i++)
|
||||
{
|
||||
node = lto_cgraph_encoder_deref (encoder, i);
|
||||
lto_output_node (ob, node, encoder, set, vset);
|
||||
symtab_node node = lto_symtab_encoder_deref (encoder, i);
|
||||
if (symtab_function_p (node))
|
||||
lto_output_node (ob, cgraph (node), encoder, set, vset);
|
||||
else
|
||||
lto_output_varpool_node (ob, varpool (node), encoder,
|
||||
set, vset);
|
||||
|
||||
}
|
||||
|
||||
/* Go over the nodes in SET again to write edges. */
|
||||
|
@ -885,8 +808,7 @@ output_cgraph (cgraph_node_set set, varpool_node_set vset)
|
|||
lto_output_toplevel_asms ();
|
||||
}
|
||||
|
||||
output_varpool (set, vset);
|
||||
output_refs (set, vset, encoder, varpool_encoder);
|
||||
output_refs (set, vset, encoder);
|
||||
}
|
||||
|
||||
/* Overwrite the information in NODE based on FILE_DATA, TAG, FLAGS,
|
||||
|
@ -899,7 +821,7 @@ output_cgraph (cgraph_node_set set, varpool_node_set vset)
|
|||
static void
|
||||
input_overwrite_node (struct lto_file_decl_data *file_data,
|
||||
struct cgraph_node *node,
|
||||
enum LTO_cgraph_tags tag,
|
||||
enum LTO_symtab_tags tag,
|
||||
struct bitpack_d *bp)
|
||||
{
|
||||
node->symbol.aux = (void *) tag;
|
||||
|
@ -916,7 +838,7 @@ input_overwrite_node (struct lto_file_decl_data *file_data,
|
|||
node->abstract_and_needed = bp_unpack_value (bp, 1);
|
||||
node->symbol.used_from_other_partition = bp_unpack_value (bp, 1);
|
||||
node->lowered = bp_unpack_value (bp, 1);
|
||||
node->analyzed = tag == LTO_cgraph_analyzed_node;
|
||||
node->analyzed = tag == LTO_symtab_analyzed_node;
|
||||
node->symbol.in_other_partition = bp_unpack_value (bp, 1);
|
||||
if (node->symbol.in_other_partition
|
||||
/* Avoid updating decl when we are seeing just inline clone.
|
||||
|
@ -942,38 +864,14 @@ input_overwrite_node (struct lto_file_decl_data *file_data,
|
|||
LDPR_NUM_KNOWN);
|
||||
}
|
||||
|
||||
/* Output the part of the cgraph in SET. */
|
||||
|
||||
static void
|
||||
output_varpool (cgraph_node_set set, varpool_node_set vset)
|
||||
{
|
||||
struct lto_simple_output_block *ob = lto_create_simple_output_block (LTO_section_varpool);
|
||||
lto_varpool_encoder_t varpool_encoder = ob->decl_state->varpool_node_encoder;
|
||||
int len = lto_varpool_encoder_size (varpool_encoder), i;
|
||||
|
||||
streamer_write_uhwi_stream (ob->main_stream, len);
|
||||
|
||||
/* Write out the nodes. We must first output a node and then its clones,
|
||||
otherwise at a time reading back the node there would be nothing to clone
|
||||
from. */
|
||||
for (i = 0; i < len; i++)
|
||||
{
|
||||
lto_output_varpool_node (ob, lto_varpool_encoder_deref (varpool_encoder, i),
|
||||
varpool_encoder,
|
||||
set, vset);
|
||||
}
|
||||
|
||||
lto_destroy_simple_output_block (ob);
|
||||
}
|
||||
|
||||
/* Read a node from input_block IB. TAG is the node's tag just read.
|
||||
Return the node read or overwriten. */
|
||||
|
||||
static struct cgraph_node *
|
||||
input_node (struct lto_file_decl_data *file_data,
|
||||
struct lto_input_block *ib,
|
||||
enum LTO_cgraph_tags tag,
|
||||
VEC(cgraph_node_ptr, heap) *nodes)
|
||||
enum LTO_symtab_tags tag,
|
||||
VEC(symtab_node, heap) *nodes)
|
||||
{
|
||||
tree fn_decl;
|
||||
struct cgraph_node *node;
|
||||
|
@ -991,7 +889,7 @@ input_node (struct lto_file_decl_data *file_data,
|
|||
|
||||
if (clone_ref != LCC_NOT_FOUND)
|
||||
{
|
||||
node = cgraph_clone_node (VEC_index (cgraph_node_ptr, nodes, clone_ref), fn_decl,
|
||||
node = cgraph_clone_node (cgraph (VEC_index (symtab_node, nodes, clone_ref)), fn_decl,
|
||||
0, CGRAPH_FREQ_BASE, false, NULL, false);
|
||||
}
|
||||
else
|
||||
|
@ -1004,7 +902,7 @@ input_node (struct lto_file_decl_data *file_data,
|
|||
node->count = streamer_read_hwi (ib);
|
||||
node->count_materialization_scale = streamer_read_hwi (ib);
|
||||
|
||||
if (tag == LTO_cgraph_analyzed_node)
|
||||
if (tag == LTO_symtab_analyzed_node)
|
||||
ref = streamer_read_hwi (ib);
|
||||
|
||||
ref2 = streamer_read_hwi (ib);
|
||||
|
@ -1107,25 +1005,16 @@ input_varpool_node (struct lto_file_decl_data *file_data,
|
|||
static void
|
||||
input_ref (struct lto_input_block *ib,
|
||||
symtab_node referring_node,
|
||||
VEC(cgraph_node_ptr, heap) *nodes,
|
||||
VEC(varpool_node_ptr, heap) *varpool_nodes_vec)
|
||||
VEC(symtab_node, heap) *nodes)
|
||||
{
|
||||
struct cgraph_node *node = NULL;
|
||||
struct varpool_node *varpool_node = NULL;
|
||||
symtab_node node = NULL;
|
||||
struct bitpack_d bp;
|
||||
int type;
|
||||
enum ipa_ref_use use;
|
||||
|
||||
bp = streamer_read_bitpack (ib);
|
||||
type = bp_unpack_value (&bp, 1);
|
||||
use = (enum ipa_ref_use) bp_unpack_value (&bp, 2);
|
||||
if (type)
|
||||
node = VEC_index (cgraph_node_ptr, nodes, streamer_read_hwi (ib));
|
||||
else
|
||||
varpool_node = VEC_index (varpool_node_ptr, varpool_nodes_vec,
|
||||
streamer_read_hwi (ib));
|
||||
ipa_record_reference (referring_node,
|
||||
node ? (symtab_node) node : (symtab_node) varpool_node, use, NULL);
|
||||
node = VEC_index (symtab_node, nodes, streamer_read_hwi (ib));
|
||||
ipa_record_reference (referring_node, node, use, NULL);
|
||||
}
|
||||
|
||||
/* Read an edge from IB. NODES points to a vector of previously read nodes for
|
||||
|
@ -1134,7 +1023,7 @@ input_ref (struct lto_input_block *ib,
|
|||
indirect_unknown_callee set). */
|
||||
|
||||
static void
|
||||
input_edge (struct lto_input_block *ib, VEC(cgraph_node_ptr, heap) *nodes,
|
||||
input_edge (struct lto_input_block *ib, VEC(symtab_node, heap) *nodes,
|
||||
bool indirect)
|
||||
{
|
||||
struct cgraph_node *caller, *callee;
|
||||
|
@ -1146,13 +1035,13 @@ input_edge (struct lto_input_block *ib, VEC(cgraph_node_ptr, heap) *nodes,
|
|||
struct bitpack_d bp;
|
||||
int ecf_flags = 0;
|
||||
|
||||
caller = VEC_index (cgraph_node_ptr, nodes, streamer_read_hwi (ib));
|
||||
caller = cgraph (VEC_index (symtab_node, nodes, streamer_read_hwi (ib)));
|
||||
if (caller == NULL || caller->symbol.decl == NULL_TREE)
|
||||
internal_error ("bytecode stream: no caller found while reading edge");
|
||||
|
||||
if (!indirect)
|
||||
{
|
||||
callee = VEC_index (cgraph_node_ptr, nodes, streamer_read_hwi (ib));
|
||||
callee = cgraph (VEC_index (symtab_node, nodes, streamer_read_hwi (ib)));
|
||||
if (callee == NULL || callee->symbol.decl == NULL_TREE)
|
||||
internal_error ("bytecode stream: no callee found while reading edge");
|
||||
}
|
||||
|
@ -1197,117 +1086,85 @@ input_edge (struct lto_input_block *ib, VEC(cgraph_node_ptr, heap) *nodes,
|
|||
|
||||
/* Read a cgraph from IB using the info in FILE_DATA. */
|
||||
|
||||
static VEC(cgraph_node_ptr, heap) *
|
||||
static VEC(symtab_node, heap) *
|
||||
input_cgraph_1 (struct lto_file_decl_data *file_data,
|
||||
struct lto_input_block *ib)
|
||||
{
|
||||
enum LTO_cgraph_tags tag;
|
||||
VEC(cgraph_node_ptr, heap) *nodes = NULL;
|
||||
struct cgraph_node *node;
|
||||
enum LTO_symtab_tags tag;
|
||||
VEC(symtab_node, heap) *nodes = NULL;
|
||||
symtab_node node;
|
||||
unsigned i;
|
||||
|
||||
tag = streamer_read_enum (ib, LTO_cgraph_tags, LTO_cgraph_last_tag);
|
||||
tag = streamer_read_enum (ib, LTO_symtab_tags, LTO_symtab_last_tag);
|
||||
order_base = symtab_order;
|
||||
while (tag)
|
||||
{
|
||||
if (tag == LTO_cgraph_edge)
|
||||
if (tag == LTO_symtab_edge)
|
||||
input_edge (ib, nodes, false);
|
||||
else if (tag == LTO_cgraph_indirect_edge)
|
||||
else if (tag == LTO_symtab_indirect_edge)
|
||||
input_edge (ib, nodes, true);
|
||||
else if (tag == LTO_symtab_variable)
|
||||
{
|
||||
node = (symtab_node)input_varpool_node (file_data, ib);
|
||||
VEC_safe_push (symtab_node, heap, nodes, node);
|
||||
lto_symtab_encoder_encode (file_data->symtab_node_encoder, node);
|
||||
}
|
||||
else
|
||||
{
|
||||
node = input_node (file_data, ib, tag,nodes);
|
||||
node = (symtab_node)input_node (file_data, ib, tag, nodes);
|
||||
if (node == NULL || node->symbol.decl == NULL_TREE)
|
||||
internal_error ("bytecode stream: found empty cgraph node");
|
||||
VEC_safe_push (cgraph_node_ptr, heap, nodes, node);
|
||||
lto_cgraph_encoder_encode (file_data->cgraph_node_encoder, node);
|
||||
VEC_safe_push (symtab_node, heap, nodes, node);
|
||||
lto_symtab_encoder_encode (file_data->symtab_node_encoder, node);
|
||||
}
|
||||
|
||||
tag = streamer_read_enum (ib, LTO_cgraph_tags, LTO_cgraph_last_tag);
|
||||
tag = streamer_read_enum (ib, LTO_symtab_tags, LTO_symtab_last_tag);
|
||||
}
|
||||
|
||||
lto_input_toplevel_asms (file_data, order_base);
|
||||
|
||||
/* AUX pointers should be all non-zero for nodes read from the stream. */
|
||||
/* AUX pointers should be all non-zero for function nodes read from the stream. */
|
||||
#ifdef ENABLE_CHECKING
|
||||
FOR_EACH_VEC_ELT (cgraph_node_ptr, nodes, i, node)
|
||||
gcc_assert (node->symbol.aux);
|
||||
FOR_EACH_VEC_ELT (symtab_node, nodes, i, node)
|
||||
gcc_assert (node->symbol.aux || !symtab_function_p (node));
|
||||
#endif
|
||||
FOR_EACH_VEC_ELT (cgraph_node_ptr, nodes, i, node)
|
||||
FOR_EACH_VEC_ELT (symtab_node, nodes, i, node)
|
||||
{
|
||||
int ref = (int) (intptr_t) node->global.inlined_to;
|
||||
int ref;
|
||||
if (symtab_function_p (node))
|
||||
{
|
||||
ref = (int) (intptr_t) cgraph (node)->global.inlined_to;
|
||||
|
||||
/* We share declaration of builtins, so we may read same node twice. */
|
||||
if (!node->symbol.aux)
|
||||
continue;
|
||||
node->symbol.aux = NULL;
|
||||
/* We share declaration of builtins, so we may read same node twice. */
|
||||
if (!node->symbol.aux)
|
||||
continue;
|
||||
node->symbol.aux = NULL;
|
||||
|
||||
/* Fixup inlined_to from reference to pointer. */
|
||||
if (ref != LCC_NOT_FOUND)
|
||||
node->global.inlined_to = VEC_index (cgraph_node_ptr, nodes, ref);
|
||||
else
|
||||
node->global.inlined_to = NULL;
|
||||
/* Fixup inlined_to from reference to pointer. */
|
||||
if (ref != LCC_NOT_FOUND)
|
||||
cgraph (node)->global.inlined_to = cgraph (VEC_index (symtab_node, nodes, ref));
|
||||
else
|
||||
cgraph (node)->global.inlined_to = NULL;
|
||||
}
|
||||
|
||||
ref = (int) (intptr_t) node->symbol.same_comdat_group;
|
||||
|
||||
/* Fixup same_comdat_group from reference to pointer. */
|
||||
if (ref != LCC_NOT_FOUND)
|
||||
node->symbol.same_comdat_group = (symtab_node)VEC_index (cgraph_node_ptr, nodes, ref);
|
||||
node->symbol.same_comdat_group = VEC_index (symtab_node, nodes, ref);
|
||||
else
|
||||
node->symbol.same_comdat_group = NULL;
|
||||
}
|
||||
FOR_EACH_VEC_ELT (cgraph_node_ptr, nodes, i, node)
|
||||
node->symbol.aux = (void *)1;
|
||||
FOR_EACH_VEC_ELT (symtab_node, nodes, i, node)
|
||||
node->symbol.aux = symtab_function_p (node) ? (void *)1 : NULL;
|
||||
return nodes;
|
||||
}
|
||||
|
||||
/* Read a varpool from IB using the info in FILE_DATA. */
|
||||
|
||||
static VEC(varpool_node_ptr, heap) *
|
||||
input_varpool_1 (struct lto_file_decl_data *file_data,
|
||||
struct lto_input_block *ib)
|
||||
{
|
||||
unsigned HOST_WIDE_INT len;
|
||||
VEC(varpool_node_ptr, heap) *varpool = NULL;
|
||||
int i;
|
||||
struct varpool_node *node;
|
||||
|
||||
len = streamer_read_uhwi (ib);
|
||||
while (len)
|
||||
{
|
||||
VEC_safe_push (varpool_node_ptr, heap, varpool,
|
||||
input_varpool_node (file_data, ib));
|
||||
len--;
|
||||
}
|
||||
#ifdef ENABLE_CHECKING
|
||||
FOR_EACH_VEC_ELT (varpool_node_ptr, varpool, i, node)
|
||||
gcc_assert (!node->symbol.aux);
|
||||
#endif
|
||||
FOR_EACH_VEC_ELT (varpool_node_ptr, varpool, i, node)
|
||||
{
|
||||
int ref = (int) (intptr_t) node->symbol.same_comdat_group;
|
||||
/* We share declaration of builtins, so we may read same node twice. */
|
||||
if (node->symbol.aux)
|
||||
continue;
|
||||
node->symbol.aux = (void *)1;
|
||||
|
||||
/* Fixup same_comdat_group from reference to pointer. */
|
||||
if (ref != LCC_NOT_FOUND)
|
||||
node->symbol.same_comdat_group = (symtab_node)VEC_index (varpool_node_ptr, varpool, ref);
|
||||
else
|
||||
node->symbol.same_comdat_group = NULL;
|
||||
}
|
||||
FOR_EACH_VEC_ELT (varpool_node_ptr, varpool, i, node)
|
||||
node->symbol.aux = NULL;
|
||||
return varpool;
|
||||
}
|
||||
|
||||
/* Input ipa_refs. */
|
||||
|
||||
static void
|
||||
input_refs (struct lto_input_block *ib,
|
||||
VEC(cgraph_node_ptr, heap) *nodes,
|
||||
VEC(varpool_node_ptr, heap) *varpool)
|
||||
VEC(symtab_node, heap) *nodes)
|
||||
{
|
||||
int count;
|
||||
int idx;
|
||||
|
@ -1318,10 +1175,10 @@ input_refs (struct lto_input_block *ib,
|
|||
if (!count)
|
||||
break;
|
||||
idx = streamer_read_uhwi (ib);
|
||||
node = VEC_index (cgraph_node_ptr, nodes, idx);
|
||||
node = cgraph (VEC_index (symtab_node, nodes, idx));
|
||||
while (count)
|
||||
{
|
||||
input_ref (ib, (symtab_node) node, nodes, varpool);
|
||||
input_ref (ib, (symtab_node) node, nodes);
|
||||
count--;
|
||||
}
|
||||
}
|
||||
|
@ -1331,11 +1188,11 @@ input_refs (struct lto_input_block *ib,
|
|||
count = streamer_read_uhwi (ib);
|
||||
if (!count)
|
||||
break;
|
||||
node = VEC_index (varpool_node_ptr, varpool,
|
||||
streamer_read_uhwi (ib));
|
||||
node = varpool (VEC_index (symtab_node, nodes,
|
||||
streamer_read_uhwi (ib)));
|
||||
while (count)
|
||||
{
|
||||
input_ref (ib, (symtab_node) node, nodes, varpool);
|
||||
input_ref (ib, (symtab_node) node, nodes);
|
||||
count--;
|
||||
}
|
||||
}
|
||||
|
@ -1462,38 +1319,28 @@ input_cgraph (void)
|
|||
const char *data;
|
||||
size_t len;
|
||||
struct lto_input_block *ib;
|
||||
VEC(cgraph_node_ptr, heap) *nodes;
|
||||
VEC(varpool_node_ptr, heap) *varpool;
|
||||
VEC(symtab_node, heap) *nodes;
|
||||
|
||||
ib = lto_create_simple_input_block (file_data, LTO_section_cgraph,
|
||||
&data, &len);
|
||||
if (!ib)
|
||||
fatal_error ("cannot find LTO cgraph in %s", file_data->file_name);
|
||||
input_profile_summary (ib, file_data);
|
||||
file_data->cgraph_node_encoder = lto_cgraph_encoder_new ();
|
||||
file_data->symtab_node_encoder = lto_symtab_encoder_new ();
|
||||
nodes = input_cgraph_1 (file_data, ib);
|
||||
lto_destroy_simple_input_block (file_data, LTO_section_cgraph,
|
||||
ib, data, len);
|
||||
|
||||
ib = lto_create_simple_input_block (file_data, LTO_section_varpool,
|
||||
&data, &len);
|
||||
if (!ib)
|
||||
fatal_error ("cannot find LTO varpool in %s", file_data->file_name);
|
||||
varpool = input_varpool_1 (file_data, ib);
|
||||
lto_destroy_simple_input_block (file_data, LTO_section_varpool,
|
||||
ib, data, len);
|
||||
|
||||
ib = lto_create_simple_input_block (file_data, LTO_section_refs,
|
||||
&data, &len);
|
||||
if (!ib)
|
||||
fatal_error("cannot find LTO section refs in %s", file_data->file_name);
|
||||
input_refs (ib, nodes, varpool);
|
||||
input_refs (ib, nodes);
|
||||
lto_destroy_simple_input_block (file_data, LTO_section_refs,
|
||||
ib, data, len);
|
||||
if (flag_ltrans)
|
||||
input_cgraph_opt_summary (nodes);
|
||||
VEC_free (cgraph_node_ptr, heap, nodes);
|
||||
VEC_free (varpool_node_ptr, heap, varpool);
|
||||
VEC_free (symtab_node, heap, nodes);
|
||||
}
|
||||
|
||||
merge_profile_summaries (file_data_vec);
|
||||
|
@ -1598,27 +1445,28 @@ output_node_opt_summary (struct output_block *ob,
|
|||
static void
|
||||
output_cgraph_opt_summary (cgraph_node_set set)
|
||||
{
|
||||
struct cgraph_node *node;
|
||||
symtab_node node;
|
||||
int i, n_nodes;
|
||||
lto_cgraph_encoder_t encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
struct output_block *ob = create_output_block (LTO_section_cgraph_opt_sum);
|
||||
unsigned count = 0;
|
||||
|
||||
ob->cgraph_node = NULL;
|
||||
encoder = ob->decl_state->cgraph_node_encoder;
|
||||
n_nodes = lto_cgraph_encoder_size (encoder);
|
||||
encoder = ob->decl_state->symtab_node_encoder;
|
||||
n_nodes = lto_symtab_encoder_size (encoder);
|
||||
for (i = 0; i < n_nodes; i++)
|
||||
if (output_cgraph_opt_summary_p (lto_cgraph_encoder_deref (encoder, i),
|
||||
set))
|
||||
if (symtab_function_p (node = lto_symtab_encoder_deref (encoder, i))
|
||||
&& output_cgraph_opt_summary_p (cgraph (node), set))
|
||||
count++;
|
||||
streamer_write_uhwi (ob, count);
|
||||
for (i = 0; i < n_nodes; i++)
|
||||
{
|
||||
node = lto_cgraph_encoder_deref (encoder, i);
|
||||
if (output_cgraph_opt_summary_p (node, set))
|
||||
node = lto_symtab_encoder_deref (encoder, i);
|
||||
if (symtab_function_p (node)
|
||||
&& output_cgraph_opt_summary_p (cgraph (node), set))
|
||||
{
|
||||
streamer_write_uhwi (ob, i);
|
||||
output_node_opt_summary (ob, node, set);
|
||||
output_node_opt_summary (ob, cgraph (node), set);
|
||||
}
|
||||
}
|
||||
produce_asm (ob, NULL);
|
||||
|
@ -1690,7 +1538,7 @@ input_node_opt_summary (struct cgraph_node *node,
|
|||
|
||||
static void
|
||||
input_cgraph_opt_section (struct lto_file_decl_data *file_data,
|
||||
const char *data, size_t len, VEC (cgraph_node_ptr,
|
||||
const char *data, size_t len, VEC (symtab_node,
|
||||
heap) * nodes)
|
||||
{
|
||||
const struct lto_function_header *header =
|
||||
|
@ -1714,7 +1562,7 @@ input_cgraph_opt_section (struct lto_file_decl_data *file_data,
|
|||
for (i = 0; i < count; i++)
|
||||
{
|
||||
int ref = streamer_read_uhwi (&ib_main);
|
||||
input_node_opt_summary (VEC_index (cgraph_node_ptr, nodes, ref),
|
||||
input_node_opt_summary (cgraph (VEC_index (symtab_node, nodes, ref)),
|
||||
&ib_main, data_in);
|
||||
}
|
||||
lto_free_section_data (file_data, LTO_section_cgraph_opt_sum, NULL, data,
|
||||
|
@ -1725,7 +1573,7 @@ input_cgraph_opt_section (struct lto_file_decl_data *file_data,
|
|||
/* Input optimization summary of cgraph. */
|
||||
|
||||
static void
|
||||
input_cgraph_opt_summary (VEC (cgraph_node_ptr, heap) * nodes)
|
||||
input_cgraph_opt_summary (VEC (symtab_node, heap) * nodes)
|
||||
{
|
||||
struct lto_file_decl_data **file_data_vec = lto_get_file_decl_data ();
|
||||
struct lto_file_decl_data *file_data;
|
||||
|
|
|
@ -348,13 +348,13 @@ lto_write_tree (struct output_block *ob, tree expr, bool ref_p)
|
|||
&& (TREE_STATIC (expr) || DECL_EXTERNAL (expr))
|
||||
&& initial)
|
||||
{
|
||||
lto_varpool_encoder_t varpool_encoder;
|
||||
lto_symtab_encoder_t encoder;
|
||||
struct varpool_node *vnode;
|
||||
|
||||
varpool_encoder = ob->decl_state->varpool_node_encoder;
|
||||
encoder = ob->decl_state->symtab_node_encoder;
|
||||
vnode = varpool_get_node (expr);
|
||||
if (!vnode
|
||||
|| !lto_varpool_encoder_encode_initializer_p (varpool_encoder,
|
||||
|| !lto_symtab_encoder_encode_initializer_p (encoder,
|
||||
vnode))
|
||||
initial = error_mark_node;
|
||||
}
|
||||
|
@ -983,17 +983,20 @@ lto_output (cgraph_node_set set, varpool_node_set vset)
|
|||
bitmap output = lto_bitmap_alloc ();
|
||||
#endif
|
||||
int i, n_nodes;
|
||||
lto_cgraph_encoder_t encoder = lto_get_out_decl_state ()->cgraph_node_encoder;
|
||||
lto_symtab_encoder_t encoder = lto_get_out_decl_state ()->symtab_node_encoder;
|
||||
|
||||
/* Initialize the streamer. */
|
||||
lto_streamer_init ();
|
||||
|
||||
n_nodes = lto_cgraph_encoder_size (encoder);
|
||||
n_nodes = lto_symtab_encoder_size (encoder);
|
||||
/* Process only the functions with bodies. */
|
||||
for (i = 0; i < n_nodes; i++)
|
||||
{
|
||||
node = lto_cgraph_encoder_deref (encoder, i);
|
||||
if (lto_cgraph_encoder_encode_body_p (encoder, node)
|
||||
symtab_node snode = lto_symtab_encoder_deref (encoder, i);
|
||||
if (!symtab_function_p (snode))
|
||||
continue;
|
||||
node = cgraph (snode);
|
||||
if (lto_symtab_encoder_encode_body_p (encoder, node)
|
||||
&& !node->alias
|
||||
&& !node->thunk.thunk_p)
|
||||
{
|
||||
|
@ -1290,8 +1293,7 @@ produce_symtab (struct output_block *ob)
|
|||
struct cgraph_node *node;
|
||||
struct varpool_node *vnode;
|
||||
struct lto_output_stream stream;
|
||||
lto_varpool_encoder_t varpool_encoder = ob->decl_state->varpool_node_encoder;
|
||||
lto_cgraph_encoder_t encoder = ob->decl_state->cgraph_node_encoder;
|
||||
lto_symtab_encoder_t encoder = ob->decl_state->symtab_node_encoder;
|
||||
int i;
|
||||
|
||||
lto_begin_section (section_name, false);
|
||||
|
@ -1303,9 +1305,11 @@ produce_symtab (struct output_block *ob)
|
|||
/* Write all functions.
|
||||
First write all defined functions and then write all used functions.
|
||||
This is done so only to handle duplicated symbols in cgraph. */
|
||||
for (i = 0; i < lto_cgraph_encoder_size (encoder); i++)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
{
|
||||
node = lto_cgraph_encoder_deref (encoder, i);
|
||||
if (!symtab_function_p (lto_symtab_encoder_deref (encoder, i)))
|
||||
continue;
|
||||
node = cgraph (lto_symtab_encoder_deref (encoder, i));
|
||||
if (DECL_EXTERNAL (node->symbol.decl))
|
||||
continue;
|
||||
if (DECL_COMDAT (node->symbol.decl)
|
||||
|
@ -1315,9 +1319,11 @@ produce_symtab (struct output_block *ob)
|
|||
continue;
|
||||
write_symbol (cache, &stream, node->symbol.decl, seen, false);
|
||||
}
|
||||
for (i = 0; i < lto_cgraph_encoder_size (encoder); i++)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
{
|
||||
node = lto_cgraph_encoder_deref (encoder, i);
|
||||
if (!symtab_function_p (lto_symtab_encoder_deref (encoder, i)))
|
||||
continue;
|
||||
node = cgraph (lto_symtab_encoder_deref (encoder, i));
|
||||
if (!DECL_EXTERNAL (node->symbol.decl))
|
||||
continue;
|
||||
/* We keep around unused extern inlines in order to be able to inline
|
||||
|
@ -1334,9 +1340,11 @@ produce_symtab (struct output_block *ob)
|
|||
}
|
||||
|
||||
/* Write all variables. */
|
||||
for (i = 0; i < lto_varpool_encoder_size (varpool_encoder); i++)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
{
|
||||
vnode = lto_varpool_encoder_deref (varpool_encoder, i);
|
||||
if (!symtab_variable_p (lto_symtab_encoder_deref (encoder, i)))
|
||||
continue;
|
||||
vnode = varpool (lto_symtab_encoder_deref (encoder, i));
|
||||
if (DECL_EXTERNAL (vnode->symbol.decl))
|
||||
continue;
|
||||
/* COMDAT virtual tables can be unshared. Do not declare them
|
||||
|
@ -1351,9 +1359,11 @@ produce_symtab (struct output_block *ob)
|
|||
continue;
|
||||
write_symbol (cache, &stream, vnode->symbol.decl, seen, false);
|
||||
}
|
||||
for (i = 0; i < lto_varpool_encoder_size (varpool_encoder); i++)
|
||||
for (i = 0; i < lto_symtab_encoder_size (encoder); i++)
|
||||
{
|
||||
vnode = lto_varpool_encoder_deref (varpool_encoder, i);
|
||||
if (!symtab_variable_p (lto_symtab_encoder_deref (encoder, i)))
|
||||
continue;
|
||||
vnode = varpool (lto_symtab_encoder_deref (encoder, i));
|
||||
if (!DECL_EXTERNAL (vnode->symbol.decl))
|
||||
continue;
|
||||
if (DECL_COMDAT (vnode->symbol.decl)
|
||||
|
@ -1482,8 +1492,7 @@ produce_asm_for_decls (cgraph_node_set set ATTRIBUTE_UNUSED,
|
|||
VEC_index (lto_out_decl_state_ptr, lto_function_decl_states, idx);
|
||||
lto_delete_out_decl_state (fn_out_state);
|
||||
}
|
||||
lto_cgraph_encoder_delete (ob->decl_state->cgraph_node_encoder);
|
||||
lto_varpool_encoder_delete (ob->decl_state->varpool_node_encoder);
|
||||
lto_symtab_encoder_delete (ob->decl_state->symtab_node_encoder);
|
||||
VEC_free (lto_out_decl_state_ptr, heap, lto_function_decl_states);
|
||||
lto_function_decl_states = NULL;
|
||||
destroy_output_block (ob);
|
||||
|
|
|
@ -423,49 +423,28 @@ struct lto_stats_d
|
|||
};
|
||||
|
||||
/* Encoder data structure used to stream callgraph nodes. */
|
||||
struct lto_cgraph_encoder_d
|
||||
struct lto_symtab_encoder_d
|
||||
{
|
||||
/* Map nodes to reference number. */
|
||||
struct pointer_map_t *map;
|
||||
|
||||
/* Map reference number to node. */
|
||||
VEC(cgraph_node_ptr,heap) *nodes;
|
||||
VEC(symtab_node,heap) *nodes;
|
||||
|
||||
/* Map of nodes where we want to output body. */
|
||||
struct pointer_set_t *body;
|
||||
};
|
||||
|
||||
typedef struct lto_cgraph_encoder_d *lto_cgraph_encoder_t;
|
||||
|
||||
/* Return number of encoded nodes in ENCODER. */
|
||||
|
||||
static inline int
|
||||
lto_cgraph_encoder_size (lto_cgraph_encoder_t encoder)
|
||||
{
|
||||
return VEC_length (cgraph_node_ptr, encoder->nodes);
|
||||
}
|
||||
|
||||
|
||||
/* Encoder data structure used to stream callgraph nodes. */
|
||||
struct lto_varpool_encoder_d
|
||||
{
|
||||
/* Map nodes to reference number. */
|
||||
struct pointer_map_t *map;
|
||||
|
||||
/* Map reference number to node. */
|
||||
VEC(varpool_node_ptr,heap) *nodes;
|
||||
|
||||
/* Map of nodes where we want to output initializer. */
|
||||
struct pointer_set_t *initializer;
|
||||
};
|
||||
typedef struct lto_varpool_encoder_d *lto_varpool_encoder_t;
|
||||
|
||||
typedef struct lto_symtab_encoder_d *lto_symtab_encoder_t;
|
||||
|
||||
/* Return number of encoded nodes in ENCODER. */
|
||||
|
||||
static inline int
|
||||
lto_varpool_encoder_size (lto_varpool_encoder_t encoder)
|
||||
lto_symtab_encoder_size (lto_symtab_encoder_t encoder)
|
||||
{
|
||||
return VEC_length (varpool_node_ptr, encoder->nodes);
|
||||
return VEC_length (symtab_node, encoder->nodes);
|
||||
}
|
||||
|
||||
/* Mapping from indices to trees. */
|
||||
|
@ -520,10 +499,7 @@ struct lto_out_decl_state
|
|||
struct lto_tree_ref_encoder streams[LTO_N_DECL_STREAMS];
|
||||
|
||||
/* Encoder for cgraph nodes. */
|
||||
lto_cgraph_encoder_t cgraph_node_encoder;
|
||||
|
||||
/* Encoder for varpool nodes. */
|
||||
lto_varpool_encoder_t varpool_node_encoder;
|
||||
lto_symtab_encoder_t symtab_node_encoder;
|
||||
|
||||
/* If this out-decl state belongs to a function, fn_decl points to that
|
||||
function. Otherwise, it is NULL. */
|
||||
|
@ -549,10 +525,7 @@ struct GTY(()) lto_file_decl_data
|
|||
struct lto_in_decl_state *global_decl_state;
|
||||
|
||||
/* Table of cgraph nodes present in this file. */
|
||||
lto_cgraph_encoder_t GTY((skip)) cgraph_node_encoder;
|
||||
|
||||
/* Table of varpool nodes present in this file. */
|
||||
lto_varpool_encoder_t GTY((skip)) varpool_node_encoder;
|
||||
lto_symtab_encoder_t GTY((skip)) symtab_node_encoder;
|
||||
|
||||
/* Hash table maps lto-related section names to location in file. */
|
||||
htab_t GTY((param_is (struct lto_in_decl_state))) function_decl_states;
|
||||
|
@ -837,23 +810,16 @@ void lto_output_location (struct output_block *, location_t);
|
|||
|
||||
|
||||
/* In lto-cgraph.c */
|
||||
struct cgraph_node *lto_cgraph_encoder_deref (lto_cgraph_encoder_t, int);
|
||||
int lto_cgraph_encoder_lookup (lto_cgraph_encoder_t, struct cgraph_node *);
|
||||
lto_cgraph_encoder_t lto_cgraph_encoder_new (void);
|
||||
int lto_cgraph_encoder_encode (lto_cgraph_encoder_t, struct cgraph_node *);
|
||||
void lto_cgraph_encoder_delete (lto_cgraph_encoder_t);
|
||||
bool lto_cgraph_encoder_encode_body_p (lto_cgraph_encoder_t,
|
||||
symtab_node lto_symtab_encoder_deref (lto_symtab_encoder_t, int);
|
||||
int lto_symtab_encoder_lookup (lto_symtab_encoder_t, symtab_node);
|
||||
lto_symtab_encoder_t lto_symtab_encoder_new (void);
|
||||
int lto_symtab_encoder_encode (lto_symtab_encoder_t, symtab_node);
|
||||
void lto_symtab_encoder_delete (lto_symtab_encoder_t);
|
||||
bool lto_symtab_encoder_encode_body_p (lto_symtab_encoder_t,
|
||||
struct cgraph_node *);
|
||||
|
||||
bool lto_varpool_encoder_encode_body_p (lto_varpool_encoder_t,
|
||||
struct varpool_node *);
|
||||
struct varpool_node *lto_varpool_encoder_deref (lto_varpool_encoder_t, int);
|
||||
int lto_varpool_encoder_lookup (lto_varpool_encoder_t, struct varpool_node *);
|
||||
lto_varpool_encoder_t lto_varpool_encoder_new (void);
|
||||
int lto_varpool_encoder_encode (lto_varpool_encoder_t, struct varpool_node *);
|
||||
void lto_varpool_encoder_delete (lto_varpool_encoder_t);
|
||||
bool lto_varpool_encoder_encode_initializer_p (lto_varpool_encoder_t,
|
||||
struct varpool_node *);
|
||||
bool lto_symtab_encoder_encode_initializer_p (lto_symtab_encoder_t,
|
||||
struct varpool_node *);
|
||||
void output_cgraph (cgraph_node_set, varpool_node_set);
|
||||
void input_cgraph (void);
|
||||
bool referenced_from_other_partition_p (struct ipa_ref_list *,
|
||||
|
|
Loading…
Add table
Reference in a new issue