aboutsummaryrefslogtreecommitdiff
path: root/ld/testsuite/ld-msp430-elf
diff options
context:
space:
mode:
authorJozef Lawrynowicz <jozef.l@mittosystems.com>2019-04-17 15:05:08 +0100
committerNick Clifton <nickc@redhat.com>2019-04-17 15:05:08 +0100
commite25de718de3b613cfafb9c5b28dea8e55a8649b8 (patch)
tree91742b2c280836b8223b3e509ac7c642d9b81251 /ld/testsuite/ld-msp430-elf
parentafff667ae800adee5934020c92012e3ecbf4dabd (diff)
downloadgdb-e25de718de3b613cfafb9c5b28dea8e55a8649b8.zip
gdb-e25de718de3b613cfafb9c5b28dea8e55a8649b8.tar.gz
gdb-e25de718de3b613cfafb9c5b28dea8e55a8649b8.tar.bz2
MSP430 Linker: Define __crt0_init_bss/__crt0_movedata symbols when .lower or .either prefixed sections are present.
ld * config/tc-msp430.c (msp430_make_init_symbols): Define __crt0_init_bss symbol when .lower.bss or .either.bss sections exist. Define __crt0_movedata when .lower.data or .either.data sections exist. * testsuite/gas/msp430/either-data-bss-sym.d: New test. * testsuite/gas/msp430/low-data-bss-sym.d: New test. * testsuite/gas/msp430/either-data-bss-sym.s: New test source. * testsuite/gas/msp430/low-data-bss-sym.s: New test source. * testsuite/gas/msp430/msp430.exp: Run new tests. Enable large code model when running -mdata-region={upper,either} tests.
Diffstat (limited to 'ld/testsuite/ld-msp430-elf')
-rw-r--r--ld/testsuite/ld-msp430-elf/msp430-elf.exp52
-rw-r--r--ld/testsuite/ld-msp430-elf/valid-map-foo.s26
-rw-r--r--ld/testsuite/ld-msp430-elf/valid-map.d6
-rw-r--r--ld/testsuite/ld-msp430-elf/valid-map.map6
-rw-r--r--ld/testsuite/ld-msp430-elf/valid-map.s60
-rw-r--r--ld/testsuite/ld-msp430-elf/warn-no-lower-code.r1
-rw-r--r--ld/testsuite/ld-msp430-elf/warn-no-lower-data.r3
-rw-r--r--ld/testsuite/ld-msp430-elf/warn-no-lower.r4
-rw-r--r--ld/testsuite/ld-msp430-elf/warn-no-lower.s44
9 files changed, 193 insertions, 9 deletions
diff --git a/ld/testsuite/ld-msp430-elf/msp430-elf.exp b/ld/testsuite/ld-msp430-elf/msp430-elf.exp
index 8996d3f..b6f3151 100644
--- a/ld/testsuite/ld-msp430-elf/msp430-elf.exp
+++ b/ld/testsuite/ld-msp430-elf/msp430-elf.exp
@@ -23,15 +23,29 @@ if { ![istarget "msp430*elf*"] } {
return
}
-# List contains test-items with 3 items followed by 2 lists and one more item:
-# 0:name 1:ld early options 2:ld late options 3:assembler options
-# 4:filenames of assembler files 5: action and options. 6: name of output file
-
-# Actions:
-# objdump: Apply objdump options on result. Compare with regex (last arg).
-# nm: Apply nm options on result. Compare with regex (last arg).
-# readelf: Apply readelf options on result. Compare with regex (last arg).
-
+# List contains test-items with 3 items followed by 2 lists, one item and
+# one optional item:
+# 0:name
+# 1:ld/ar leading options, placed before object files
+# 2:ld/ar trailing options, placed after object files
+# 3:assembler options
+# 4:filenames of assembler files
+# 5:list of actions, options and expected outputs.
+# 6:name of output file
+# 7:compiler flags (optional)
+#
+# Actions: { command command-line-options file-containg-expected-output-regexps }
+# Commands:
+# objdump: Apply objdump options on result.
+# nm: Apply nm options on result.
+# readelf: Apply readelf options on result.
+# ld: Don't apply anything on result. Compare output during linking with
+# the file containing regexps (which is the second arg, not the third).
+# Note that this *must* be the first action if it is to be used at all;
+# in all other cases, any output from the linker during linking is
+# treated as a sign of an error and FAILs the test.
+#
+#
set msp430regionprefixtests {
{"Move main() to .upper.text" "-T msp430.ld --code-region=upper"
"" "" {main-with-text-rodata.s} {{objdump -d main-text-upper.d}} "main-upper"}
@@ -136,6 +150,26 @@ set msp430eithershuffletests {
{{objdump -D main-const-upper.d}} "either-to-upper-const-unique-sec"}
}
+set msp430warntests {
+ {"Warn when section cannot be transformed because output section does not exist in linker script (text,data,bss,rodata)"
+ "-T msp430-no-lower.ld --code-region=lower --data-region=lower" "" "" {warn-no-lower.s}
+ {{ld warn-no-lower.r}} "warn-no-lower"}
+ {"Warn when section cannot be transformed because output section does not exist in linker script (text only)"
+ "-T msp430-no-lower.ld --code-region=lower" "" "" {warn-no-lower.s}
+ {{ld warn-no-lower-code.r}} "warn-no-lower-code"}
+ {"Warn when section cannot be transformed because output section does not exist in linker script (data,bss,rodata)"
+ "-T msp430-no-lower.ld --data-region=lower" "" "" {warn-no-lower.s}
+ {{ld warn-no-lower-data.r}} "warn-no-lower-data"}
+}
+
+# Don't run section shuffle tests when msp430 ISA is selected
+if {[string match "*-mcpu=msp430 *" [board_info [target_info name] multilib_flags]]
+ || [string match "*-mcpu=msp430" [board_info [target_info name] multilib_flags]]} {
+ return
+}
run_ld_link_tests $msp430regionprefixtests
run_ld_link_tests $msp430regionprefixuniquesectiontests
run_ld_link_tests $msp430eithershuffletests
+run_ld_link_tests $msp430warntests
+
+run_dump_test valid-map
diff --git a/ld/testsuite/ld-msp430-elf/valid-map-foo.s b/ld/testsuite/ld-msp430-elf/valid-map-foo.s
new file mode 100644
index 0000000..3296139
--- /dev/null
+++ b/ld/testsuite/ld-msp430-elf/valid-map-foo.s
@@ -0,0 +1,26 @@
+ .file "foo.c"
+.text
+ .section .text.foo1,"ax",@progbits
+ .balign 2
+ .global foo1
+ .type foo1, @function
+foo1:
+; start of function
+; framesize_regs: 0
+; framesize_locals: 0
+; framesize_outgoing: 0
+; framesize: 0
+; elim ap -> fp 2
+; elim fp -> sp 0
+; saved regs:(none)
+ ; start of prologue
+ ; end of prologue
+ NOP
+.L2:
+ MOV.W &a, R12
+ CMP.W #0, R12 { JNE .L2
+ MOV.B #0, R12
+ ; start of epilogue
+ RET
+ .size foo1, .-foo1
+ .ident "GCC: (jozef) 7.3.2"
diff --git a/ld/testsuite/ld-msp430-elf/valid-map.d b/ld/testsuite/ld-msp430-elf/valid-map.d
new file mode 100644
index 0000000..cb82406
--- /dev/null
+++ b/ld/testsuite/ld-msp430-elf/valid-map.d
@@ -0,0 +1,6 @@
+# source: valid-map-foo.s
+# source: valid-map.s
+# ld: -Map=valid-map.map --code-region=lower --script=msp430.ld
+# map: valid-map.map
+
+#pass
diff --git a/ld/testsuite/ld-msp430-elf/valid-map.map b/ld/testsuite/ld-msp430-elf/valid-map.map
new file mode 100644
index 0000000..39e3979
--- /dev/null
+++ b/ld/testsuite/ld-msp430-elf/valid-map.map
@@ -0,0 +1,6 @@
+# Test that the transformed section name foo1 from foo.s appears correctly
+# in the map file
+
+#...
+ .lower.text.foo1
+#pass
diff --git a/ld/testsuite/ld-msp430-elf/valid-map.s b/ld/testsuite/ld-msp430-elf/valid-map.s
new file mode 100644
index 0000000..feeb503
--- /dev/null
+++ b/ld/testsuite/ld-msp430-elf/valid-map.s
@@ -0,0 +1,60 @@
+ .file "tester.c"
+.text
+ .global a
+.data
+ .balign 2
+ .type a, @object
+ .size a, 2
+a:
+ .short 5
+.text
+ .balign 2
+ .global foo
+ .type foo, @function
+foo:
+; start of function
+; framesize_regs: 0
+; framesize_locals: 2
+; framesize_outgoing: 0
+; framesize: 2
+; elim ap -> fp 2
+; elim fp -> sp 2
+; saved regs:(none)
+ ; start of prologue
+ SUB.W #2, R1
+ ; end of prologue
+ MOV.W R12, @R1
+ MOV.W @R1, R12
+ ADD.W #-2, R12
+ MOV.W @R12, R12
+ CMP.W #0, R12 { JEQ .L2
+ MOV.B #0, R12
+ BR #.L3
+.L2:
+ MOV.B #1, R12
+.L3:
+ ; start of epilogue
+ ADD.W #2, R1
+ RET
+ .size foo, .-foo
+ .balign 2
+ .global main
+ .type main, @function
+main:
+; start of function
+; framesize_regs: 0
+; framesize_locals: 0
+; framesize_outgoing: 0
+; framesize: 0
+; elim ap -> fp 2
+; elim fp -> sp 0
+; saved regs:(none)
+ ; start of prologue
+ ; end of prologue
+ MOV.W #a, R12
+ CALL #foo
+ ; start of epilogue
+ .refsym __crt0_call_exit
+ RET
+ .size main, .-main
+ .ident "GCC: (jozef) 7.3.2"
diff --git a/ld/testsuite/ld-msp430-elf/warn-no-lower-code.r b/ld/testsuite/ld-msp430-elf/warn-no-lower-code.r
new file mode 100644
index 0000000..de05e77
--- /dev/null
+++ b/ld/testsuite/ld-msp430-elf/warn-no-lower-code.r
@@ -0,0 +1 @@
+.*warning: no input section rule matches .lower.text in linker script
diff --git a/ld/testsuite/ld-msp430-elf/warn-no-lower-data.r b/ld/testsuite/ld-msp430-elf/warn-no-lower-data.r
new file mode 100644
index 0000000..1c81612
--- /dev/null
+++ b/ld/testsuite/ld-msp430-elf/warn-no-lower-data.r
@@ -0,0 +1,3 @@
+.*warning: no input section rule matches .lower.data in linker script
+.*warning: no input section rule matches .lower.bss in linker script
+.*warning: no input section rule matches .lower.rodata in linker script
diff --git a/ld/testsuite/ld-msp430-elf/warn-no-lower.r b/ld/testsuite/ld-msp430-elf/warn-no-lower.r
new file mode 100644
index 0000000..53c82db
--- /dev/null
+++ b/ld/testsuite/ld-msp430-elf/warn-no-lower.r
@@ -0,0 +1,4 @@
+.*warning: no input section rule matches .lower.text in linker script
+.*warning: no input section rule matches .lower.data in linker script
+.*warning: no input section rule matches .lower.bss in linker script
+.*warning: no input section rule matches .lower.rodata in linker script
diff --git a/ld/testsuite/ld-msp430-elf/warn-no-lower.s b/ld/testsuite/ld-msp430-elf/warn-no-lower.s
new file mode 100644
index 0000000..4c8e20d
--- /dev/null
+++ b/ld/testsuite/ld-msp430-elf/warn-no-lower.s
@@ -0,0 +1,44 @@
+ .file "tester.c"
+.text
+ .global foo
+ .section .rodata
+.LC0:
+ .string "bar"
+ .section .data,"aw",@progbits
+ .balign 2
+ .type foo, @object
+ .size foo, 2
+foo:
+ .short .LC0
+ .section .text,"ax",@progbits
+ .balign 2
+ .global main
+ .type main, @function
+main:
+; start of function
+; framesize_regs: 0
+; framesize_locals: 2
+; framesize_outgoing: 0
+; framesize: 2
+; elim ap -> fp 2
+; elim fp -> sp 2
+; saved regs:(none)
+ ; start of prologue
+ SUB.W #2, R1
+ ; end of prologue
+ MOV.W #1, @R1
+ BR #.L2
+.L3:
+ MOV.W &foo, R12
+ ADD.W #-1, R12
+ MOV.W R12, &foo
+.L2:
+ MOV.W @R1, R12
+ CMP.W #0, R12 { JNE .L3
+ MOV.B #0, R12
+ ; start of epilogue
+ .refsym __crt0_call_exit
+ ADD.W #2, R1
+ RET
+ .size main, .-main
+ .ident "GCC: (jozef) 7.3.2"