From ec9acd130e2d4a8f8e314a2ae02f5d5f7b97a42d Mon Sep 17 00:00:00 2001 From: Nathan Sidwell Date: Wed, 28 Nov 2007 13:53:05 +0000 Subject: [PATCH] * internal.h (ELF_IS_SECTION_IN_SEGMENT): Adjust to cope with segments at the end of memory. --- include/elf/ChangeLog | 5 +++++ include/elf/internal.h | 7 ++++--- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/include/elf/ChangeLog b/include/elf/ChangeLog index fe6134ded..ded671263 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 f5380b8d5..93c2315e8 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) \ -- 2.11.4.GIT