diff options
author | Nick Clifton <nickc@redhat.com> | 2002-02-13 10:20:59 +0000 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2002-02-13 10:20:59 +0000 |
commit | bf36db1824820273d5766b88bdcd75bd51e05f08 (patch) | |
tree | 9533e28a71203cdc56a711b2fa85833b0947ef7b /bfd/elf.c | |
parent | 6cdd886ce9775afcb1f968f3a6d4a934b5d5e5b7 (diff) | |
download | gdb-bf36db1824820273d5766b88bdcd75bd51e05f08.zip gdb-bf36db1824820273d5766b88bdcd75bd51e05f08.tar.gz gdb-bf36db1824820273d5766b88bdcd75bd51e05f08.tar.bz2 |
Accept a physicall address of 0 as valid in a program header
Diffstat (limited to 'bfd/elf.c')
-rw-r--r-- | bfd/elf.c | 11 |
1 files changed, 8 insertions, 3 deletions
@@ -652,10 +652,15 @@ _bfd_elf_make_section_from_shdr (abfd, hdr, name) offset plus size lies within the segment's memory span and, if the section is loaded, the extent of the loaded data lies within the extent of the segment. - If the p_paddr field is not set, we don't alter the - LMA. */ + + Note - we used to check the p_paddr field as well, and + refuse to set the LMA if it was 0. This is wrong + though as a perfectly valid, initialised segment can + have a p_paddr of zero. Some architectures, eg ARM, + place special significance one the address 0 and + executables need to be able to have a segment which + covers this address. */ if (phdr->p_type == PT_LOAD - && phdr->p_paddr && (bfd_vma) hdr->sh_offset >= phdr->p_offset && (hdr->sh_offset + hdr->sh_size <= phdr->p_offset + phdr->p_memsz) |