]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
ld: add an error in case of address space overflow.
authorTristan Gingold <gingold@adacore.com>
Fri, 10 Mar 2017 14:16:19 +0000 (15:16 +0100)
committerTristan Gingold <gingold@adacore.com>
Mon, 13 Mar 2017 09:41:22 +0000 (10:41 +0100)
ld/
* ldlang.c (lang_check_section_addresses): Check for address space
overflow.
* testsuite/ld-checks/checks.exp (overflow_check): New procedure
* testsuite/ld-checks/over.s: New test source.
* testsuite/ld-checks/over.d: New test.
* testsuite/ld-checks/over2.s: New test source.
* testsuite/ld-checks/over2.d: New test.

ld/ChangeLog
ld/ldlang.c
ld/testsuite/ld-checks/checks.exp
ld/testsuite/ld-checks/over.d [new file with mode: 0644]
ld/testsuite/ld-checks/over.s [new file with mode: 0644]
ld/testsuite/ld-checks/over2.d [new file with mode: 0644]
ld/testsuite/ld-checks/over2.s [new file with mode: 0644]

index 44e6895504fe201994eb95a4ad43c1b6a070d1a8..c164710a2eda0501d52ef019f4050c5689d09ac4 100644 (file)
@@ -1,3 +1,13 @@
+2017-03-13  Tristan Gingold  <gingold@adacore.com>
+
+       * ldlang.c (lang_check_section_addresses): Check for address space
+       overflow.
+       * testsuite/ld-checks/checks.exp (overflow_check): New procedure
+       * testsuite/ld-checks/over.s: New test source.
+       * testsuite/ld-checks/over.d: New test.
+       * testsuite/ld-checks/over2.s: New test source.
+       * testsuite/ld-checks/over2.d: New test.
+
 2017-03-13  Alexey Neyman  <stilor@att.net>
 
        * emulparams/elf32ppccommon.sh (LIBPATH_SUFFIX): Set from target
index 6011a00cd5bad0552a92dfe1f4169df363929a5d..a0638eae235a1aa5712c1a2e0606ebd1972cae63 100644 (file)
@@ -4768,6 +4768,7 @@ lang_check_section_addresses (void)
   asection *s, *p;
   struct check_sec *sections;
   size_t i, count;
+  bfd_vma addr_mask;
   bfd_vma s_start;
   bfd_vma s_end;
   bfd_vma p_start = 0;
@@ -4775,6 +4776,25 @@ lang_check_section_addresses (void)
   lang_memory_region_type *m;
   bfd_boolean overlays;
 
+  /* Detect address space overflow.  */
+  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)
+       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)
+           einfo (_("%X%P: section %s LMA wraps around address space\n"),
+                  s->name);
+       }
+    }
+
   if (bfd_count_sections (link_info.output_bfd) <= 1)
     return;
 
index b1c8454921b43e479b8cfb5f97dbe69f39e75132..782f50a4c0d215f7dc4d09e114f829702706bfb7 100644 (file)
@@ -78,4 +78,17 @@ proc section_check {} {
     }
 }
 
+proc overflow_check {} {
+    # Test only on some 32-bit targets that are often tested
+    if { ![istarget i?86-*-*]
+        && ![istarget powerpc-*-*]
+        && ![istarget arm*-*-*] } {
+       return
+    }
+
+    run_dump_test "over"
+    run_dump_test "over2"
+}
+
 section_check
+overflow_check
diff --git a/ld/testsuite/ld-checks/over.d b/ld/testsuite/ld-checks/over.d
new file mode 100644 (file)
index 0000000..e34bea9
--- /dev/null
@@ -0,0 +1,4 @@
+#name: section size overflow
+#source: over.s
+#ld: -Ttext=0xfffffffc
+#error: .* section .text VMA wraps around address space
diff --git a/ld/testsuite/ld-checks/over.s b/ld/testsuite/ld-checks/over.s
new file mode 100644 (file)
index 0000000..7f8d4b5
--- /dev/null
@@ -0,0 +1,7 @@
+       .text
+       .globl _start
+_start:
+       .long 0
+       .long 0
+       .long 0
+       .long 0
diff --git a/ld/testsuite/ld-checks/over2.d b/ld/testsuite/ld-checks/over2.d
new file mode 100644 (file)
index 0000000..511b917
--- /dev/null
@@ -0,0 +1,8 @@
+#name: section size overflow
+#source: over2.s
+#ld: -Ttext=0xfffffffc
+#nm: -n
+
+#...
+fffffffc T _start
+#pass
diff --git a/ld/testsuite/ld-checks/over2.s b/ld/testsuite/ld-checks/over2.s
new file mode 100644 (file)
index 0000000..dc6de0e
--- /dev/null
@@ -0,0 +1,4 @@
+       .text
+       .globl _start
+_start:
+       .long 0