From: Nick Clifton Date: Wed, 2 Aug 2017 10:45:05 +0000 (+0100) Subject: Fix seg-fault when trying to place non-ELF orphan sections. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ddff3d84be42fa80c2c9aaa635f2b9269e74e4f9;p=binutils-gdb.git Fix seg-fault when trying to place non-ELF orphan sections. PR 21884 * emultempl/elf32.em (_place_orphan): Skip non-ELF binaries when looking for sections to merge. --- diff --git a/ld/ChangeLog b/ld/ChangeLog index 3c918e6c583..9acf64efd7e 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,9 @@ +2017-08-02 Nick Clifton + + PR 21884 + * emultempl/elf32.em (_place_orphan): Skip non-ELF binaries when + looking for sections to merge. + 2017-07-31 Alan Modra * ld.texinfo (plt-localentry): Revise. diff --git a/ld/emultempl/elf32.em b/ld/emultempl/elf32.em index d2551b6f2c0..8cdcc6c7f91 100644 --- a/ld/emultempl/elf32.em +++ b/ld/emultempl/elf32.em @@ -2150,6 +2150,8 @@ gld${EMULATION_NAME}_place_orphan (asection *s, one of them has SHF_EXCLUDE. Don't merge 2 sections with different sh_info. */ if (os->bfd_section != NULL + /* PR 21884: Don't merge non-ELF sections. */ + && bfd_get_flavour (os->bfd_section->owner) == bfd_target_elf_flavour && (elf_section_data (os->bfd_section)->this_hdr.sh_info == elf_section_data (s)->this_hdr.sh_info) && (os->bfd_section->flags == 0