From: Tristan Gingold Date: Fri, 17 Mar 2017 10:12:05 +0000 (+0100) Subject: ld: check overflow only for allocated sections. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=21701718895d186285e6daf04cc7342c6c88fb03;p=binutils-gdb.git ld: check overflow only for allocated sections. * ldlang.c (lang_check_section_addresses): Check only for allocated sections. --- diff --git a/ld/ChangeLog b/ld/ChangeLog index 4af309bf584..e42df383375 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,8 @@ +2017-03-21 gingold + + * ldlang.c (lang_check_section_addresses): Check only for + allocated sections. + 2017-03-17 Alan Modra * testsuite/ld-elf/sec64k.exp: Don't run on h8300 and ip2k. diff --git a/ld/ldlang.c b/ld/ldlang.c index 8c1d8299c37..5a426596743 100644 --- a/ld/ldlang.c +++ b/ld/ldlang.c @@ -4776,24 +4776,25 @@ lang_check_section_addresses (void) lang_memory_region_type *m; bfd_boolean overlays; - /* Detect address space overflow. */ + /* Detect address space overflow on allocated sections. */ addr_mask = ((bfd_vma) 1 << (bfd_arch_bits_per_address (link_info.output_bfd) - 1)) - 1; addr_mask = (addr_mask << 1) + 1; for (s = link_info.output_bfd->sections; s != NULL; s = s->next) - { - s_end = (s->vma + s->size) & addr_mask; - if (s_end != 0 && s_end < (s->vma & addr_mask)) - einfo (_("%X%P: section %s VMA wraps around address space\n"), - s->name); - else - { - s_end = (s->lma + s->size) & addr_mask; - if (s_end != 0 && s_end < (s->lma & addr_mask)) - einfo (_("%X%P: section %s LMA wraps around address space\n"), - s->name); - } - } + if ((s->flags & SEC_ALLOC) != 0) + { + s_end = (s->vma + s->size) & addr_mask; + if (s_end != 0 && s_end < (s->vma & addr_mask)) + einfo (_("%X%P: section %s VMA wraps around address space\n"), + s->name); + else + { + s_end = (s->lma + s->size) & addr_mask; + if (s_end != 0 && s_end < (s->lma & addr_mask)) + einfo (_("%X%P: section %s LMA wraps around address space\n"), + s->name); + } + } if (bfd_count_sections (link_info.output_bfd) <= 1) return;