diff options
author | Nick Clifton <nickc@redhat.com> | 2020-08-26 16:26:13 +0100 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2020-08-26 16:26:13 +0100 |
commit | eae0b5c3b2d6b76c3ed80146bc938e0d6b7e9fec (patch) | |
tree | a741e096dc5fbcf768bc2c18de93667fd491d11b /bfd/elf64-alpha.c | |
parent | b74a6c6086033907f4ea1dbd61166ee63b6f0a99 (diff) | |
download | binutils-eae0b5c3b2d6b76c3ed80146bc938e0d6b7e9fec.zip binutils-eae0b5c3b2d6b76c3ed80146bc938e0d6b7e9fec.tar.gz binutils-eae0b5c3b2d6b76c3ed80146bc938e0d6b7e9fec.tar.bz2 |
Fix sanitization problems running the linker testsuite for the alpha-elf target.
PR 26416
* elf64-alpha.c (elf64_alpha_relax_tls_get_addr): Test for and
ignore local symbols.
(elf64_alpha_relax_got_load): Do not check for local dynamic
symbols.
(OP_LDA, OP_LDAH, OP_LDQ, OP_BR, OP_BSR): Use unsigned constant
values.
(INSN_A) Cast the A parameter to unsigned.
(INSN_AB): Define in terms of INSN_A.
(INSN_ABC): Likewise.
(INSN_ABO): Likewise.
(INSN_AD): Likewise.
Diffstat (limited to 'bfd/elf64-alpha.c')
-rw-r--r-- | bfd/elf64-alpha.c | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/bfd/elf64-alpha.c b/bfd/elf64-alpha.c index 1976450..fd1f4b2 100644 --- a/bfd/elf64-alpha.c +++ b/bfd/elf64-alpha.c @@ -52,11 +52,11 @@ /* Instruction data for plt generation and relaxation. */ -#define OP_LDA 0x08 -#define OP_LDAH 0x09 -#define OP_LDQ 0x29 -#define OP_BR 0x30 -#define OP_BSR 0x34 +#define OP_LDA 0x08U +#define OP_LDAH 0x09U +#define OP_LDQ 0x29U +#define OP_BR 0x30U +#define OP_BSR 0x34U #define INSN_LDA (OP_LDA << 26) #define INSN_LDAH (OP_LDAH << 26) @@ -73,11 +73,11 @@ #define INSN_JMP 0x68000000 #define INSN_JSR_MASK 0xfc00c000 -#define INSN_A(I,A) (I | (A << 21)) -#define INSN_AB(I,A,B) (I | (A << 21) | (B << 16)) -#define INSN_ABC(I,A,B,C) (I | (A << 21) | (B << 16) | C) -#define INSN_ABO(I,A,B,O) (I | (A << 21) | (B << 16) | ((O) & 0xffff)) -#define INSN_AD(I,A,D) (I | (A << 21) | (((D) >> 2) & 0x1fffff)) +#define INSN_A(I,A) (I | ((unsigned) A << 21)) +#define INSN_AB(I,A,B) (INSN_A (I, A) | (B << 16)) +#define INSN_ABC(I,A,B,C) (INSN_A (I, A) | (B << 16) | C) +#define INSN_ABO(I,A,B,O) (INSN_A (I, A) | (B << 16) | ((O) & 0xffff)) +#define INSN_AD(I,A,D) (INSN_A (I, A) | (((D) >> 2) & 0x1fffff)) /* PLT/GOT Stuff */ @@ -2995,7 +2995,8 @@ elf64_alpha_relax_got_load (struct alpha_relax_info *info, bfd_vma symval, } /* Can't relax dynamic symbols. */ - if (alpha_elf_dynamic_symbol_p (&info->h->root, info->link_info)) + if (info->h != NULL + && alpha_elf_dynamic_symbol_p (&info->h->root, info->link_info)) return TRUE; /* Can't use local-exec relocations in shared libraries. */ @@ -3463,6 +3464,8 @@ elf64_alpha_relax_tls_get_addr (struct alpha_relax_info *info, bfd_vma symval, bfd_boolean dynamic, use_gottprel; unsigned long new_symndx; + if (info->h == NULL) + return TRUE; /* FIXME: Should this be return FALSE ? */ dynamic = alpha_elf_dynamic_symbol_p (&info->h->root, info->link_info); /* If a TLS symbol is accessed using IE at least once, there is no point |