]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - ld/testsuite/ld-powerpc/powerpc.exp
ARM/opcodes: Fix negative hexadecimal offset disassembly
[thirdparty/binutils-gdb.git] / ld / testsuite / ld-powerpc / powerpc.exp
CommitLineData
17c2bdee 1# Expect script for ld-powerpc tests
4b95cf5c 2# Copyright (C) 2002-2014 Free Software Foundation, Inc.
17c2bdee 3#
f96b4a7b
NC
4# This file is part of the GNU Binutils.
5#
6# This program is free software; you can redistribute it and/or modify
17c2bdee 7# it under the terms of the GNU General Public License as published by
f96b4a7b 8# the Free Software Foundation; either version 3 of the License, or
17c2bdee
AM
9# (at your option) any later version.
10#
11# This program is distributed in the hope that it will be useful,
12# but WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14# GNU General Public License for more details.
15#
16# You should have received a copy of the GNU General Public License
17# along with this program; if not, write to the Free Software
f96b4a7b
NC
18# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
19# MA 02110-1301, USA.
17c2bdee
AM
20#
21
22if { ![istarget "powerpc*-*-*"] } {
23 return
24}
25
4a3dc543
RS
26if {[istarget "*-*-vxworks"]} {
27 set ppcvxtests {
897aea50 28 {"VxWorks shared library test 1 (default script)" "-shared" ""
4a3dc543
RS
29 "-mregnames" {vxworks1-lib.s}
30 {{readelf --segments vxworks1-lib.sd}}
31 "libvxworks1.so"}
897aea50 32 {"VxWorks shared library test 1" "-shared -Tvxworks1.ld" ""
4a3dc543 33 "-mregnames" {vxworks1-lib.s}
711de32c 34 {{readelf --relocs vxworks1-lib.rd} {objdump -dr vxworks1-lib.dd}
e68ed250 35 {readelf --symbols vxworks1-lib.nd} {readelf -d vxworks1-lib.td}}
4a3dc543 36 "libvxworks1.so"}
4f471f39 37 {"VxWorks executable test 1 (dynamic)" \
897aea50 38 "tmpdir/libvxworks1.so -Tvxworks1.ld -q --force-dynamic" ""
4f471f39 39 "-mregnames" {vxworks1.s}
4a3dc543
RS
40 {{readelf --relocs vxworks1.rd} {objdump -dr vxworks1.dd}}
41 "vxworks1"}
4f471f39 42 {"VxWorks executable test 2 (dynamic)" \
897aea50 43 "-Tvxworks1.ld -q --force-dynamic" ""
4f471f39
RS
44 "-mregnames" {vxworks2.s}
45 {{readelf --segments vxworks2.sd}}
46 "vxworks2"}
47 {"VxWorks executable test 2 (static)"
897aea50 48 "-Tvxworks1.ld" ""
4f471f39
RS
49 "-mregnames" {vxworks2.s}
50 {{readelf --segments vxworks2-static.sd}}
51 "vxworks2"}
9bc4e62b 52 {"VxWorks relax test"
897aea50 53 "-Tvxworks1.ld --relax -q" ""
9bc4e62b
NS
54 "-mregnames" {vxworks-relax.s}
55 {{readelf --relocs vxworks-relax.rd}}
56 "vxworks-relax"}
c8a1f254 57 {"VxWorks relocatable relax test"
897aea50 58 "-Tvxworks1.ld -r --relax -q" ""
c8a1f254
NS
59 "-mregnames" {vxworks-relax-2.s}
60 {{readelf --relocs vxworks-relax-2.rd}}
61 "vxworks-relax-2"}
4a3dc543
RS
62 }
63 run_ld_link_tests $ppcvxtests
4f471f39 64 run_dump_test "vxworks1-static"
4a3dc543
RS
65 return
66}
67
e4e4a5d1
AM
68# powerpc ELF only at the moment. Disable for nto too, even though it
69# is ELF, because we pass -melf32ppc to ld and powerpc-nto-ld wants
70# -melf32ppcnto.
17c2bdee
AM
71
72if { [istarget "*-*-macos*"] || [istarget "*-*-netware*"]
73 || [istarget "*-*-pe"] || [istarget "*-*-winnt*"]
74 || [istarget "*-*-cygwin*"] || [istarget "*-*-aix*"]
e4e4a5d1
AM
75 || [istarget "*-*-beos*"] || [istarget "*-*-lynxos*"]
76 || [istarget "*-*-nto*"] } {
17c2bdee
AM
77 return
78}
79
266fb683
AM
80proc supports_ppc64 { } {
81 global ld
82
83 catch "exec $ld --help | grep emulations" tmp
65fd058f 84 if [ regexp "elf64l?ppc" $tmp ] then {
266fb683
AM
85 return 1
86 } else {
87 return 0
88 }
89}
90
17c2bdee 91# List contains test-items with 3 items followed by 2 lists:
897aea50
MR
92# 0:name 1:ld early options 2:ld late options 3:assembler options
93# 4:filenames of assembler files 5: action and options. 6: name of output file
17c2bdee
AM
94
95# Actions:
96# objdump: Apply objdump options on result. Compare with regex (last arg).
97# nm: Apply nm options on result. Compare with regex (last arg).
98# readelf: Apply readelf options on result. Compare with regex (last arg).
99
100set ppcelftests {
897aea50 101 {"Reloc section order" "-melf32ppc -shared -z nocombreloc" "" "-a32" {reloc.s}
17c2bdee 102 {{objdump -hw reloc.d}} "reloc.so"}
897aea50 103 {"APUinfo section processing" "-melf32ppc" ""
deddc40b 104 "-a32 -me500" {apuinfo1.s apuinfo-nul.s apuinfo2.s}
57316bff 105 {{readelf -x2 apuinfo.rd}} "apuinfo"}
897aea50 106 {"APUinfo NULL section processing" "-melf32ppc" ""
f2faa800
NS
107 "-a32 -me500" {apuinfo-nul1.s apuinfo-nul.s}
108 {{readelf -x2 apuinfo-nul.rd}} "apuinfo"}
897aea50 109 {"TLS32 static exec" "-melf32ppc" "" "-a32" {tls32.s tlslib32.s}
2a050fb5
AM
110 {{objdump -dr tls32.d} {objdump -sj.got tls32.g}
111 {objdump -sj.tdata tls32.t}}
112 "tls32"}
897aea50 113 {"TLS32 helper shared library" "-shared -melf32ppc tmpdir/tlslib32.o" "" "" {}
2a050fb5 114 {} "libtlslib32.so"}
897aea50 115 {"TLS32 dynamic exec" "-melf32ppc --no-ld-generated-unwind-info tmpdir/tls32.o tmpdir/libtlslib32.so" "" "" {}
2a050fb5
AM
116 {{readelf -WSsrl tlsexe32.r} {objdump -dr tlsexe32.d}
117 {objdump -sj.got tlsexe32.g} {objdump -sj.tdata tlsexe32.t}}
118 "tlsexe32"}
897aea50 119 {"TLS32 shared" "-shared -melf32ppc --no-ld-generated-unwind-info tmpdir/tls32.o" "" "" {}
2a050fb5
AM
120 {{readelf -WSsrl tlsso32.r} {objdump -dr tlsso32.d}
121 {objdump -sj.got tlsso32.g} {objdump -sj.tdata tlsso32.t}}
122 "tls32.so"}
897aea50 123 {"TLS32 markers" "-melf32ppc" "" "-a32" {tlsmark32.s tlslib32.s}
727fc41e
AM
124 {{objdump -dr tlsmark32.d}}
125 "tlsmark32"}
897aea50 126 {"TLS32 opt 1" "-melf32ppc" "" "-a32" {tlsopt1_32.s tlslib32.s}
663a1470
AM
127 {{objdump -dr tlsopt1_32.d}}
128 "tlsopt1_32"}
897aea50 129 {"TLS32 opt 2" "-melf32ppc" "" "-a32" {tlsopt2_32.s tlslib32.s}
663a1470
AM
130 {{objdump -dr tlsopt2_32.d}}
131 "tlsopt2_32"}
897aea50 132 {"TLS32 opt 3" "-melf32ppc" "" "-a32" {tlsopt3_32.s tlslib32.s}
663a1470
AM
133 {{objdump -dr tlsopt3_32.d}}
134 "tlsopt3_32"}
897aea50 135 {"TLS32 opt 4" "-melf32ppc" "" "-a32" {tlsopt4_32.s tlslib32.s}
663a1470
AM
136 {{objdump -dr tlsopt4_32.d}}
137 "tlsopt4_32"}
897aea50 138 {"Shared library with global symbol" "-shared -melf32ppc" "" "-a32" {sdalib.s}
4dc4a9a5 139 {} "sdalib.so"}
897aea50 140 {"Dynamic application with SDA" "-melf32ppc tmpdir/sdalib.so" "" "-a32" {sdadyn.s}
4dc4a9a5 141 {{objdump -R sdadyn.d}} "sdadyn"}
897aea50 142 {"relaxing" "-melf32ppc --relax -Ttext=0 --defsym far=0x80001234 --defsym near=0x00004320" "" "-a32" "relax.s"
9853c099
AS
143 {{objdump -dr relax.d}}
144 "relax"}
897aea50 145 {"relocatable relaxing" "-melf32ppc -r --relax" "" "-a32" "relax.s"
9853c099
AS
146 {{objdump -dr relaxr.d}}
147 "relax"}
17c2bdee
AM
148}
149
266fb683 150set ppc64elftests {
897aea50 151 {"TLS static exec" "-melf64ppc" "" "-a64" {tls.s tlslib.s}
266fb683
AM
152 {{objdump -dr tls.d} {objdump -sj.got tls.g} {objdump -sj.tdata tls.t}}
153 "tls"}
897aea50 154 {"TLS helper shared library" "-shared -melf64ppc tmpdir/tlslib.o" "" "" {}
266fb683 155 {} "libtlslib.so"}
897aea50 156 {"TLS helper old shared lib" "-shared -melf64ppc" "" "-a64" {oldtlslib.s}
a7f2871e 157 {} "liboldlib.so"}
897aea50 158 {"TLS dynamic exec" "-melf64ppc --no-ld-generated-unwind-info tmpdir/tls.o tmpdir/libtlslib.so" "" "" {}
266fb683
AM
159 {{readelf -WSsrl tlsexe.r} {objdump -dr tlsexe.d}
160 {objdump -sj.got tlsexe.g} {objdump -sj.tdata tlsexe.t}}
161 "tlsexe"}
897aea50 162 {"TLS dynamic old" "-melf64ppc --no-ld-generated-unwind-info tmpdir/tls.o tmpdir/liboldlib.so" "" "" {}
a7f2871e
AM
163 {{readelf -WSsrl tlsexe.r} {objdump -dr tlsexe.d}
164 {objdump -sj.got tlsexe.g} {objdump -sj.tdata tlsexe.t}}
165 "tlsexeold"}
897aea50 166 {"TLS shared" "-shared -melf64ppc --no-ld-generated-unwind-info tmpdir/tls.o" "" "" {}
266fb683
AM
167 {{readelf -WSsrl tlsso.r} {objdump -dr tlsso.d}
168 {objdump -sj.got tlsso.g} {objdump -sj.tdata tlsso.t}}
169 "tls.so"}
897aea50 170 {"TLSTOC static exec" "-melf64ppc tmpdir/tlslib.o " "" "-a64" {tlstoc.s}
1c0bd72e 171 {{objdump -dr tlstoc.d} {objdump -sj.got tlstoc.g}
266fb683
AM
172 {objdump -sj.tdata tlstoc.t}}
173 "tlstoc"}
897aea50 174 {"TLSTOC dynamic exec" "-melf64ppc --no-ld-generated-unwind-info tmpdir/tlstoc.o tmpdir/libtlslib.so" ""
266fb683
AM
175 "" {}
176 {{readelf -WSsrl tlsexetoc.r} {objdump -dr tlsexetoc.d}
1c0bd72e 177 {objdump -sj.got tlsexetoc.g} {objdump -sj.tdata tlsexetoc.t}}
266fb683 178 "tlsexetoc"}
897aea50 179 {"TLSTOC dynamic old" "-melf64ppc --no-ld-generated-unwind-info tmpdir/tlstoc.o tmpdir/liboldlib.so" ""
a7f2871e
AM
180 "" {}
181 {{readelf -WSsrl tlsexetoc.r} {objdump -dr tlsexetoc.d}
182 {objdump -sj.got tlsexetoc.g} {objdump -sj.tdata tlsexetoc.t}}
183 "tlsexetocold"}
897aea50 184 {"TLSTOC shared" "-shared -melf64ppc --no-ld-generated-unwind-info tmpdir/tlstoc.o" "" "" {}
266fb683 185 {{readelf -WSsrl tlstocso.r} {objdump -dr tlstocso.d}
1c0bd72e 186 {objdump -sj.got tlstocso.g} {objdump -sj.tdata tlstocso.t}}
266fb683 187 "tlstoc.so"}
897aea50 188 {"TLS markers" "-melf64ppc" "" "-a64" {tlsmark.s tlslib.s}
727fc41e
AM
189 {{objdump -dr tlsmark.d}}
190 "tlsmark"}
897aea50 191 {"TLS opt 1" "-melf64ppc" "" "-a64" {tlsopt1.s tlslib.s}
663a1470
AM
192 {{objdump -dr tlsopt1.d}}
193 "tlsopt1"}
897aea50 194 {"TLS opt 2" "-melf64ppc" "" "-a64" {tlsopt2.s tlslib.s}
663a1470
AM
195 {{objdump -dr tlsopt2.d}}
196 "tlsopt2"}
897aea50 197 {"TLS opt 3" "-melf64ppc" "" "-a64" {tlsopt3.s tlslib.s}
663a1470
AM
198 {{objdump -dr tlsopt3.d}}
199 "tlsopt3"}
897aea50 200 {"TLS opt 4" "-melf64ppc" "" "-a64" {tlsopt4.s tlslib.s}
663a1470
AM
201 {{objdump -dr tlsopt4.d}}
202 "tlsopt4"}
897aea50 203 {"sym@tocbase" "-shared -melf64ppc" "" "-a64" {symtocbase-1.s symtocbase-2.s}
08f46626 204 {{objdump -dj.data symtocbase.d}} "symtocbase.so"}
897aea50 205 {"TOC opt" "-melf64ppc" "" "-a64" {tocopt.s}
560c8763 206 {{ld tocopt.out} {objdump -s tocopt.d}} "tocopt"}
897aea50 207 {"TOC opt2" "-melf64ppc --defsym x=2" "" "-a64" {tocopt2.s}
2843fdaa 208 {{ld tocopt2.out} {objdump -s tocopt2.d}} "tocopt2"}
897aea50 209 {"TOC opt3" "-melf64ppc -no-keep-memory --defsym x=2" "" "-a64" {tocopt3.s}
2843fdaa 210 {{objdump -s tocopt3.d}} "tocopt3"}
897aea50 211 {"TOC opt4" "-melf64ppc -no-keep-memory --defsym x=2" "" "-a64"
365b60b0 212 {tocopt4a.s tocopt4b.s} {{objdump -s tocopt4.d}} "tocopt4"}
897aea50 213 {"TOC opt5" "-melf64ppc" "" "-a64" {tocopt5.s}
98528052 214 {{objdump -s tocopt5.d}} "tocopt5"}
f6c7c3e8
AM
215 {"ambig shared v1" "-shared -melf64ppc" "" "-a64" {funv1.s} {} "funv1.so"}
216 {"ambig shared v2" "-shared -melf64ppc" "" "-a64" {funv2.s} {} "funv2.so"}
266fb683
AM
217}
218
b9c361e0 219set ppceabitests {
897aea50 220 {"VLE multiple segments 1" "-T vle-multiseg-1.ld" ""
b9c361e0
JL
221 "-mregnames -mvle" {vle-multiseg.s}
222 {{readelf "-l" vle-multiseg-1.d}} "vle-multiseg-1"}
897aea50 223 {"VLE multiple segments 2" "-T vle-multiseg-2.ld" ""
b9c361e0
JL
224 "-mregnames -mvle" {vle-multiseg.s}
225 {{readelf "-l" vle-multiseg-2.d}} "vle-multiseg-2"}
897aea50 226 {"VLE multiple segments 3" "-T vle-multiseg-3.ld" ""
b9c361e0
JL
227 "-mregnames -mvle" {vle-multiseg.s}
228 {{readelf "-l" vle-multiseg-3.d}} "vle-multiseg-3"}
897aea50 229 {"VLE multiple segments 4" "-T vle-multiseg-4.ld" ""
b9c361e0
JL
230 "-mregnames -mvle" {vle-multiseg.s}
231 {{readelf "-l" vle-multiseg-4.d}} "vle-multiseg-4"}
897aea50 232 {"VLE multiple segments 5" "-T vle-multiseg-5.ld" ""
b9c361e0
JL
233 "-mregnames -mvle" {vle-multiseg.s}
234 {{readelf "-l" vle-multiseg-5.d}} "vle-multiseg-5"}
897aea50 235 {"VLE relocations 1" "-T vle.ld" ""
b9c361e0
JL
236 "-mvle" {vle-reloc-1.s vle-reloc-def-1.s}
237 {{objdump "-Mvle -d" vle-reloc-1.d}} "vle-reloc-1"}
897aea50 238 {"VLE relocations 2" "-T vle.ld" ""
b9c361e0
JL
239 "-mvle" {vle-reloc-2.s vle-reloc-def-2.s}
240 {{objdump "-Mvle -d" vle-reloc-2.d}} "vle-reloc-2"}
897aea50 241 {"VLE relocations 3" "-T vle.ld" ""
b9c361e0
JL
242 "-mvle" {vle-reloc-3.s vle-reloc-def-3.s}
243 {{objdump "-Mvle -d" vle-reloc-3.d}} "vle-reloc-3"}
244}
245
ed6b7ef4 246if [istarget "powerpc*le*-*-*"] then {
65fd058f 247 set options_regsub(ld) {{-melf([3264]*)ppc} {-melf\1lppc}}
ed6b7ef4
AM
248
249 for {set i 0} {$i < [llength $ppcelftests]} {incr i} {
250 set line [lindex $ppcelftests $i]
251 set ld_options [lindex $line 1]
252 regsub -all elf32ppc $ld_options elf32lppc ld_options
253 set line [lreplace $line 1 1 $ld_options]
254 set ppcelftests [lreplace $ppcelftests $i $i $line]
255 }
256
257 if [ supports_ppc64 ] then {
258 for {set i 0} {$i < [llength $ppc64elftests]} {incr i} {
65fd058f 259 set line [lindex $ppc64elftests $i]
ed6b7ef4
AM
260 set ld_options [lindex $line 1]
261 regsub -all elf64ppc $ld_options elf64lppc ld_options
262 set line [lreplace $line 1 1 $ld_options]
263 set ppc64elftests [lreplace $ppc64elftests $i $i $line]
264 }
265 }
266}
266fb683 267
17c2bdee 268run_ld_link_tests $ppcelftests
266fb683
AM
269
270if [ supports_ppc64 ] then {
271 run_ld_link_tests $ppc64elftests
faead562 272 run_dump_test "relbrlt"
d4a95d49
AM
273 run_dump_test "elfv2so"
274 run_dump_test "elfv2exe"
45965137
AM
275 run_dump_test "elfv2-2so"
276 run_dump_test "elfv2-2exe"
f6c7c3e8 277 run_dump_test "ambiguousv1"
d1eca1e4 278 run_dump_test "ambiguousv1b"
f6c7c3e8 279 run_dump_test "ambiguousv2"
d1eca1e4 280 run_dump_test "ambiguousv2b"
bffebb6b 281 run_dump_test "defsym"
266fb683 282}
faead562 283
b9c361e0
JL
284if { [istarget "powerpc*-eabi*"] } {
285 run_ld_link_tests $ppceabitests
286}
287
faead562 288run_dump_test "plt1"
34c8bcba
JM
289
290run_dump_test "attr-gnu-4-00"
291run_dump_test "attr-gnu-4-01"
292run_dump_test "attr-gnu-4-02"
3c7b9897 293run_dump_test "attr-gnu-4-03"
34c8bcba
JM
294run_dump_test "attr-gnu-4-10"
295run_dump_test "attr-gnu-4-11"
296run_dump_test "attr-gnu-4-12"
297run_dump_test "attr-gnu-4-13"
3c7b9897 298run_dump_test "attr-gnu-4-14"
34c8bcba
JM
299run_dump_test "attr-gnu-4-20"
300run_dump_test "attr-gnu-4-21"
301run_dump_test "attr-gnu-4-22"
3c7b9897
AM
302run_dump_test "attr-gnu-4-23"
303run_dump_test "attr-gnu-4-24"
34c8bcba 304run_dump_test "attr-gnu-4-31"
3c7b9897
AM
305run_dump_test "attr-gnu-4-32"
306run_dump_test "attr-gnu-4-33"
307run_dump_test "attr-gnu-4-34"
308run_dump_test "attr-gnu-4-41"
c6e65352
DJ
309
310run_dump_test "attr-gnu-8-11"
311run_dump_test "attr-gnu-8-23"
312run_dump_test "attr-gnu-8-31"
f82e0623
NF
313
314run_dump_test "attr-gnu-12-11"
315run_dump_test "attr-gnu-12-21"
b9c361e0
JL
316
317run_dump_test "vle-multiseg-6"