LD: Export relative-from-absolute symbol marking to BFD

It is usually possible to tell absolute and ordinary symbols apart in
BFD throughout the link, by checking whether the section that owns the
symbol is absolute or not.

That however does not work for ordinary symbols defined in a linker
script outside an output section statement.  Initially such symbols are
entered into to the link hash as absolute symbols, owned by the absolute
section.  A flag is set in the internal linker expression defining such
symbols to tell the linker to convert them to section-relative ones in
the final phase of the link.  That flag is however not accessible to BFD
linker code, including BFD target code in particular.

Add a flag to the link hash then to copy the information held in the
linker expression.  Define a macro, `bfd_is_abs_symbol', for BFD code to
use where determining whether a symbol is absolute or ordinary is
required before the final link phase.

This macro will correctly identify the special `__ehdr_start' symbol as
ordinary throughout link, for example, even though early on it will be
assigned to the absolute section.  Of course this does not let BFD code
identify what the symbol's ultimate section will be before the final
link phase has converted this symbol (in `update_definedness').

	include/
	* bfdlink.h (bfd_link_hash_entry): Add `rel_from_abs' member.

	bfd/
	* linker.c (bfd_is_abs_symbol): New macro.
	* bfd-in2.h: Regenerate.

	ld/
	* ldexp.c (exp_fold_tree_1) <etree_assign, etree_provide>
	<etree_provided>: Copy expression's `rel_from_abs' flag to the
	link hash.
This commit is contained in:
Maciej W. Rozycki 2018-07-17 20:04:53 +01:00
parent 27724bad00
commit d5c928c053
7 changed files with 46 additions and 1 deletions

View File

@ -1,3 +1,8 @@
2018-07-17 Maciej W. Rozycki <macro@mips.com>
* linker.c (bfd_is_abs_symbol): New macro.
* bfd-in2.h: Regenerate.
2018-07-16 Edjunior Barbosa Machado <emachado@linux.vnet.ibm.com>
* elf-bfd.h (elfcore_write_ppc_tar): Add prototype.

View File

@ -7802,6 +7802,17 @@ bfd_boolean bfd_set_format (bfd *abfd, bfd_format format);
const char *bfd_format_string (bfd_format format);
/* Extracted from linker.c. */
/* Return TRUE if the symbol described by a linker hash entry H
is going to be absolute. Linker-script defined symbols can be
converted from absolute to section-relative ones late in the
link. Use this macro to correctly determine whether the symbol
will actually end up absolute in output. */
#define bfd_is_abs_symbol(H) \
(((H)->type == bfd_link_hash_defined \
|| (H)->type == bfd_link_hash_defweak) \
&& bfd_is_abs_section ((H)->u.def.section) \
&& !(H)->rel_from_abs)
bfd_boolean bfd_link_split_section (bfd *abfd, asection *sec);
#define bfd_link_split_section(abfd, sec) \

View File

@ -484,7 +484,20 @@ _bfd_link_hash_table_init
/* Look up a symbol in a link hash table. If follow is TRUE, we
follow bfd_link_hash_indirect and bfd_link_hash_warning links to
the real symbol. */
the real symbol.
.{* Return TRUE if the symbol described by a linker hash entry H
. is going to be absolute. Linker-script defined symbols can be
. converted from absolute to section-relative ones late in the
. link. Use this macro to correctly determine whether the symbol
. will actually end up absolute in output. *}
.#define bfd_is_abs_symbol(H) \
. (((H)->type == bfd_link_hash_defined \
. || (H)->type == bfd_link_hash_defweak) \
. && bfd_is_abs_section ((H)->u.def.section) \
. && !(H)->rel_from_abs)
.
*/
struct bfd_link_hash_entry *
bfd_link_hash_lookup (struct bfd_link_hash_table *table,

View File

@ -1,3 +1,7 @@
2018-07-17 Maciej W. Rozycki <macro@mips.com>
* bfdlink.h (bfd_link_hash_entry): Add `rel_from_abs' member.
2018-07-06 Alan Modra <amodra@gmail.com>
* diagnostics.h: Comment on macro usage.

View File

@ -115,6 +115,11 @@ struct bfd_link_hash_entry
/* Symbol defined in a linker script. */
unsigned int ldscript_def : 1;
/* Symbol will be converted from absolute to section-relative. Set for
symbols defined by a script from "dot" (also SEGMENT_START or ORIGIN)
outside of an output section statement. */
unsigned int rel_from_abs : 1;
/* A union of information depending upon the type. */
union
{

View File

@ -1,3 +1,9 @@
2018-07-17 Maciej W. Rozycki <macro@mips.com>
* ldexp.c (exp_fold_tree_1) <etree_assign, etree_provide>
<etree_provided>: Copy expression's `rel_from_abs' flag to the
link hash.
2018-07-12 Maciej W. Rozycki <macro@mips.com>
* testsuite/ld-mips-elf/mips-elf.exp (run_dump_test_abi)

View File

@ -1200,6 +1200,7 @@ exp_fold_tree_1 (etree_type *tree)
h->u.def.section = expld.result.section;
h->linker_def = ! tree->assign.type.lineno;
h->ldscript_def = 1;
h->rel_from_abs = expld.rel_from_abs;
if (tree->assign.hidden)
bfd_link_hide_symbol (link_info.output_bfd,
&link_info, h);