mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-25 21:41:47 +08:00
Do not include empty sections in loadable segments.
This commit is contained in:
@ -1,3 +1,9 @@
|
|||||||
|
2002-06-06 David Heine <dlheine@tensilica.com>
|
||||||
|
|
||||||
|
* 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 <rsandifo@redhat.com>
|
2002-06-06 Richard Sandiford <rsandifo@redhat.com>
|
||||||
|
|
||||||
* stabs.c (_bfd_link_section_stabs): Check that the symbol offset
|
* 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.
|
* elf64-sh64.c (sh_elf64_get_relocated_section_contents): Likewise.
|
||||||
* elfxx-ia64.c (elfNN_ia64_relax_section): Likewise.
|
* elfxx-ia64.c (elfNN_ia64_relax_section): Likewise.
|
||||||
|
|
||||||
Wed Jun 5 20:43:27 2002 J"orn Rennecke <joern.rennecke@superh.com>
|
2002-06-05 J"orn Rennecke <joern.rennecke@superh.com>
|
||||||
|
|
||||||
* config.bfd (sh64l*-*-elf*, shl*-*-elf*): New configurations.
|
* config.bfd (sh64l*-*-elf*, shl*-*-elf*): New configurations.
|
||||||
|
|
||||||
|
36
bfd/elf.c
36
bfd/elf.c
@ -3455,6 +3455,37 @@ assign_file_positions_for_segments (abfd)
|
|||||||
if (! map_sections_to_segments (abfd))
|
if (! map_sections_to_segments (abfd))
|
||||||
return false;
|
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)
|
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
|
/* Special segments, such as the PT_PHDR segment, may contain
|
||||||
no sections, but ordinary, loadable segments should 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)
|
if (segment->p_type == PT_LOAD)
|
||||||
(*_bfd_error_handler)
|
(*_bfd_error_handler)
|
||||||
(_("%s: warning: Empty loadable segment detected\n"),
|
(_("%s: warning: Empty loadable segment detected, is this intentional ?\n"),
|
||||||
bfd_archive_filename (ibfd));
|
bfd_archive_filename (ibfd));
|
||||||
|
|
||||||
map->count = 0;
|
map->count = 0;
|
||||||
|
@ -1,3 +1,10 @@
|
|||||||
|
2002-06-06 David Heine <dlheine@tensilica.com>
|
||||||
|
|
||||||
|
* 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 <hjl@gnu.org>
|
2005-06-02 H.J. Lu <hjl@gnu.org>
|
||||||
|
|
||||||
* ld-srec/sr3.cc (__dso_handle): Added for gcc 3.1 with
|
* ld-srec/sr3.cc (__dso_handle): Added for gcc 3.1 with
|
||||||
|
64
ld/testsuite/ld-scripts/phdrs2.exp
Normal file
64
ld/testsuite/ld-scripts/phdrs2.exp
Normal file
@ -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
|
||||||
|
}
|
||||||
|
}
|
7
ld/testsuite/ld-scripts/phdrs2.s
Normal file
7
ld/testsuite/ld-scripts/phdrs2.s
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
.text
|
||||||
|
.align 4
|
||||||
|
.long 1
|
||||||
|
|
||||||
|
.data
|
||||||
|
.align 4
|
||||||
|
.long 2
|
23
ld/testsuite/ld-scripts/phdrs2.t
Normal file
23
ld/testsuite/ld-scripts/phdrs2.t
Normal file
@ -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/ : { *(.*) }
|
||||||
|
}
|
Reference in New Issue
Block a user