From: Nathan Sidwell Date: Wed, 28 Nov 2007 13:53:05 +0000 (+0000) Subject: * internal.h (ELF_IS_SECTION_IN_SEGMENT): Adjust to cope with X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f7bc09bdbcacf440e497242df536910f9f976346;p=binutils-gdb.git * internal.h (ELF_IS_SECTION_IN_SEGMENT): Adjust to cope with segments at the end of memory. --- diff --git a/include/elf/ChangeLog b/include/elf/ChangeLog index fe6134ded89..ded6712636a 100644 --- a/include/elf/ChangeLog +++ b/include/elf/ChangeLog @@ -1,3 +1,8 @@ +2007-11-28 Nathan Sidwell + + * internal.h (ELF_IS_SECTION_IN_SEGMENT): Adjust to cope with + segments at the end of memory. + 2007-11-16 Nick Clifton * dwarf2.h: Mention the location of the DWARF3 spec on the web. diff --git a/include/elf/internal.h b/include/elf/internal.h index f5380b8d514..93c2315e8d7 100644 --- a/include/elf/internal.h +++ b/include/elf/internal.h @@ -286,11 +286,12 @@ struct elf_segment_map || ((bfd_vma) sec_hdr->sh_offset >= segment->p_offset \ && (sec_hdr->sh_offset + ELF_SECTION_SIZE(sec_hdr, segment) \ <= segment->p_offset + segment->p_filesz))) \ - /* SHF_ALLOC sections must have VMAs within the segment. */ \ + /* SHF_ALLOC sections must have VMAs within the segment. Be \ + careful about segments right at the end of memory. */ \ && ((sec_hdr->sh_flags & SHF_ALLOC) == 0 \ || (sec_hdr->sh_addr >= segment->p_vaddr \ - && (sec_hdr->sh_addr + ELF_SECTION_SIZE(sec_hdr, segment) \ - <= segment->p_vaddr + segment->p_memsz)))) + && (sec_hdr->sh_addr - segment->p_vaddr \ + + ELF_SECTION_SIZE(sec_hdr, segment) <= segment->p_memsz)))) /* Decide if the given sec_hdr is in the given segment in file. */ #define ELF_IS_SECTION_IN_SEGMENT_FILE(sec_hdr, segment) \