diff options
author | Alan Modra <amodra@gmail.com> | 2018-06-02 18:05:24 +0930 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2018-06-07 09:07:32 +0930 |
commit | 527278f3360dde3e5439b8d10f3f635155b35aca (patch) | |
tree | ceda73acd52a8af921680d4c6e03ebef48144e98 /bfd/elf32-tic6x.c | |
parent | e5a77256e8961294b3ea7d483124834311ca363b (diff) | |
download | gdb-527278f3360dde3e5439b8d10f3f635155b35aca.zip gdb-527278f3360dde3e5439b8d10f3f635155b35aca.tar.gz gdb-527278f3360dde3e5439b8d10f3f635155b35aca.tar.bz2 |
TIC6X __c6xabi_DSBT_BASE
Adding an undefined __c6xabi_DSBT_BASE via an EXTERN in the linker
script isn't ideal, as the symbol is not always needed. This patch
adds the undefined symbol on encountering relocations where it is
implicitly referenced.
bfd/
* elf32-tic6x.c (elf32_tic6x_check_relocs): Reference
__c6xabi_DSBT_BASE explicitly for R_C6000_SBR_* relocs.
ld/
* emulparams/elf32_tic6x_le.sh (EXECUTABLE_SYMBOLS): Don't define.
Diffstat (limited to 'bfd/elf32-tic6x.c')
-rw-r--r-- | bfd/elf32-tic6x.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/bfd/elf32-tic6x.c b/bfd/elf32-tic6x.c index 96965b3..768bfb8 100644 --- a/bfd/elf32-tic6x.c +++ b/bfd/elf32-tic6x.c @@ -2972,6 +2972,19 @@ elf32_tic6x_check_relocs (bfd *abfd, struct bfd_link_info *info, case R_C6000_SBR_H16_B: case R_C6000_SBR_H16_H: case R_C6000_SBR_H16_W: + { + /* These relocations implicitly reference __c6xabi_DSBT_BASE. + Add an explicit reference so that the symbol will be + provided by a linker script. */ + struct bfd_link_hash_entry *bh = NULL; + if (!_bfd_generic_link_add_one_symbol (info, abfd, + "__c6xabi_DSBT_BASE", + BSF_GLOBAL, + bfd_und_section_ptr, 0, + NULL, FALSE, FALSE, &bh)) + return FALSE; + ((struct elf_link_hash_entry *) bh)->non_elf = 0; + } if (h != NULL && bfd_link_executable (info)) { /* For B14-relative addresses, we might need a copy |