diff options
-rw-r--r-- | bfd/ChangeLog | 6 | ||||
-rw-r--r-- | bfd/elf32-microblaze.c | 12 |
2 files changed, 17 insertions, 1 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 3ed2e9e..f42cb5f 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2017-08-08 Alan Modra <amodra@gmail.com> + + PR 21017 + * elf32-microblaze.c (microblaze_elf_check_relocs): Don't bump + got.refcount for GOTOFF relocs, just create .got section. + 2017-08-07 H.J. Lu <hongjiu.lu@intel.com> * elflink.c (elf_link_add_object_symbols): Move common symbol diff --git a/bfd/elf32-microblaze.c b/bfd/elf32-microblaze.c index 2657736..94ef09e 100644 --- a/bfd/elf32-microblaze.c +++ b/bfd/elf32-microblaze.c @@ -2353,7 +2353,6 @@ microblaze_elf_check_relocs (bfd * abfd, dogottls: sec->has_tls_reloc = 1; /* Fall through. */ - case R_MICROBLAZE_GOTOFF_64: case R_MICROBLAZE_GOT_64: if (htab->elf.sgot == NULL) { @@ -2374,6 +2373,17 @@ microblaze_elf_check_relocs (bfd * abfd, } break; + case R_MICROBLAZE_GOTOFF_64: + case R_MICROBLAZE_GOTOFF_32: + if (htab->elf.sgot == NULL) + { + if (htab->elf.dynobj == NULL) + htab->elf.dynobj = abfd; + if (!_bfd_elf_create_got_section (htab->elf.dynobj, info)) + return FALSE; + } + break; + case R_MICROBLAZE_64: case R_MICROBLAZE_64_PCREL: case R_MICROBLAZE_32: |