diff options
Diffstat (limited to 'gcc/lto-symtab.c')
-rw-r--r-- | gcc/lto-symtab.c | 41 |
1 files changed, 20 insertions, 21 deletions
diff --git a/gcc/lto-symtab.c b/gcc/lto-symtab.c index bdfbd7d67a2..1d90ab113f6 100644 --- a/gcc/lto-symtab.c +++ b/gcc/lto-symtab.c @@ -51,6 +51,8 @@ struct GTY(()) lto_symtab_entry_def /* LTO file-data and symbol resolution for this decl. */ struct lto_file_decl_data * GTY((skip (""))) file_data; enum ld_plugin_symbol_resolution resolution; + /* True when resolution was guessed and not read from the file. */ + bool guessed; /* Pointer to the next entry with the same key. Before decl merging this links all symbols from the different TUs. After decl merging this links merged but incompatible decls, thus all prevailing ones @@ -513,12 +515,14 @@ lto_symtab_resolve_symbols (void **slot) if (!lto_symtab_resolve_can_prevail_p (e)) { e->resolution = LDPR_RESOLVED_IR; + e->guessed = true; continue; } /* Set a default resolution - the final prevailing one will get adjusted later. */ e->resolution = LDPR_PREEMPTED_IR; + e->guessed = true; if (!lto_symtab_resolve_replaceable_p (e)) { if (prevailing) @@ -572,6 +576,7 @@ found: resolution file. These variables still need manual externally_visible attribute. */ prevailing->resolution = LDPR_PREVAILING_DEF_IRONLY; + prevailing->guessed = true; } /* Merge all decls in the symbol table chain to the prevailing decl and @@ -740,27 +745,21 @@ lto_symtab_merge_decls_1 (void **slot, void *data ATTRIBUTE_UNUSED) && TREE_CODE (prevailing->decl) != VAR_DECL) prevailing->next = NULL; - /* Set used_from_object_file flags. */ - if (prevailing->resolution == LDPR_PREVAILING_DEF - || prevailing->resolution == LDPR_PREEMPTED_REG - || prevailing->resolution == LDPR_RESOLVED_EXEC - || prevailing->resolution == LDPR_RESOLVED_DYN) - { - if (TREE_CODE (prevailing->decl) == FUNCTION_DECL) - { - if (prevailing->node->same_body_alias) - prevailing->node->same_body->local.used_from_object_file = true; - else - prevailing->node->local.used_from_object_file = true; - } - else - { - if (prevailing->vnode->alias) - prevailing->vnode->extra_name->used_from_object_file = true; - else - prevailing->vnode->used_from_object_file = true; - } - } + /* Store resolution decision into the callgraph. + In LTRANS don't overwrite information we stored into callgraph at + WPA stage. + + Do not bother to store guessed decisions. Generic code knows how + to handle UNKNOWN relocation well. + + The problem with storing guessed decision is whether to use + PREVAILING_DEF or PREVAILING_DEF_IRONLY. First one would disable + some whole program optimizations, while ther second would imply + to many whole program assumptions. */ + if (prevailing->node && !flag_ltrans && !prevailing->guessed) + prevailing->node->resolution = prevailing->resolution; + else if (prevailing->vnode && !flag_ltrans && !prevailing->guessed) + prevailing->vnode->resolution = prevailing->resolution; return 1; } |