[PowerPC64] pc-relative TLS relocations
[external/binutils.git] / ld / testsuite / ld-powerpc / powerpc.exp
1 # Expect script for ld-powerpc tests
2 #   Copyright (C) 2002-2019 Free Software Foundation, Inc.
3 #
4 # This file is part of the GNU Binutils.
5 #
6 # This program is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 3 of the License, or
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
18 # Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
19 # MA 02110-1301, USA.
20 #
21
22 if { ![istarget "powerpc*-*-*"] } {
23     return
24 }
25
26 if {[istarget "*-*-vxworks"]} {
27     set ppcvxtests {
28         {"VxWorks shared library test 1 (default script)" "-shared" ""
29          "-mregnames" {vxworks1-lib.s}
30          {{readelf --segments vxworks1-lib.sd}}
31          "libvxworks1.so"}
32         {"VxWorks shared library test 1"
33          "-shared --hash-style=sysv -Tvxworks1.ld" ""
34          "-mregnames" {vxworks1-lib.s}
35          {{readelf --relocs vxworks1-lib.rd} {objdump -dr vxworks1-lib.dd}
36           {readelf --symbols vxworks1-lib.nd} {readelf -d vxworks1-lib.td}}
37          "libvxworks1.so"}
38         {"VxWorks executable test 1 (dynamic)" \
39          "tmpdir/libvxworks1.so -Tvxworks1.ld -q --force-dynamic --hash-style=sysv" ""
40          "-mregnames" {vxworks1.s}
41          {{readelf --relocs vxworks1.rd} {objdump -dr vxworks1.dd}}
42          "vxworks1"}
43         {"VxWorks executable test 2 (dynamic)" \
44          "-Tvxworks1.ld -q --force-dynamic --hash-style=sysv" ""
45          "-mregnames" {vxworks2.s}
46          {{readelf --segments vxworks2.sd}}
47          "vxworks2"}
48         {"VxWorks executable test 2 (static)"
49          "-Tvxworks1.ld --hash-style=sysv" ""
50          "-mregnames" {vxworks2.s}
51          {{readelf --segments vxworks2-static.sd}}
52          "vxworks2"}
53         {"VxWorks relax test"
54          "-Tvxworks1.ld --relax -q --hash-style=sysv" ""
55          "-mregnames" {vxworks-relax.s}
56          {{readelf --relocs vxworks-relax.rd}}
57          "vxworks-relax"}
58         {"VxWorks relocatable relax test"
59          "-Tvxworks1.ld -r --relax -q --hash-style=sysv" ""
60          "-mregnames" {vxworks-relax-2.s}
61          {{readelf --relocs vxworks-relax-2.rd}}
62          "vxworks-relax-2"}
63     }
64     run_ld_link_tests $ppcvxtests
65     run_dump_test "vxworks1-static"
66     return
67 }
68
69 # powerpc ELF only at the moment.  Disable for nto too, even though it
70 # is ELF, because we pass -melf32ppc to ld and powerpc-nto-ld wants
71 # -melf32ppcnto.
72
73 if { [istarget "*-*-macos*"]
74      || [istarget "*-*-pe"] || [istarget "*-*-winnt*"]
75      || [istarget "*-*-cygwin*"] || [istarget "*-*-aix*"]
76      || [istarget "*-*-beos*"] || [istarget "*-*-lynxos*"]
77      || [istarget "*-*-nto*"] } {
78     return
79 }
80
81 proc supports_ppc64 { } {
82     global ld
83
84     catch "exec $ld --help | grep emulations" tmp
85     if [ regexp "elf64l?ppc" $tmp ] then {
86         return 1
87     } else {
88         return 0
89     }
90 }
91
92 # List contains test-items with 3 items followed by 2 lists:
93 # 0:name 1:ld early options 2:ld late options 3:assembler options
94 # 4:filenames of assembler files 5: action and options. 6: name of output file
95
96 # Actions:
97 # objdump: Apply objdump options on result.  Compare with regex (last arg).
98 # nm: Apply nm options on result.  Compare with regex (last arg).
99 # readelf: Apply readelf options on result.  Compare with regex (last arg).
100
101 set ppcelftests {
102     {"Reloc section order" "-melf32ppc -shared -z nocombreloc" "" "-a32" {reloc.s}
103      {{objdump -hw reloc.d}} "reloc.so"}
104     {"APUinfo section processing" "-melf32ppc" ""
105      "-a32 -me500" {apuinfo1.s apuinfo-nul.s apuinfo2.s}
106      {{readelf -x2 apuinfo.rd}} "apuinfo"}
107     {"APUinfo VLE section processing" "-melf32ppc" ""
108      "-a32 -me500 -mvle" {apuinfo1.s apuinfo-vle.s apuinfo-vle2.s}
109      {{readelf -x2 apuinfo-vle.rd}} "apuinfo-vle"}
110     {"APUinfo NULL section processing" "-melf32ppc" ""
111      "-a32 -me500" {apuinfo-nul1.s apuinfo-nul.s}
112      {{readelf -x2 apuinfo-nul.rd}} "apuinfo"}
113     {"TLS32 static exec (markers)" "-melf32ppc" ""
114      "-a32 --defsym TLSMARK=1"  {tls32.s tlslib32.s}
115      {{objdump -dr tls32.d} {objdump -sj.got tls32.g}
116       {objdump -sj.tdata tls32.t}}
117      "tls32m"}
118     {"TLS32 static exec" "-melf32ppc" "" "-a32"  {tls32.s tlslib32.s}
119      {{objdump -dr tls32.d} {objdump -sj.got tls32.g}
120       {objdump -sj.tdata tls32.t}}
121      "tls32"}
122     {"TLS32 helper shared library" "-shared -melf32ppc tmpdir/tlslib32.o" "" "" {}
123      {} "libtlslib32.so"}
124     {"TLS32 dynamic exec" "-melf32ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls32.o tmpdir/libtlslib32.so" "" "" {}
125      {{readelf -WSsrl tlsexe32.r} {objdump -dr tlsexe32.d}
126       {objdump -sj.got tlsexe32.g} {objdump -sj.tdata tlsexe32.t}}
127      "tlsexe32"}
128     {"TLS32 shared" "-shared -melf32ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls32.o" "" "" {}
129      {{readelf -WSsrl tlsso32.r} {objdump -dr tlsso32.d}
130       {objdump -sj.got tlsso32.g} {objdump -sj.tdata tlsso32.t}}
131      "tls32.so"}
132     {"TLS32 markers" "-melf32ppc" "" "-a32"  {tlsmark32.s tlslib32.s}
133      {{objdump -dr tlsmark32.d}}
134      "tlsmark32"}
135     {"TLS32 opt 1" "-melf32ppc" "" "-a32"  {tlsopt1_32.s tlslib32.s}
136      {{objdump -dr tlsopt1_32.d}}
137      "tlsopt1_32"}
138     {"TLS32 opt 2" "-melf32ppc" "" "-a32"  {tlsopt2_32.s tlslib32.s}
139      {{objdump -dr tlsopt2_32.d}}
140      "tlsopt2_32"}
141     {"TLS32 opt 3" "-melf32ppc" "" "-a32"  {tlsopt3_32.s tlslib32.s}
142      {{objdump -dr tlsopt3_32.d}}
143       "tlsopt3_32"}
144     {"TLS32 opt 4" "-melf32ppc" "" "-a32"  {tlsopt4_32.s tlslib32.s}
145      {{objdump -dr tlsopt4_32.d}}
146      "tlsopt4_32"}
147     {"TLS32 DLL" "-shared -melf32ppc --version-script tlsdll.ver" ""
148      "-a32" {tlsdll_32.s}
149      {} "tlsdll32.so"}
150     {"TLS32 opt 5" "-melf32ppc -shared --gc-sections --secure-plt --no-plt-align tmpdir/tlsdll32.so" "" "-a32"  {tlsopt5_32.s}
151      {{objdump -dr tlsopt5_32.d}}
152      "tlsopt5_32"}
153     {"Shared library with global symbol" "-shared -melf32ppc" "" "-a32" {sdalib.s}
154      {} "sdalib.so"}
155     {"Dynamic application with SDA" "-melf32ppc tmpdir/sdalib.so" "" "-a32" {sdadyn.s}
156      {{objdump -R sdadyn.d}} "sdadyn"}
157     {"relaxing" "-melf32ppc --relax -Ttext=0 --defsym far=0x80001234 --defsym near=0x00004320" "" "-a32" "relax.s"
158      {{objdump -dr relax.d}}
159      "relax"}
160     {"relocatable relaxing" "-melf32ppc -r --relax" "" "-a32" "relax.s"
161      {{objdump -dr relaxr.d}}
162      "rrelax"}
163     {"relocatable relaxing large" "-melf32ppc -r --relax" "" "-a32" "relax.s big.s"
164      {{objdump -dr relaxrl.d}}
165      "rrelax"}
166 }
167
168 set ppc64elftests {
169     {"TLS static exec (markers)" "-melf64ppc --no-plt-align" ""
170      "-a64 --defsym TLSMARK=1"  {tls.s tlslib.s}
171      {{objdump -dr tls.d} {objdump -sj.got tls.g} {objdump -sj.tdata tls.t}}
172      "tlsm"}
173     {"TLS static exec" "-melf64ppc --no-plt-align" "" "-a64"  {tls.s tlslib.s}
174      {{objdump -dr tls.d} {objdump -sj.got tls.g} {objdump -sj.tdata tls.t}}
175      "tls"}
176     {"TLS helper shared library" "-shared -melf64ppc tmpdir/tlslib.o" "" "" {}
177      {} "libtlslib.so"}
178     {"TLS helper old shared lib" "-shared -melf64ppc" "" "-a64" {oldtlslib.s}
179      {} "liboldlib.so"}
180     {"TLS dynamic exec" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls.o tmpdir/libtlslib.so" "" "" {}
181      {{readelf -WSsrl tlsexe.r} {objdump -dr tlsexe.d}
182       {objdump -sj.got tlsexe.g} {objdump -sj.tdata tlsexe.t}}
183      "tlsexe"}
184     {"TLS dynamic old" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls.o tmpdir/liboldlib.so" "" "" {}
185      {{readelf -WSsrl tlsexe.r} {objdump -dr tlsexe.d}
186       {objdump -sj.got tlsexe.g} {objdump -sj.tdata tlsexe.t}}
187      "tlsexeold"}
188     {"TLS shared" "-shared -melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls.o" "" "" {}
189      {{readelf -WSsrl tlsso.r} {objdump -dr tlsso.d}
190       {objdump -sj.got tlsso.g} {objdump -sj.tdata tlsso.t}}
191      "tls.so"}
192     {"TLSTOC static exec" "-melf64ppc tmpdir/tlslib.o " "" "-a64"  {tlstoc.s}
193      {{objdump -dr tlstoc.d} {objdump -sj.got tlstoc.g}
194       {objdump -sj.tdata tlstoc.t}}
195      "tlstoc"}
196     {"TLSTOC dynamic exec" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tlstoc.o tmpdir/libtlslib.so" ""
197      "" {}
198      {{readelf -WSsrl tlsexetoc.r} {objdump -dr tlsexetoc.d}
199       {objdump -sj.got tlsexetoc.g} {objdump -sj.tdata tlsexetoc.t}}
200      "tlsexetoc"}
201     {"TLSTOC dynamic old" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tlstoc.o tmpdir/liboldlib.so" ""
202      "" {}
203      {{readelf -WSsrl tlsexetoc.r} {objdump -dr tlsexetoc.d}
204       {objdump -sj.got tlsexetoc.g} {objdump -sj.tdata tlsexetoc.t}}
205      "tlsexetocold"}
206     {"TLSTOC shared" "-shared -melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tlstoc.o" "" "" {}
207      {{readelf -WSsrl tlstocso.r} {objdump -dr tlstocso.d}
208       {objdump -sj.got tlstocso.g} {objdump -sj.tdata tlstocso.t}}
209      "tlstoc.so"}
210     {"TLS markers" "-melf64ppc" "" "-a64"  {tlsmark.s tlslib.s}
211      {{objdump -dr tlsmark.d}}
212      "tlsmark"}
213     {"TLS opt 1" "-melf64ppc" "" "-a64"  {tlsopt1.s tlslib.s}
214      {{objdump -dr tlsopt1.d}}
215      "tlsopt1"}
216     {"TLS opt 2" "-melf64ppc" "" "-a64"  {tlsopt2.s tlslib.s}
217      {{objdump -dr tlsopt2.d}}
218      "tlsopt2"}
219     {"TLS opt 3" "-melf64ppc" "" "-a64"  {tlsopt3.s tlslib.s}
220      {{objdump -dr tlsopt3.d}}
221      "tlsopt3"}
222     {"TLS opt 4" "-melf64ppc" "" "-a64"  {tlsopt4.s tlslib.s}
223      {{objdump -dr tlsopt4.d}}
224      "tlsopt4"}
225     {"TLS DLL" "-shared -melf64ppc --version-script tlsdll.ver" "" "-a64" {tlsdll.s}
226      {} "tlsdll.so"}
227     {"TLS opt 5" "-melf64ppc -shared --hash-style=both --gc-sections --no-plt-localentry tmpdir/tlsdll.so" "" "-a64"  {tlsopt5.s}
228      {{objdump -dr tlsopt5.d} {readelf -wf tlsopt5.wf}}
229      "tlsopt5"}
230     {"sym@tocbase" "-shared -melf64ppc" "" "-a64" {symtocbase-1.s symtocbase-2.s}
231         {{objdump -dj.data symtocbase.d}} "symtocbase.so"}
232     {"TOC opt" "-melf64ppc" "" "-a64"  {tocopt.s}
233         {{ld tocopt.out} {objdump -s tocopt.d}} "tocopt"}
234     {"TOC opt2" "-melf64ppc --defsym x=2" "" "-a64"  {tocopt2.s}
235         {{ld tocopt2.out} {objdump -s tocopt2.d}} "tocopt2"}
236     {"TOC opt3" "-melf64ppc -no-keep-memory --defsym x=2" "" "-a64"  {tocopt3.s}
237         {{objdump -s tocopt3.d}} "tocopt3"}
238     {"TOC opt4" "-melf64ppc -no-keep-memory --defsym x=2" "" "-a64"
239         {tocopt4a.s tocopt4b.s} {{objdump -s tocopt4.d}} "tocopt4"}
240     {"TOC opt5" "-melf64ppc" "" "-a64"  {tocopt5.s}
241         {{objdump -s tocopt5.d}} "tocopt5"}
242     {"TOC opt6" "-melf64ppc" "" "-a64"  {tocopt6a.s tocopt6b.s tocopt6c.s}
243         {{objdump -d tocopt6.d}} "tocopt6"}
244     {"TOC opt7" "-melf64ppc" "" "-a64 -mpower9"  {tocopt7.s}
245         {{ld tocopt7.out} {objdump -s tocopt7.d}} "tocopt7"}
246     {"TOC opt8" "-melf64ppc" "" "-a64 -mpower9"  {tocopt8.s}
247         {{objdump -s tocopt8.d}} "tocopt8"}
248     {"tocsave lib" "-shared -melf64ppc" "" "-a64" {tocsavelib.s}
249         {} "tocsavelib.so"}
250     {"tocsave1 shared" "-melf64ppc" "tmpdir/tocsavelib.so" "-a64" {tocsave1.s}
251         {{objdump -dr tocsave1s.d}} "tocsave1s"}
252     {"tocsave1 static" "-melf64ppc" "tmpdir/tocsavelib.o" "-a64" {tocsave1.s}
253         {{objdump -dr tocsave1a.d}} "tocsave1a"}
254     {"tocsave2 shared" "-melf64ppc" "tmpdir/tocsavelib.so" "-a64" {tocsave2.s}
255         {{objdump -dr tocsave2s.d}} "tocsave2s"}
256     {"tocsave2 static" "-melf64ppc" "tmpdir/tocsavelib.o" "-a64" {tocsave2.s}
257         {{objdump -dr tocsave2a.d}} "tocsave2a"}
258     {"ambig shared v1" "-shared -melf64ppc" "" "-a64" {funv1.s} {} "funv1.so"}
259     {"ambig shared v2" "-shared -melf64ppc" "" "-a64" {funv2.s} {} "funv2.so"}
260     {"notoc ext" "" "" "-a64" {ext.s} {} ""}
261     {"notoc" "-melf64ppc --no-plt-localentry -T ext.lnk" "" "-a64" {notoc.s}
262         {{objdump -d notoc.d} {readelf {-wf -W} notoc.wf}} "notoc"}
263     {"notoc2" "-melf64ppc -shared" "" "-a64 -mfuture" {notoc2.s}
264         {{objdump {-d -Mfuture} notoc2.d}} "notoc2"}
265     {"pcrelopt" "-melf64ppc --hash-style=gnu" "tmpdir/symtocbase.so"
266         "-a64 -mfuture" {pcrelopt.s}
267         {{objdump {-d -Mfuture} pcrelopt.d}
268          {readelf {-S --wide} pcrelopt.sec}} "pcrelopt" }
269 }
270
271 set ppceabitests {
272     {"VLE multiple segments 1" "-melf32ppc -T vle-multiseg-1.ld" ""
273      "-a32 -mbig -mregnames -mvle" {vle-multiseg.s}
274     {{readelf "-l" vle-multiseg-1.d}} "vle-multiseg-1"}
275     {"VLE multiple segments 2" "-melf32ppc -T vle-multiseg-2.ld" ""
276      "-a32 -mbig -mregnames -mvle" {vle-multiseg.s}
277     {{readelf "-l" vle-multiseg-2.d}} "vle-multiseg-2"}
278     {"VLE multiple segments 3" "-melf32ppc -T vle-multiseg-3.ld" ""
279      "-a32 -mbig -mregnames -mvle" {vle-multiseg.s}
280     {{readelf "-l" vle-multiseg-3.d}} "vle-multiseg-3"}
281     {"VLE multiple segments 4" "-melf32ppc -T vle-multiseg-4.ld" ""
282      "-a32 -mbig -mregnames -mvle" {vle-multiseg.s}
283     {{readelf "-l" vle-multiseg-4.d}} "vle-multiseg-4"}
284     {"VLE multiple segments 5" "-melf32ppc -T vle-multiseg-5.ld" ""
285      "-a32 -mbig -mregnames -mvle" {vle-multiseg.s}
286     {{readelf "-l" vle-multiseg-5.d}} "vle-multiseg-5"}
287     {"VLE relocations 1" "-melf32ppc -T vle.ld" ""
288      "-a32 -mbig -mvle" {vle-reloc-1.s vle-reloc-def-1.s}
289     {{objdump "-Mvle -d" vle-reloc-1.d}} "vle-reloc-1"}
290     {"VLE relocations 2" "-melf32ppc -T vle.ld" ""
291      "-a32 -mbig -mvle" {vle-reloc-2.s vle-reloc-def-2.s}
292     {{objdump "-Mvle -d" vle-reloc-2.d}} "vle-reloc-2"}
293     {"VLE relocations 3" "-melf32ppc -T vle.ld" ""
294      "-a32 -mbig -mvle" {vle-reloc-3.s vle-reloc-def-3.s}
295     {{objdump "-Mvle -d" vle-reloc-3.d}} "vle-reloc-3"}
296 }
297
298 if [istarget "powerpc*le*-*-*"] then {
299     set options_regsub(ld) {{-melf([3264]*)ppc} {-melf\1lppc}}
300
301     for {set i 0} {$i < [llength $ppcelftests]} {incr i} {
302         set line [lindex $ppcelftests $i]
303         set ld_options [lindex $line 1]
304         regsub -all elf32ppc $ld_options elf32lppc ld_options
305         set line [lreplace $line 1 1 $ld_options]
306         set ppcelftests [lreplace $ppcelftests $i $i $line]
307     }
308
309     if [ supports_ppc64 ] then {
310         for {set i 0} {$i < [llength $ppc64elftests]} {incr i} {
311             set line [lindex $ppc64elftests $i]
312             set ld_options [lindex $line 1]
313             regsub -all elf64ppc $ld_options elf64lppc ld_options
314             set line [lreplace $line 1 1 $ld_options]
315             set ppc64elftests [lreplace $ppc64elftests $i $i $line]
316         }
317     }
318 }
319
320 run_ld_link_tests $ppcelftests
321
322 if [ supports_ppc64 ] then {
323     run_ld_link_tests $ppc64elftests
324     run_dump_test "relbrlt"
325     run_dump_test "elfv2so"
326     run_dump_test "elfv2exe"
327     run_dump_test "elfv2-2so"
328     run_dump_test "elfv2-2exe"
329     run_dump_test "ambiguousv1"
330     run_dump_test "ambiguousv1b"
331     run_dump_test "ambiguousv2"
332     run_dump_test "ambiguousv2b"
333     run_dump_test "defsym"
334     run_dump_test "tocvar"
335     run_dump_test "tocnovar"
336     run_dump_test "tlsldopt"
337     run_dump_test "relocsort"
338     run_dump_test "addpcis"
339     run_dump_test "dotsym1"
340     run_dump_test "dotsym2"
341     run_dump_test "dotsym3"
342     run_dump_test "dotsym4"
343     run_dump_test "pr23937"
344     run_dump_test "callstub-1"
345     run_dump_test "callstub-2"
346     run_dump_test "tlsgd"
347     run_dump_test "tlsld"
348     run_dump_test "tlsie"
349 }
350
351 run_dump_test "tlsldopt32"
352
353 run_ld_link_tests $ppceabitests
354
355 run_dump_test "plt1"
356 run_dump_test "sdabase"
357 run_dump_test "sdabase2"
358
359 run_dump_test "attr-gnu-4-00"
360 run_dump_test "attr-gnu-4-01"
361 run_dump_test "attr-gnu-4-02"
362 run_dump_test "attr-gnu-4-03"
363 run_dump_test "attr-gnu-4-10"
364 run_dump_test "attr-gnu-4-11"
365 run_dump_test "attr-gnu-4-12"
366 run_dump_test "attr-gnu-4-13"
367 run_dump_test "attr-gnu-4-20"
368 run_dump_test "attr-gnu-4-21"
369 run_dump_test "attr-gnu-4-22"
370 run_dump_test "attr-gnu-4-23"
371 run_dump_test "attr-gnu-4-31"
372 run_dump_test "attr-gnu-4-32"
373 run_dump_test "attr-gnu-4-33"
374
375 run_dump_test "attr-gnu-8-11"
376 run_dump_test "attr-gnu-8-23"
377 run_dump_test "attr-gnu-8-31"
378
379 run_dump_test "attr-gnu-12-11"
380 run_dump_test "attr-gnu-12-21"
381
382 run_dump_test "vle-multiseg-6"
383
384 run_dump_test "ppc476-shared"
385 run_dump_test "ppc476-shared2"