PR23850, strip should not discard/move .rela.plt in executable
Alan Modra
amodra@gmail.com
Fri Nov 2 04:47:00 GMT 2018
More information about the Binutils mailing list
Fri Nov 2 04:47:00 GMT 2018
- Previous message (by thread): [PATCH] [ARM] ping: Update knowledge of bfd architectures
- Next message (by thread): [GOLD] make clean
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
strip/objcopy can't deal with alloc reloc sections, not .rela.dyn or .rela.plt in a dynamic executable, or .rela.plt/.rela.iplt in a static executable. So, don't have BFD treat them as side-channel data associated with the section they are relocating. PR 23850 * elf.c (bfd_section_from_shdr): Treat SHF_ALLOC SHT_REL* sections in an executable or shared library as normal sections. diff --git a/bfd/elf.c b/bfd/elf.c index 764c61f044..bebda20195 100644 --- a/bfd/elf.c +++ b/bfd/elf.c @@ -2384,15 +2384,18 @@ bfd_section_from_shdr (bfd *abfd, unsigned int shindex) && ! bfd_section_from_shdr (abfd, hdr->sh_link)) goto fail; - /* If this reloc section does not use the main symbol table we - don't treat it as a reloc section. BFD can't adequately - represent such a section, so at least for now, we don't - try. We just present it as a normal section. We also - can't use it as a reloc section if it points to the null - section, an invalid section, another reloc section, or its - sh_link points to the null section. */ - if (hdr->sh_link != elf_onesymtab (abfd) + /* If this is an alloc section in an executable or shared + library, or the reloc section does not use the main symbol + table we don't treat it as a reloc section. BFD can't + adequately represent such a section, so at least for now, + we don't try. We just present it as a normal section. We + also can't use it as a reloc section if it points to the + null section, an invalid section, another reloc section, or + its sh_link points to the null section. */ + if (((abfd->flags & (DYNAMIC | EXEC_P)) != 0 + && (hdr->sh_flags & SHF_ALLOC) != 0) || hdr->sh_link == SHN_UNDEF + || hdr->sh_link != elf_onesymtab (abfd) || hdr->sh_info == SHN_UNDEF || hdr->sh_info >= num_sec || elf_elfsections (abfd)[hdr->sh_info]->sh_type == SHT_REL -- Alan Modra Australia Development Lab, IBM
- Previous message (by thread): [PATCH] [ARM] ping: Update knowledge of bfd architectures
- Next message (by thread): [GOLD] make clean
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
More information about the Binutils mailing list