]>
Commit | Line | Data |
---|---|---|
17c2bdee | 1 | # Expect script for ld-powerpc tests |
a2c58332 | 2 | # Copyright (C) 2002-2022 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 | ||
22 | if { ![istarget "powerpc*-*-*"] } { | |
23 | return | |
24 | } | |
25 | ||
4a3dc543 RS |
26 | if {[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"} | |
bab55c05 AM |
32 | {"VxWorks shared library test 1" |
33 | "-shared --hash-style=sysv -Tvxworks1.ld" "" | |
4a3dc543 | 34 | "-mregnames" {vxworks1-lib.s} |
0942c7ab | 35 | {{readelf {--relocs -T} vxworks1-lib.rd} {objdump -dr vxworks1-lib.dd} |
e68ed250 | 36 | {readelf --symbols vxworks1-lib.nd} {readelf -d vxworks1-lib.td}} |
4a3dc543 | 37 | "libvxworks1.so"} |
4f471f39 | 38 | {"VxWorks executable test 1 (dynamic)" \ |
bab55c05 | 39 | "tmpdir/libvxworks1.so -Tvxworks1.ld -q --force-dynamic --hash-style=sysv" "" |
4f471f39 | 40 | "-mregnames" {vxworks1.s} |
0942c7ab | 41 | {{readelf {--relocs -T} vxworks1.rd} {objdump -dr vxworks1.dd}} |
4a3dc543 | 42 | "vxworks1"} |
4f471f39 | 43 | {"VxWorks executable test 2 (dynamic)" \ |
bab55c05 | 44 | "-Tvxworks1.ld -q --force-dynamic --hash-style=sysv" "" |
4f471f39 RS |
45 | "-mregnames" {vxworks2.s} |
46 | {{readelf --segments vxworks2.sd}} | |
47 | "vxworks2"} | |
48 | {"VxWorks executable test 2 (static)" | |
bab55c05 | 49 | "-Tvxworks1.ld --hash-style=sysv" "" |
4f471f39 RS |
50 | "-mregnames" {vxworks2.s} |
51 | {{readelf --segments vxworks2-static.sd}} | |
52 | "vxworks2"} | |
9bc4e62b | 53 | {"VxWorks relax test" |
bab55c05 | 54 | "-Tvxworks1.ld --relax -q --hash-style=sysv" "" |
9bc4e62b NS |
55 | "-mregnames" {vxworks-relax.s} |
56 | {{readelf --relocs vxworks-relax.rd}} | |
57 | "vxworks-relax"} | |
c8a1f254 | 58 | {"VxWorks relocatable relax test" |
bab55c05 | 59 | "-Tvxworks1.ld -r --relax -q --hash-style=sysv" "" |
c8a1f254 | 60 | "-mregnames" {vxworks-relax-2.s} |
0942c7ab | 61 | {{readelf {--relocs -T} vxworks-relax-2.rd}} |
c8a1f254 | 62 | "vxworks-relax-2"} |
4a3dc543 RS |
63 | } |
64 | run_ld_link_tests $ppcvxtests | |
4f471f39 | 65 | run_dump_test "vxworks1-static" |
4a3dc543 RS |
66 | return |
67 | } | |
68 | ||
e4e4a5d1 AM |
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. | |
17c2bdee | 72 | |
7193487f | 73 | if { [is_xcoff_format] |
17c2bdee | 74 | || [istarget "*-*-pe"] || [istarget "*-*-winnt*"] |
7193487f AM |
75 | || [istarget "*-*-cygwin*"] |
76 | || [istarget "*-*-lynxos*"] | |
e4e4a5d1 | 77 | || [istarget "*-*-nto*"] } { |
17c2bdee AM |
78 | return |
79 | } | |
80 | ||
266fb683 AM |
81 | proc supports_ppc64 { } { |
82 | global ld | |
83 | ||
84 | catch "exec $ld --help | grep emulations" tmp | |
65fd058f | 85 | if [ regexp "elf64l?ppc" $tmp ] then { |
266fb683 AM |
86 | return 1 |
87 | } else { | |
88 | return 0 | |
89 | } | |
90 | } | |
91 | ||
17c2bdee | 92 | # List contains test-items with 3 items followed by 2 lists: |
897aea50 MR |
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 | |
17c2bdee AM |
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 { | |
7cc34005 | 102 | {"Reloc section order" "-melf32ppc -shared -z nocombreloc -z notext" "" "-a32" {reloc.s} |
17c2bdee | 103 | {{objdump -hw reloc.d}} "reloc.so"} |
897aea50 | 104 | {"APUinfo section processing" "-melf32ppc" "" |
deddc40b | 105 | "-a32 -me500" {apuinfo1.s apuinfo-nul.s apuinfo2.s} |
39326c35 | 106 | {{readelf -x.PPC.EMB.apuinfo apuinfo.rd}} "apuinfo"} |
fbd94057 | 107 | {"APUinfo VLE section processing" "-melf32ppc" "" |
14b57c7c | 108 | "-a32 -me500 -mvle" {apuinfo1.s apuinfo-vle.s apuinfo-vle2.s} |
39326c35 | 109 | {{readelf -x.PPC.EMB.apuinfo apuinfo-vle.rd}} "apuinfo-vle"} |
897aea50 | 110 | {"APUinfo NULL section processing" "-melf32ppc" "" |
f2faa800 | 111 | "-a32 -me500" {apuinfo-nul1.s apuinfo-nul.s} |
39326c35 | 112 | {{readelf -x.PPC.EMB.apuinfo apuinfo-nul.rd}} "apuinfo"} |
9a23f96e AM |
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"} | |
897aea50 | 118 | {"TLS32 static exec" "-melf32ppc" "" "-a32" {tls32.s tlslib32.s} |
2a050fb5 AM |
119 | {{objdump -dr tls32.d} {objdump -sj.got tls32.g} |
120 | {objdump -sj.tdata tls32.t}} | |
121 | "tls32"} | |
c3614cff AM |
122 | {"TLS32 static exec (--no-tls-optimize)" "-melf32ppc --no-tls-optimize" "" |
123 | "-a32 --defsym TLSMARK=1" {tls32.s tlslib32.s} | |
124 | {{objdump -dr tls32no.d} {objdump -sj.got tls32no.g} | |
125 | {objdump -sj.tdata tls32.t}} | |
126 | "tls32no"} | |
897aea50 | 127 | {"TLS32 helper shared library" "-shared -melf32ppc tmpdir/tlslib32.o" "" "" {} |
2a050fb5 | 128 | {} "libtlslib32.so"} |
407aa07c | 129 | {"TLS32 dynamic exec" "-melf32ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls32.o tmpdir/libtlslib32.so" "" "" {} |
2a050fb5 AM |
130 | {{readelf -WSsrl tlsexe32.r} {objdump -dr tlsexe32.d} |
131 | {objdump -sj.got tlsexe32.g} {objdump -sj.tdata tlsexe32.t}} | |
9a23f96e | 132 | "tlsexe32"} |
c3614cff AM |
133 | {"TLS32 dynamic exec (--no-tls-optimize)" "-melf32ppc --no-tls-optimize --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls32.o tmpdir/libtlslib32.so" "" "" {} |
134 | {{readelf -WSsrl tlsexe32no.r} {objdump -dr tlsexe32no.d} | |
135 | {objdump -sj.got tlsexe32no.g} {objdump -sj.tdata tlsexe32.t}} | |
136 | "tlsexe32no"} | |
7cc34005 | 137 | {"TLS32 shared" "-shared -melf32ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv -z notext tmpdir/tls32.o" "" "" {} |
2a050fb5 AM |
138 | {{readelf -WSsrl tlsso32.r} {objdump -dr tlsso32.d} |
139 | {objdump -sj.got tlsso32.g} {objdump -sj.tdata tlsso32.t}} | |
9a23f96e | 140 | "tls32.so"} |
897aea50 | 141 | {"TLS32 markers" "-melf32ppc" "" "-a32" {tlsmark32.s tlslib32.s} |
727fc41e | 142 | {{objdump -dr tlsmark32.d}} |
9a23f96e | 143 | "tlsmark32"} |
897aea50 | 144 | {"TLS32 opt 1" "-melf32ppc" "" "-a32" {tlsopt1_32.s tlslib32.s} |
663a1470 | 145 | {{objdump -dr tlsopt1_32.d}} |
9a23f96e | 146 | "tlsopt1_32"} |
897aea50 | 147 | {"TLS32 opt 2" "-melf32ppc" "" "-a32" {tlsopt2_32.s tlslib32.s} |
663a1470 | 148 | {{objdump -dr tlsopt2_32.d}} |
9a23f96e | 149 | "tlsopt2_32"} |
897aea50 | 150 | {"TLS32 opt 3" "-melf32ppc" "" "-a32" {tlsopt3_32.s tlslib32.s} |
663a1470 AM |
151 | {{objdump -dr tlsopt3_32.d}} |
152 | "tlsopt3_32"} | |
897aea50 | 153 | {"TLS32 opt 4" "-melf32ppc" "" "-a32" {tlsopt4_32.s tlslib32.s} |
663a1470 | 154 | {{objdump -dr tlsopt4_32.d}} |
9a23f96e AM |
155 | "tlsopt4_32"} |
156 | {"TLS32 DLL" "-shared -melf32ppc --version-script tlsdll.ver" "" | |
157 | "-a32" {tlsdll_32.s} | |
3bd43ebc | 158 | {} "tlsdll32.so"} |
407aa07c | 159 | {"TLS32 opt 5" "-melf32ppc -shared --gc-sections --secure-plt --no-plt-align tmpdir/tlsdll32.so" "" "-a32" {tlsopt5_32.s} |
3bd43ebc | 160 | {{objdump -dr tlsopt5_32.d}} |
9a23f96e | 161 | "tlsopt5_32"} |
897aea50 | 162 | {"Shared library with global symbol" "-shared -melf32ppc" "" "-a32" {sdalib.s} |
4dc4a9a5 | 163 | {} "sdalib.so"} |
897aea50 | 164 | {"Dynamic application with SDA" "-melf32ppc tmpdir/sdalib.so" "" "-a32" {sdadyn.s} |
4dc4a9a5 | 165 | {{objdump -R sdadyn.d}} "sdadyn"} |
897aea50 | 166 | {"relaxing" "-melf32ppc --relax -Ttext=0 --defsym far=0x80001234 --defsym near=0x00004320" "" "-a32" "relax.s" |
9853c099 | 167 | {{objdump -dr relax.d}} |
9a23f96e | 168 | "relax"} |
897aea50 | 169 | {"relocatable relaxing" "-melf32ppc -r --relax" "" "-a32" "relax.s" |
9853c099 | 170 | {{objdump -dr relaxr.d}} |
9a23f96e | 171 | "rrelax"} |
49199304 AM |
172 | {"relocatable relaxing large" "-melf32ppc -r --relax" "" "-a32" "relax.s big.s" |
173 | {{objdump -dr relaxrl.d}} | |
174 | "rrelax"} | |
13ffdac3 | 175 | {"build empty shared library" "-shared" "" "" "empty.s" {} "empty.so"} |
17c2bdee AM |
176 | } |
177 | ||
266fb683 | 178 | set ppc64elftests { |
2420fff6 | 179 | {"TLS static exec (markers)" "-melf64ppc --no-plt-align" "" |
9a23f96e AM |
180 | "-a64 --defsym TLSMARK=1" {tls.s tlslib.s} |
181 | {{objdump -dr tls.d} {objdump -sj.got tls.g} {objdump -sj.tdata tls.t}} | |
182 | "tlsm"} | |
2420fff6 | 183 | {"TLS static exec" "-melf64ppc --no-plt-align" "" "-a64" {tls.s tlslib.s} |
266fb683 | 184 | {{objdump -dr tls.d} {objdump -sj.got tls.g} {objdump -sj.tdata tls.t}} |
9a23f96e | 185 | "tls"} |
c3614cff AM |
186 | {"TLS static exec (--no-tls-optimize)" "-melf64ppc --no-tls-optimize --no-plt-align" "" |
187 | "-a64 --defsym TLSMARK=1" {tls.s tlslib.s} | |
188 | {{objdump -dr tlsno.d} {objdump -sj.got tlsno.g} {objdump -sj.tdata tls.t}} | |
189 | "tlsno"} | |
897aea50 | 190 | {"TLS helper shared library" "-shared -melf64ppc tmpdir/tlslib.o" "" "" {} |
266fb683 | 191 | {} "libtlslib.so"} |
897aea50 | 192 | {"TLS helper old shared lib" "-shared -melf64ppc" "" "-a64" {oldtlslib.s} |
a7f2871e | 193 | {} "liboldlib.so"} |
407aa07c | 194 | {"TLS dynamic exec" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls.o tmpdir/libtlslib.so" "" "" {} |
266fb683 AM |
195 | {{readelf -WSsrl tlsexe.r} {objdump -dr tlsexe.d} |
196 | {objdump -sj.got tlsexe.g} {objdump -sj.tdata tlsexe.t}} | |
9a23f96e | 197 | "tlsexe"} |
407aa07c | 198 | {"TLS dynamic old" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls.o tmpdir/liboldlib.so" "" "" {} |
a7f2871e AM |
199 | {{readelf -WSsrl tlsexe.r} {objdump -dr tlsexe.d} |
200 | {objdump -sj.got tlsexe.g} {objdump -sj.tdata tlsexe.t}} | |
9a23f96e | 201 | "tlsexeold"} |
c3614cff AM |
202 | {"TLS dynamic exec (--no-tls-optimize)" "-melf64ppc --no-tls-optimize --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls.o tmpdir/libtlslib.so" "" "" {} |
203 | {{readelf -WSsrl tlsexeno.r} {objdump -dr tlsexeno.d} | |
204 | {objdump -sj.got tlsexeno.g} {objdump -sj.tdata tlsexe.t}} | |
205 | "tlsexeno"} | |
7cc34005 | 206 | {"TLS shared" "-shared -melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv -z notext tmpdir/tls.o" "" "" {} |
266fb683 AM |
207 | {{readelf -WSsrl tlsso.r} {objdump -dr tlsso.d} |
208 | {objdump -sj.got tlsso.g} {objdump -sj.tdata tlsso.t}} | |
9a23f96e | 209 | "tls.so"} |
c3614cff | 210 | {"TLSTOC static exec" "-melf64ppc tmpdir/tlslib.o" "" "-a64" {tlstoc.s} |
1c0bd72e | 211 | {{objdump -dr tlstoc.d} {objdump -sj.got tlstoc.g} |
266fb683 | 212 | {objdump -sj.tdata tlstoc.t}} |
9a23f96e | 213 | "tlstoc"} |
c3614cff AM |
214 | {"TLSTOC static exec (--no-tls-optimize)" "-melf64ppc --no-tls-optimize tmpdir/tlslib.o tmpdir/tlstoc.o" "" "" {} |
215 | {{objdump -dr tlstocno.d} {objdump -sj.got tlstocno.g} | |
216 | {objdump -sj.tdata tlstoc.t}} | |
217 | "tlstocno"} | |
407aa07c | 218 | {"TLSTOC dynamic exec" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tlstoc.o tmpdir/libtlslib.so" "" |
266fb683 AM |
219 | "" {} |
220 | {{readelf -WSsrl tlsexetoc.r} {objdump -dr tlsexetoc.d} | |
1c0bd72e | 221 | {objdump -sj.got tlsexetoc.g} {objdump -sj.tdata tlsexetoc.t}} |
9a23f96e | 222 | "tlsexetoc"} |
407aa07c | 223 | {"TLSTOC dynamic old" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tlstoc.o tmpdir/liboldlib.so" "" |
a7f2871e AM |
224 | "" {} |
225 | {{readelf -WSsrl tlsexetoc.r} {objdump -dr tlsexetoc.d} | |
226 | {objdump -sj.got tlsexetoc.g} {objdump -sj.tdata tlsexetoc.t}} | |
9a23f96e | 227 | "tlsexetocold"} |
c3614cff AM |
228 | {"TLSTOC dynamic exec (--no-tls-optimize)" "-melf64ppc --no-tls-optimize --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tlstoc.o tmpdir/libtlslib.so" "" |
229 | "" {} | |
230 | {{readelf -WSsrl tlsexetoc.r} {objdump -dr tlsexetocno.d} | |
231 | {objdump -sj.got tlsexetocno.g} {objdump -sj.tdata tlsexetoc.t}} | |
232 | "tlsexetocno"} | |
7cc34005 | 233 | {"TLSTOC shared" "-shared -melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv -z notext tmpdir/tlstoc.o" "" "" {} |
266fb683 | 234 | {{readelf -WSsrl tlstocso.r} {objdump -dr tlstocso.d} |
1c0bd72e | 235 | {objdump -sj.got tlstocso.g} {objdump -sj.tdata tlstocso.t}} |
9a23f96e | 236 | "tlstoc.so"} |
9e7028aa AM |
237 | {"TLS dynamic exec (--tls-get-addr-regsave)" "-melf64ppc --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv --tls-get-addr-regsave tmpdir/tls.o tmpdir/libtlslib.so" "" "" {} |
238 | {{readelf -WSsrl tlsexers.r} {objdump -dr tlsexers.d} | |
239 | {objdump -sj.got tlsexe.g} {objdump -sj.tdata tlsexe.t}} | |
240 | "tlsexers"} | |
241 | {"TLS dynamic exec (--no-tls-optimize --tls-get-addr-regsave)" "-melf64ppc --no-tls-optimize --tls-get-addr-regsave --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tls.o tmpdir/libtlslib.so" "" "" {} | |
242 | {{readelf -WSsrl tlsexenors.r} {objdump -dr tlsexenors.d} | |
243 | {objdump -sj.got tlsexeno.g} {objdump -sj.tdata tlsexe.t}} | |
244 | "tlsexenors"} | |
245 | {"TLSTOC dynamic exec (--tls-get-addr-regsave)" "-melf64ppc --tls-get-addr-regsave --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tlstoc.o tmpdir/libtlslib.so" "" | |
246 | "" {} | |
247 | {{readelf -WSsrl tlsexetocrs.r} {objdump -dr tlsexetocrs.d} | |
248 | {objdump -sj.got tlsexetoc.g} {objdump -sj.tdata tlsexetoc.t}} | |
249 | "tlsexetocrs"} | |
250 | {"TLSTOC dynamic exec (--no-tls-optimize --tls-get-addr-regsave)" "-melf64ppc --no-tls-optimize --tls-get-addr-regsave --no-plt-align --no-ld-generated-unwind-info --hash-style=sysv tmpdir/tlstoc.o tmpdir/libtlslib.so" "" | |
251 | "" {} | |
252 | {{readelf -WSsrl tlsexetocrs.r} {objdump -dr tlsexetocnors.d} | |
253 | {objdump -sj.got tlsexetocno.g} {objdump -sj.tdata tlsexetoc.t}} | |
254 | "tlsexetocnors"} | |
897aea50 | 255 | {"TLS markers" "-melf64ppc" "" "-a64" {tlsmark.s tlslib.s} |
727fc41e | 256 | {{objdump -dr tlsmark.d}} |
9a23f96e | 257 | "tlsmark"} |
897aea50 | 258 | {"TLS opt 1" "-melf64ppc" "" "-a64" {tlsopt1.s tlslib.s} |
663a1470 | 259 | {{objdump -dr tlsopt1.d}} |
9a23f96e | 260 | "tlsopt1"} |
897aea50 | 261 | {"TLS opt 2" "-melf64ppc" "" "-a64" {tlsopt2.s tlslib.s} |
663a1470 | 262 | {{objdump -dr tlsopt2.d}} |
9a23f96e | 263 | "tlsopt2"} |
897aea50 | 264 | {"TLS opt 3" "-melf64ppc" "" "-a64" {tlsopt3.s tlslib.s} |
663a1470 | 265 | {{objdump -dr tlsopt3.d}} |
9a23f96e | 266 | "tlsopt3"} |
897aea50 | 267 | {"TLS opt 4" "-melf64ppc" "" "-a64" {tlsopt4.s tlslib.s} |
663a1470 | 268 | {{objdump -dr tlsopt4.d}} |
9a23f96e | 269 | "tlsopt4"} |
3bd43ebc AM |
270 | {"TLS DLL" "-shared -melf64ppc --version-script tlsdll.ver" "" "-a64" {tlsdll.s} |
271 | {} "tlsdll.so"} | |
a67ae9b0 | 272 | {"TLS opt 5" "-melf64ppc -shared --hash-style=both --gc-sections --no-plt-localentry tmpdir/tlsdll.so" "" "-a64" {tlsopt5.s} |
d4aaa2a0 | 273 | {{objdump -dr tlsopt5.d} {readelf -wf tlsopt5.wf}} |
9a23f96e | 274 | "tlsopt5"} |
9e7028aa AM |
275 | {"TLS opt 6" "-melf64ppc -shared --hash-style=both --gc-sections --no-plt-localentry --tls-get-addr-regsave tmpdir/tlsdll.so" "" "-a64" {tlsopt5.s} |
276 | {{objdump -dr tlsopt6.d} {readelf -wf tlsopt6.wf}} | |
277 | "tlsopt6"} | |
278 | {"TLSdesc" "-melf64ppc -shared --hash-style=both --no-plt-localentry tmpdir/libtlslib.so" "" "-a64" {tlsdesc.s} | |
279 | {{objdump -dr tlsdesc.d} {readelf -wf tlsdesc.wf}} | |
280 | "tlsdesc"} | |
281 | {"TLSdesc2" "-melf64ppc -shared --hash-style=both --no-plt-localentry tmpdir/tlsdll.so" "" "-a64" {tlsdesc.s} | |
282 | {{objdump -dr tlsdesc2.d} {readelf -wf tlsdesc2.wf}} | |
283 | "tlsdesc2"} | |
a804e476 AM |
284 | {"TLSdesc3" "-melf64ppc --no-tls-optimize tmpdir/tlsdll.o" "" "-a64" {tlsdesc.s} |
285 | {{objdump -dr tlsdesc3.d} {readelf -wf tlsdesc3.wf}} | |
286 | "tlsdesc3"} | |
287 | {"TLSdesc4" "-melf64ppc --no-tls-optimize tmpdir/tlsdll.o" "" "-a64" {tlsdesc4.s} | |
288 | {{objdump -dr tlsdesc4.d} {readelf -wf tlsdesc4.wf}} | |
289 | "tlsdesc4"} | |
f243e458 AM |
290 | {"tlsget" "-shared --hash-style=both -melf64ppc --plt-align=0" "tmpdir/tlsdll.so" "-a64 -mpower10" {tlsget.s} |
291 | {{objdump -dr tlsget.d} {readelf -wf tlsget.wf}} | |
292 | "tlsget.so"} | |
293 | {"tlsget2" "-shared --hash-style=both -melf64ppc --plt-align=0 --power10-stubs=yes" "tmpdir/tlsdll.so" "-a64 -mpower10" {tlsget.s} | |
294 | {{objdump -dr tlsget2.d} {readelf -wf tlsget2.wf}} | |
295 | "tlsget2.so"} | |
897aea50 | 296 | {"sym@tocbase" "-shared -melf64ppc" "" "-a64" {symtocbase-1.s symtocbase-2.s} |
08f46626 | 297 | {{objdump -dj.data symtocbase.d}} "symtocbase.so"} |
897aea50 | 298 | {"TOC opt" "-melf64ppc" "" "-a64" {tocopt.s} |
560c8763 | 299 | {{ld tocopt.out} {objdump -s tocopt.d}} "tocopt"} |
897aea50 | 300 | {"TOC opt2" "-melf64ppc --defsym x=2" "" "-a64" {tocopt2.s} |
2843fdaa | 301 | {{ld tocopt2.out} {objdump -s tocopt2.d}} "tocopt2"} |
897aea50 | 302 | {"TOC opt3" "-melf64ppc -no-keep-memory --defsym x=2" "" "-a64" {tocopt3.s} |
2843fdaa | 303 | {{objdump -s tocopt3.d}} "tocopt3"} |
897aea50 | 304 | {"TOC opt4" "-melf64ppc -no-keep-memory --defsym x=2" "" "-a64" |
365b60b0 | 305 | {tocopt4a.s tocopt4b.s} {{objdump -s tocopt4.d}} "tocopt4"} |
897aea50 | 306 | {"TOC opt5" "-melf64ppc" "" "-a64" {tocopt5.s} |
98528052 | 307 | {{objdump -s tocopt5.d}} "tocopt5"} |
92a9c616 RS |
308 | {"TOC opt6" "-melf64ppc" "" "-a64" {tocopt6a.s tocopt6b.s tocopt6c.s} |
309 | {{objdump -d tocopt6.d}} "tocopt6"} | |
39eeab25 AM |
310 | {"TOC opt7" "-melf64ppc" "" "-a64 -mpower9" {tocopt7.s} |
311 | {{ld tocopt7.out} {objdump -s tocopt7.d}} "tocopt7"} | |
312 | {"TOC opt8" "-melf64ppc" "" "-a64 -mpower9" {tocopt8.s} | |
313 | {{objdump -s tocopt8.d}} "tocopt8"} | |
81209eff AM |
314 | {"tocsave lib" "-shared -melf64ppc" "" "-a64" {tocsavelib.s} |
315 | {} "tocsavelib.so"} | |
316 | {"tocsave1 shared" "-melf64ppc" "tmpdir/tocsavelib.so" "-a64" {tocsave1.s} | |
317 | {{objdump -dr tocsave1s.d}} "tocsave1s"} | |
318 | {"tocsave1 static" "-melf64ppc" "tmpdir/tocsavelib.o" "-a64" {tocsave1.s} | |
319 | {{objdump -dr tocsave1a.d}} "tocsave1a"} | |
320 | {"tocsave2 shared" "-melf64ppc" "tmpdir/tocsavelib.so" "-a64" {tocsave2.s} | |
321 | {{objdump -dr tocsave2s.d}} "tocsave2s"} | |
322 | {"tocsave2 static" "-melf64ppc" "tmpdir/tocsavelib.o" "-a64" {tocsave2.s} | |
323 | {{objdump -dr tocsave2a.d}} "tocsave2a"} | |
f6c7c3e8 AM |
324 | {"ambig shared v1" "-shared -melf64ppc" "" "-a64" {funv1.s} {} "funv1.so"} |
325 | {"ambig shared v2" "-shared -melf64ppc" "" "-a64" {funv2.s} {} "funv2.so"} | |
df136d64 | 326 | {"notoc ext" "" "" "-a64" {ext.s} {} ""} |
e10a07b3 AM |
327 | {"notoc" "-melf64ppc --no-plt-localentry --no-power10-stubs -T ext.lnk" |
328 | "" "-a64" {notoc.s} | |
df136d64 | 329 | {{objdump -d notoc.d} {readelf {-wf -W} notoc.wf}} "notoc"} |
7c1f4227 AM |
330 | {"notoc2" "-melf64ppc -shared" "" "-a64 -mpower10" {notoc2.s} |
331 | {{objdump {-d -Mpower10} notoc2.d}} "notoc2"} | |
e10a07b3 AM |
332 | {"notoc3" "-melf64ppc --no-plt-localentry -T ext.lnk" "" |
333 | "-a64 -mpower10" {notoc3.s} | |
334 | {{objdump -d notoc3.d} {readelf {-wf -W} notoc3.wf}} "notoc3"} | |
4a421c53 | 335 | {"pcrelopt" "-melf64ppc --hash-style=gnu" "tmpdir/symtocbase.so" |
7c1f4227 AM |
336 | "-a64 -mpower10" {pcrelopt.s} |
337 | {{objdump {-d -Mpower10} pcrelopt.d} | |
4a421c53 | 338 | {readelf {-S --wide} pcrelopt.sec}} "pcrelopt" } |
e4d9e542 AM |
339 | {"group1" "-melf64ppc -e foo" "" "-a64" {group1.s group2.s group3.s} |
340 | {{objdump {-d} group1.d} | |
341 | {readelf {-s} group1.sym}} "group1"} | |
342 | {"group2" "-melf64ppc -e foo" "" "-a64" {group2.s group1.s group3.s} | |
343 | {{objdump {-d} group2.d} | |
344 | {readelf {-s} group2.sym}} "group2"} | |
345 | {"group3" "-melf64ppc -e foo" "" "-a64" {group3.s group2.s group1.s} | |
346 | {{objdump {-d} group2.d} | |
347 | {readelf {-s} group3.sym}} "group3"} | |
f5b9c288 AM |
348 | {"weak1" "-melf64ppc --hash-style=both" "" |
349 | "-a64 -mpower10" {weak1.s} | |
350 | {{objdump -d weak1.d} {readelf {-srW} weak1.r}} "weak1"} | |
351 | {"weak1.so" "-shared -melf64ppc --hash-style=both" "" | |
352 | "-a64 -mpower10" {weak1.s} | |
353 | {{objdump -d weak1so.d} {readelf {-srW} weak1so.r}} "weak1.so"} | |
b80e421f AM |
354 | {"startstop" "-shared -melf64ppc --hash-style=sysv --gc-sections -z start-stop-gc" "" |
355 | "-a64 -mpower10" {startstop.s} | |
356 | {{objdump -d startstop.d} {readelf {-rW} startstop.r}} "startstop.so"} | |
266fb683 AM |
357 | } |
358 | ||
b9c361e0 | 359 | set ppceabitests { |
97d4213f AM |
360 | {"VLE multiple segments 1" "-melf32ppc -T vle-multiseg-1.ld" "" |
361 | "-a32 -mbig -mregnames -mvle" {vle-multiseg.s} | |
b9c361e0 | 362 | {{readelf "-l" vle-multiseg-1.d}} "vle-multiseg-1"} |
97d4213f AM |
363 | {"VLE multiple segments 2" "-melf32ppc -T vle-multiseg-2.ld" "" |
364 | "-a32 -mbig -mregnames -mvle" {vle-multiseg.s} | |
b9c361e0 | 365 | {{readelf "-l" vle-multiseg-2.d}} "vle-multiseg-2"} |
97d4213f AM |
366 | {"VLE multiple segments 3" "-melf32ppc -T vle-multiseg-3.ld" "" |
367 | "-a32 -mbig -mregnames -mvle" {vle-multiseg.s} | |
b9c361e0 | 368 | {{readelf "-l" vle-multiseg-3.d}} "vle-multiseg-3"} |
97d4213f AM |
369 | {"VLE multiple segments 4" "-melf32ppc -T vle-multiseg-4.ld" "" |
370 | "-a32 -mbig -mregnames -mvle" {vle-multiseg.s} | |
b9c361e0 | 371 | {{readelf "-l" vle-multiseg-4.d}} "vle-multiseg-4"} |
97d4213f AM |
372 | {"VLE multiple segments 5" "-melf32ppc -T vle-multiseg-5.ld" "" |
373 | "-a32 -mbig -mregnames -mvle" {vle-multiseg.s} | |
b9c361e0 | 374 | {{readelf "-l" vle-multiseg-5.d}} "vle-multiseg-5"} |
97d4213f AM |
375 | {"VLE relocations 1" "-melf32ppc -T vle.ld" "" |
376 | "-a32 -mbig -mvle" {vle-reloc-1.s vle-reloc-def-1.s} | |
b9c361e0 | 377 | {{objdump "-Mvle -d" vle-reloc-1.d}} "vle-reloc-1"} |
97d4213f AM |
378 | {"VLE relocations 2" "-melf32ppc -T vle.ld" "" |
379 | "-a32 -mbig -mvle" {vle-reloc-2.s vle-reloc-def-2.s} | |
b9c361e0 | 380 | {{objdump "-Mvle -d" vle-reloc-2.d}} "vle-reloc-2"} |
97d4213f AM |
381 | {"VLE relocations 3" "-melf32ppc -T vle.ld" "" |
382 | "-a32 -mbig -mvle" {vle-reloc-3.s vle-reloc-def-3.s} | |
b9c361e0 JL |
383 | {{objdump "-Mvle -d" vle-reloc-3.d}} "vle-reloc-3"} |
384 | } | |
385 | ||
ed6b7ef4 | 386 | if [istarget "powerpc*le*-*-*"] then { |
65fd058f | 387 | set options_regsub(ld) {{-melf([3264]*)ppc} {-melf\1lppc}} |
ed6b7ef4 AM |
388 | |
389 | for {set i 0} {$i < [llength $ppcelftests]} {incr i} { | |
390 | set line [lindex $ppcelftests $i] | |
391 | set ld_options [lindex $line 1] | |
392 | regsub -all elf32ppc $ld_options elf32lppc ld_options | |
393 | set line [lreplace $line 1 1 $ld_options] | |
394 | set ppcelftests [lreplace $ppcelftests $i $i $line] | |
395 | } | |
396 | ||
397 | if [ supports_ppc64 ] then { | |
398 | for {set i 0} {$i < [llength $ppc64elftests]} {incr i} { | |
65fd058f | 399 | set line [lindex $ppc64elftests $i] |
ed6b7ef4 AM |
400 | set ld_options [lindex $line 1] |
401 | regsub -all elf64ppc $ld_options elf64lppc ld_options | |
402 | set line [lreplace $line 1 1 $ld_options] | |
403 | set ppc64elftests [lreplace $ppc64elftests $i $i $line] | |
404 | } | |
405 | } | |
406 | } | |
266fb683 | 407 | |
17c2bdee | 408 | run_ld_link_tests $ppcelftests |
266fb683 AM |
409 | |
410 | if [ supports_ppc64 ] then { | |
411 | run_ld_link_tests $ppc64elftests | |
faead562 | 412 | run_dump_test "relbrlt" |
d4a95d49 AM |
413 | run_dump_test "elfv2so" |
414 | run_dump_test "elfv2exe" | |
45965137 AM |
415 | run_dump_test "elfv2-2so" |
416 | run_dump_test "elfv2-2exe" | |
f6c7c3e8 | 417 | run_dump_test "ambiguousv1" |
d1eca1e4 | 418 | run_dump_test "ambiguousv1b" |
f6c7c3e8 | 419 | run_dump_test "ambiguousv2" |
d1eca1e4 | 420 | run_dump_test "ambiguousv2b" |
bffebb6b | 421 | run_dump_test "defsym" |
b86ac8e3 AM |
422 | run_dump_test "tocvar" |
423 | run_dump_test "tocnovar" | |
7a708984 | 424 | run_dump_test "tlsldopt" |
1cb0b71f | 425 | run_dump_test "relocsort" |
a680de9a | 426 | run_dump_test "addpcis" |
8c5b4e52 AM |
427 | run_dump_test "dotsym1" |
428 | run_dump_test "dotsym2" | |
429 | run_dump_test "dotsym3" | |
430 | run_dump_test "dotsym4" | |
ba85c15d | 431 | run_dump_test "pr23937" |
60d53d7f AM |
432 | run_dump_test "callstub-1" |
433 | run_dump_test "callstub-2" | |
d3b10ee7 | 434 | run_dump_test "callstub-3" |
e10a07b3 | 435 | run_dump_test "callstub-4" |
0dbd452a AM |
436 | run_dump_test "inline-1" |
437 | run_dump_test "inline-2" | |
438 | run_dump_test "inline-3" | |
439 | run_dump_test "inline-4" | |
440 | run_dump_test "inlinepcrel-1" | |
441 | run_dump_test "inlinepcrel-2" | |
442 | run_dump_test "inlinepcrel-3" | |
c213164a AM |
443 | run_dump_test "tlsgd" |
444 | run_dump_test "tlsld" | |
445 | run_dump_test "tlsie" | |
abf874aa | 446 | run_dump_test "non-contiguous-powerpc64" |
252dcdf4 | 447 | run_dump_test "tprel" |
266fb683 | 448 | } |
faead562 | 449 | |
64465112 | 450 | run_dump_test "localgot" |
7a708984 | 451 | run_dump_test "tlsldopt32" |
b86ac8e3 | 452 | |
97d4213f | 453 | run_ld_link_tests $ppceabitests |
b9c361e0 | 454 | |
faead562 | 455 | run_dump_test "plt1" |
12b2843a AM |
456 | run_dump_test "sdabase" |
457 | run_dump_test "sdabase2" | |
34c8bcba JM |
458 | |
459 | run_dump_test "attr-gnu-4-00" | |
460 | run_dump_test "attr-gnu-4-01" | |
461 | run_dump_test "attr-gnu-4-02" | |
3c7b9897 | 462 | run_dump_test "attr-gnu-4-03" |
34c8bcba JM |
463 | run_dump_test "attr-gnu-4-10" |
464 | run_dump_test "attr-gnu-4-11" | |
465 | run_dump_test "attr-gnu-4-12" | |
466 | run_dump_test "attr-gnu-4-13" | |
467 | run_dump_test "attr-gnu-4-20" | |
468 | run_dump_test "attr-gnu-4-21" | |
469 | run_dump_test "attr-gnu-4-22" | |
3c7b9897 | 470 | run_dump_test "attr-gnu-4-23" |
34c8bcba | 471 | run_dump_test "attr-gnu-4-31" |
3c7b9897 AM |
472 | run_dump_test "attr-gnu-4-32" |
473 | run_dump_test "attr-gnu-4-33" | |
c6e65352 DJ |
474 | |
475 | run_dump_test "attr-gnu-8-11" | |
476 | run_dump_test "attr-gnu-8-23" | |
477 | run_dump_test "attr-gnu-8-31" | |
f82e0623 NF |
478 | |
479 | run_dump_test "attr-gnu-12-11" | |
480 | run_dump_test "attr-gnu-12-21" | |
b9c361e0 JL |
481 | |
482 | run_dump_test "vle-multiseg-6" | |
f8b44781 AM |
483 | |
484 | run_dump_test "ppc476-shared" | |
485 | run_dump_test "ppc476-shared2" | |
abf874aa CL |
486 | |
487 | run_dump_test "non-contiguous-powerpc" | |
252dcdf4 AM |
488 | |
489 | run_dump_test "tprel32" | |
490 | run_dump_test "tprelbad" | |
13ffdac3 AM |
491 | |
492 | run_dump_test "undefweak" |