aboutsummaryrefslogtreecommitdiff
path: root/ld/testsuite/ld-elf
diff options
context:
space:
mode:
authorAndrew Burgess <andrew.burgess@embecosm.com>2017-01-17 19:13:29 +0000
committerAndrew Burgess <andrew.burgess@embecosm.com>2017-03-09 21:11:06 +0000
commit14ea2c1b230a62f312346fb16716b3dd4850815b (patch)
treedc74222ac0dccc9210afbc27a4c7e42ea1f3959d /ld/testsuite/ld-elf
parent77f5e65ecfb669ea1d2fd74b74fbbf0d0c20daf8 (diff)
downloadgdb-14ea2c1b230a62f312346fb16716b3dd4850815b.zip
gdb-14ea2c1b230a62f312346fb16716b3dd4850815b.tar.gz
gdb-14ea2c1b230a62f312346fb16716b3dd4850815b.tar.bz2
ld: Track changes to default region LMA even for empty sections
Given a linker script fragment like this: SECTIONS { . = 0x1000; .text : AT(0x100) { *(.text) } .data : AT(0x200) { *(.data) } .rodata : AT(0x300) { *(.rodata) } } and an input file containing sections, '.text', '.data.1', and '.rodata', then we'd expect the linker to place '.text' and '.rodata' in the obvious way, and the '.data.1' orphan section would be located after the '.data' section (assuming similar section properties). Further, I believe that the expectation would be that the LMA for the orphan '.data.1' section would start from 0x200 (as there is no '.data' content). However, right now, the LMA for '.data.1' would be 0x101, following on from the '.text' section, this is because the change in LMA for the '.data' section is not noticed by the linker, if there's no content in the '.data' section. What can be even more confusing to a user (though the cause is obvious once you understand what's going on) is that adding some content to '.data' will cause the orphan '.data.1' to switch to an LMA based off of 0x200. This commit changes the behaviour so that an empty section that is in the default lma region, and sets its lma, will adjust the lma of the default region, this change will then be reflected in following sections within the default lma memory region. There's a new test to cover this issue that passes on a range of targets, however, some targets generate additional sections, or have stricter memory region size requirements that make it harder to come up with a generic pass pattern, that still tests the required features. For now I've set the test to ignore these targets. ld/ChangeLog: * ldlang.c (lang_size_sections_1): Shortcut loop only after tracking changes to the default regions LMA. * testsuite/ld-elf/orphan-9.ld: Extend header comment. * testsuite/ld-elf/orphan-10.d: New file. * testsuite/ld-elf/orphan-10.s: New file. * NEWS: Mention change in behaviour.
Diffstat (limited to 'ld/testsuite/ld-elf')
-rw-r--r--ld/testsuite/ld-elf/orphan-10.d10
-rw-r--r--ld/testsuite/ld-elf/orphan-10.s8
-rw-r--r--ld/testsuite/ld-elf/orphan-9.ld10
3 files changed, 25 insertions, 3 deletions
diff --git a/ld/testsuite/ld-elf/orphan-10.d b/ld/testsuite/ld-elf/orphan-10.d
new file mode 100644
index 0000000..a5cf6d9
--- /dev/null
+++ b/ld/testsuite/ld-elf/orphan-10.d
@@ -0,0 +1,10 @@
+#source: orphan-10.s
+#ld: -N -T orphan-9.ld
+#objdump: -h
+#notarget: d30v-* dlx-* fr30-* frv-* ft32-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-*
+
+#...
+ . \.text 0+(08|10) [0-9a-f]+ 0+200 .*
+#...
+ . \.data\.1 0+8 [0-9a-f]+ 0+300 .*
+#pass
diff --git a/ld/testsuite/ld-elf/orphan-10.s b/ld/testsuite/ld-elf/orphan-10.s
new file mode 100644
index 0000000..b198966
--- /dev/null
+++ b/ld/testsuite/ld-elf/orphan-10.s
@@ -0,0 +1,8 @@
+ .text
+ .byte 0, 0, 0, 0, 0, 0, 0, 0
+
+ .section ".data.1", "aw"
+ .byte 0, 0, 0, 0, 0, 0, 0, 0
+
+ .section ".rodata", "a"
+ .byte 0, 0, 0, 0, 0, 0, 0, 0
diff --git a/ld/testsuite/ld-elf/orphan-9.ld b/ld/testsuite/ld-elf/orphan-9.ld
index 1a6773d..d8a3917 100644
--- a/ld/testsuite/ld-elf/orphan-9.ld
+++ b/ld/testsuite/ld-elf/orphan-9.ld
@@ -1,8 +1,12 @@
-/* This linker script is used for orphan-9 test.
+/* This linker script is used for orphan-9 and orphan-10 test.
- We have a single byte in .data, and an orphan .data.1
+ orphan-9: We have a single byte in .data, and an orphan .data.1
section. We are checking that the .data.1 orphan is assigned an
- LMA after .data rather than picking up the lma region of .rodata. */
+ LMA after .data rather than picking up the lma region of .rodata.
+
+ orphan-10: In this case we have nothing in .data and an orphan
+ .data.1, we are checking that .data.1 is assigned an LMA after
+ .data, rather than defaulting to take LMA == VMA. */
MEMORY
{