diff options
author | Alan Modra <amodra@gmail.com> | 2004-10-19 12:00:58 +0000 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2004-10-19 12:00:58 +0000 |
commit | 4b85d634bfaf635431d4d7690390b267d293964e (patch) | |
tree | 7ba566c156636d24ed0738c8fda15385f4ae6dfc /bfd/elf64-ppc.c | |
parent | 6df4d94c68f19ff89a25fdbc3d9df60cadf1876f (diff) | |
download | gdb-4b85d634bfaf635431d4d7690390b267d293964e.zip gdb-4b85d634bfaf635431d4d7690390b267d293964e.tar.gz gdb-4b85d634bfaf635431d4d7690390b267d293964e.tar.bz2 |
* elf64-ppc.c (opd_entry_value): Handle --just-symbols objects.
(ppc64_elf_edit_opd): Likewise.
Diffstat (limited to 'bfd/elf64-ppc.c')
-rw-r--r-- | bfd/elf64-ppc.c | 33 |
1 files changed, 31 insertions, 2 deletions
diff --git a/bfd/elf64-ppc.c b/bfd/elf64-ppc.c index 6f30194..db0bc8f 100644 --- a/bfd/elf64-ppc.c +++ b/bfd/elf64-ppc.c @@ -4698,6 +4698,32 @@ opd_entry_value (asection *opd_sec, bfd *opd_bfd = opd_sec->owner; Elf_Internal_Rela *lo, *hi, *look; + /* No relocs implies we are linking a --just-symbols object. */ + if (opd_sec->reloc_count == 0) + { + bfd_vma val; + + if (!bfd_get_section_contents (opd_bfd, opd_sec, &val, offset, 8)) + return (bfd_vma) -1; + + if (code_sec != NULL) + { + asection *sec, *likely = NULL; + for (sec = opd_bfd->sections; sec != NULL; sec = sec->next) + if (sec->vma <= val + && (sec->flags & SEC_LOAD) != 0 + && (sec->flags & SEC_ALLOC) != 0) + likely = sec; + if (likely != NULL) + { + *code_sec = likely; + if (code_off != NULL) + *code_off = val - likely->vma; + } + } + return val; + } + /* Go find the opd reloc at the sym address. */ lo = _bfd_elf_link_read_relocs (opd_bfd, opd_sec, NULL, NULL, TRUE); BFD_ASSERT (lo != NULL); @@ -5899,13 +5925,16 @@ ppc64_elf_edit_opd (bfd *obfd, struct bfd_link_info *info, opd_adjust = get_opd_info (sec); if (opd_adjust == NULL) { - /* Must be a ld -r link. ie. check_relocs hasn't been - called. */ + /* check_relocs hasn't been called. Must be a ld -r link + or --just-symbols object. */ opd_adjust = bfd_zalloc (obfd, amt); ppc64_elf_section_data (sec)->opd.adjust = opd_adjust; } memset (opd_adjust, 0, amt); + if (sec->sec_info_type == ELF_INFO_TYPE_JUST_SYMS) + continue; + if (sec->output_section == bfd_abs_section_ptr) continue; |