Segfault on phdrs allocated but not created
authorAlan Modra <amodra@gmail.com>
Sun, 25 Feb 2018 21:46:24 +0000 (08:16 +1030)
committerAlan Modra <amodra@gmail.com>
Mon, 26 Feb 2018 00:21:12 +0000 (10:51 +1030)
commit6838f2bed6459514c1b0c549e6aa3fc7dbb1d7ec
tree6a208a96143d2826c120abb1083e21e501a5e609
parentdf5f2391f7b2e3cab7e677ab7dadd02aef06e269
Segfault on phdrs allocated but not created

A number of ARM tests show results like:
ld-new: no address assigned to the veneers output section .gnu.sgstubs
ld-new: can not size stub section: invalid operation
ld-new: warning: cannot find entry symbol _start; defaulting to 0000000000010074
ld-new: tmpdir/cmse-veneers-no-gnu_sgstubs: warning: allocated section `.text' not in segment
Segmentation fault
PASS: Secure gateway veneers: no .gnu.sgstubs section

The PASS despite the segv shows the danger of using "#..." to match
error output.  This patch doesn't try to fix the testuite, but does
prevent the segfault.

* elf.c (assign_file_positions_except_relocs): Don't segfault
when actual number of phdrs is less than allocated.  Delete
outdated comment.  Formatting.
bfd/ChangeLog
bfd/elf.c