From 1ed89aa92ed7b3fc5a12f8d670392e5ce67c31b4 Mon Sep 17 00:00:00 2001 From: Nick Clifton Date: Thu, 6 Jun 2002 10:03:38 +0000 Subject: [PATCH] Do not include empty sections in loadable segments. --- bfd/ChangeLog | 8 +++- bfd/elf.c | 36 ++++++++++++++++- ld/testsuite/ChangeLog | 7 ++++ ld/testsuite/ld-scripts/phdrs2.exp | 64 ++++++++++++++++++++++++++++++ ld/testsuite/ld-scripts/phdrs2.s | 7 ++++ ld/testsuite/ld-scripts/phdrs2.t | 23 +++++++++++ 6 files changed, 142 insertions(+), 3 deletions(-) create mode 100644 ld/testsuite/ld-scripts/phdrs2.exp create mode 100644 ld/testsuite/ld-scripts/phdrs2.s create mode 100644 ld/testsuite/ld-scripts/phdrs2.t diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 51f9a90ffb..107403d07f 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2002-06-06 David Heine + + * elf.c (assign_file_positions_for_segments): Remove unallocated + sections from the section to segment mapping for PT_LOAD segments. + Update comment about empty loadable segments. + 2002-06-06 Richard Sandiford * stabs.c (_bfd_link_section_stabs): Check that the symbol offset @@ -44,7 +50,7 @@ * elf64-sh64.c (sh_elf64_get_relocated_section_contents): Likewise. * elfxx-ia64.c (elfNN_ia64_relax_section): Likewise. -Wed Jun 5 20:43:27 2002 J"orn Rennecke +2002-06-05 J"orn Rennecke * config.bfd (sh64l*-*-elf*, shl*-*-elf*): New configurations. diff --git a/bfd/elf.c b/bfd/elf.c index 36cbb7697b..fd9aa4b926 100644 --- a/bfd/elf.c +++ b/bfd/elf.c @@ -3455,6 +3455,37 @@ assign_file_positions_for_segments (abfd) if (! map_sections_to_segments (abfd)) return false; } + else + { + /* The placement algorithm assumes that non allocated sections are + not in PT_LOAD segments. We ensure this here by removing such + sections from the segment map. */ + for (m = elf_tdata (abfd)->segment_map; + m != NULL; + m = m->next) + { + unsigned int new_count; + unsigned int i; + + if (m->p_type != PT_LOAD) + continue; + + new_count = 0; + for (i = 0; i < m->count; i ++) + { + if ((m->sections[i]->flags & SEC_ALLOC) != 0) + { + if (i != new_count) + m->sections[new_count] = m->sections[i]; + + new_count ++; + } + } + + if (new_count != m->count) + m->count = new_count; + } + } if (bed->elf_backend_modify_segment_map) { @@ -4610,10 +4641,11 @@ copy_private_bfd_data (ibfd, obfd) { /* Special segments, such as the PT_PHDR segment, may contain no sections, but ordinary, loadable segments should contain - something. */ + something. They are allowed by the ELF spec however, so only + a warning is produced. */ if (segment->p_type == PT_LOAD) (*_bfd_error_handler) - (_("%s: warning: Empty loadable segment detected\n"), + (_("%s: warning: Empty loadable segment detected, is this intentional ?\n"), bfd_archive_filename (ibfd)); map->count = 0; diff --git a/ld/testsuite/ChangeLog b/ld/testsuite/ChangeLog index 1328cdefb1..551aaf96e6 100644 --- a/ld/testsuite/ChangeLog +++ b/ld/testsuite/ChangeLog @@ -1,3 +1,10 @@ +2002-06-06 David Heine + + * ld-scripts/phdrs2.exp: New file: Run second phdrs test. + * ld-scripts/phdrs2.s: New file: Dummy assembler source. + * ld-scripts/phdrs2.t: New file: Linker script with an empty + section at the start of a loadable segment. + 2005-06-02 H.J. Lu * ld-srec/sr3.cc (__dso_handle): Added for gcc 3.1 with diff --git a/ld/testsuite/ld-scripts/phdrs2.exp b/ld/testsuite/ld-scripts/phdrs2.exp new file mode 100644 index 0000000000..bbe36d08e9 --- /dev/null +++ b/ld/testsuite/ld-scripts/phdrs2.exp @@ -0,0 +1,64 @@ +# Test PHDRS with empty sections in a linker script. +# +# This file is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +# PHDRS2 is only meaningful for ELF. +if { ![istarget *-*-sysv4*] \ + && ![istarget *-*-unixware*] \ + && ![istarget *-*-elf*] \ + && ![istarget *-*-eabi*] \ + && ![istarget *-*-linux*] \ + && ![istarget *-*-irix5*] \ + && ![istarget *-*-irix6*] \ + && ![istarget *-*-solaris2*] } { + return +} + +if { [istarget *-*-linux*aout*] \ + || [istarget *-*-linux*oldld*] } { + return +} + +# This is a very simplistic test. + +set testname "PHDRS2" + +if ![ld_assemble $as $srcdir/$subdir/phdrs2.s tmpdir/phdrs2.o] { + unresolved $testname + return +} + +set phdrs_regexp \ + ".*Program Header:.*LOAD *off *0x00\[0-9a-f\]* *vaddr *0x00*800000 *paddr *0x00*800000.*filesz *0x0\[0-9a-f\]* *memsz *0x0\[0-9a-f\]*.*LOAD *off *0x00\[0-9a-f\]* *vaddr *0x00*800004 *paddr *0x00*800004.*filesz *0x00*\[0-9a-f\]* *memsz *0x0\[0-9a-f\]* *flags rw.*" + +if ![ld_simple_link $ld tmpdir/phdrs2 "-T $srcdir/$subdir/phdrs2.t tmpdir/phdrs2.o"] { + fail $testname +} else { + if {[which $objdump] == 0} { + unresolved $testname + return + } + + verbose -log "$objdump --private tmpdir/phdrs2" + catch "exec $objdump --private tmpdir/phdrs2" exec_output + set exec_output [prune_warnings $exec_output] + verbose -log $exec_output + + if [regexp $phdrs_regexp $exec_output] { + pass $testname + } else { + fail $testname + } +} diff --git a/ld/testsuite/ld-scripts/phdrs2.s b/ld/testsuite/ld-scripts/phdrs2.s new file mode 100644 index 0000000000..8092c18424 --- /dev/null +++ b/ld/testsuite/ld-scripts/phdrs2.s @@ -0,0 +1,7 @@ + .text + .align 4 + .long 1 + + .data + .align 4 + .long 2 diff --git a/ld/testsuite/ld-scripts/phdrs2.t b/ld/testsuite/ld-scripts/phdrs2.t new file mode 100644 index 0000000000..0d32b3958b --- /dev/null +++ b/ld/testsuite/ld-scripts/phdrs2.t @@ -0,0 +1,23 @@ +PHDRS +{ + text PT_LOAD ; + data PT_LOAD ; +} + +SECTIONS +{ + . = 0x800000 - 1; + /* The PHDRS generated should start at the aligned .text section + address, not the unaligned .empty section address */ + .empty : { + EMPTY_START = ABSOLUTE(.) ; + *(.empty) + EMPTY_END = ABSOLUTE(.) ; + } : text + .text : { *(.text) } :text + .data : { *(.data) + LONG(EMPTY_START) ; + } :data + + /DISCARD/ : { *(.*) } +} -- 2.34.1