Commit | Line | Data |
---|---|---|
a06ea964 | 1 | # Expect script for various AARCH64 ELF tests. |
219d1afa | 2 | # Copyright (C) 2009-2018 Free Software Foundation, Inc. |
a06ea964 NC |
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 | # Exclude non-aarch64-ELF targets. | |
22 | if { ![is_elf_format] || ![istarget "aarch64*-*-*"] } { | |
23 | return | |
24 | } | |
25 | ||
26 | # List contains test-items with 3 items followed by 2 lists: | |
897aea50 MR |
27 | # 0:name 1:ld early options 2:ld late options 3:assembler options |
28 | # 4:filenames of assembler files 5: action and options. 6: name of output file | |
a06ea964 NC |
29 | |
30 | # Actions: | |
31 | # objdump: Apply objdump options on result. Compare with regex (last arg). | |
32 | # nm: Apply nm options on result. Compare with regex (last arg). | |
33 | # readelf: Apply readelf options on result. Compare with regex (last arg). | |
34 | ||
35 | set aarch64elftests { | |
68fcca92 JW |
36 | {"Erratum 835769 dump test" |
37 | "--fix-cortex-a53-835769" "" "" {erratum835769.s} | |
38 | {{objdump -dr erratum835769.d}} | |
39 | "erratum835769"} | |
40 | {"Erratum 835769 dump test -shared" | |
41 | "--fix-cortex-a53-835769 -shared" "" "" {erratum835769.s} | |
42 | {{objdump -dr erratum835769.d}} | |
43 | "erratum835769"} | |
a06ea964 NC |
44 | } |
45 | ||
696ddf4b | 46 | proc aarch64_choose_ilp32_emul {} { |
78da3bc1 AM |
47 | if [istarget *linux*] then { |
48 | if [istarget aarch64_be-*] { | |
49 | return "aarch64linux32b" | |
50 | } | |
51 | return "aarch64linux32" | |
52 | } | |
53 | if [istarget aarch64_be-*] { | |
696ddf4b | 54 | return "aarch64elf32b" |
696ddf4b | 55 | } |
78da3bc1 | 56 | return "aarch64elf32" |
696ddf4b JW |
57 | } |
58 | ||
971f1d27 JW |
59 | proc aarch64_choose_lp64_emul {} { |
60 | if [istarget *linux*] then { | |
61 | if [istarget aarch64_be-*] { | |
62 | return "aarch64linuxb" | |
63 | } | |
64 | return "aarch64linux" | |
65 | } | |
66 | if [istarget aarch64_be-*] { | |
67 | return "aarch64elfb" | |
68 | } | |
69 | return "aarch64elf" | |
70 | } | |
71 | ||
72 | proc run_dump_test_lp64 { testname } { | |
73 | run_dump_test $testname \ | |
74 | [list [list as "-mabi=lp64"] \ | |
75 | [list ld [concat "-m " [aarch64_choose_lp64_emul]]]] | |
76 | } | |
77 | ||
78 | set eh-frame-merge-lp64 [list [list "EH Frame merge" \ | |
79 | [concat "-m " [aarch64_choose_lp64_emul] \ | |
80 | " -Ttext 0x8000"] \ | |
81 | "" "-mabi=lp64" {eh-frame-bar.s eh-frame-foo.s} \ | |
82 | {{objdump --dwarf=frames eh-frame.d}} \ | |
83 | "eh-frame"]] | |
84 | ||
a06ea964 | 85 | run_ld_link_tests $aarch64elftests |
971f1d27 JW |
86 | run_ld_link_tests eh-frame-merge-lp64 |
87 | ||
4106101c | 88 | run_dump_test "erratum843419" |
a06ea964 NC |
89 | |
90 | # Relocation Tests | |
971f1d27 | 91 | run_dump_test_lp64 "weak-undefined" |
7018c030 | 92 | run_dump_test "emit-relocs-28" |
40fbed84 JW |
93 | run_dump_test "emit-relocs-86" |
94 | run_dump_test "emit-relocs-86-overflow" | |
6ffe9a1b JW |
95 | run_dump_test "emit-relocs-87" |
96 | run_dump_test "emit-relocs-88" | |
97 | run_dump_test "emit-relocs-88-overflow" | |
98 | run_dump_test "emit-relocs-89" | |
99 | run_dump_test "emit-relocs-90" | |
100 | run_dump_test "emit-relocs-90-overflow" | |
753999c1 | 101 | run_dump_test "emit-relocs-92" |
971f1d27 JW |
102 | run_dump_test_lp64 "emit-relocs-257" |
103 | run_dump_test_lp64 "emit-relocs-257-be" | |
a06ea964 NC |
104 | # 258 is tested in 257 |
105 | # 259 is tested in 257 | |
79e74192 RL |
106 | run_dump_test_lp64 "emit-relocs-258-dyn-bad" |
107 | run_dump_test_lp64 "emit-relocs-259-dyn-bad" | |
971f1d27 JW |
108 | run_dump_test_lp64 "emit-relocs-260" |
109 | run_dump_test_lp64 "emit-relocs-260-be" | |
a06ea964 | 110 | # 261 is tested by 260 |
971f1d27 JW |
111 | run_dump_test_lp64 "emit-relocs-262" |
112 | run_dump_test_lp64 "emit-relocs-263" | |
113 | run_dump_test_lp64 "emit-relocs-264" | |
114 | run_dump_test_lp64 "emit-relocs-264-bad" | |
115 | run_dump_test_lp64 "emit-relocs-265" | |
116 | run_dump_test_lp64 "emit-relocs-266" | |
117 | run_dump_test_lp64 "emit-relocs-266-bad" | |
118 | run_dump_test_lp64 "emit-relocs-267" | |
119 | run_dump_test_lp64 "emit-relocs-268" | |
120 | run_dump_test_lp64 "emit-relocs-268-bad" | |
121 | run_dump_test_lp64 "emit-relocs-269" | |
122 | run_dump_test_lp64 "emit-relocs-269-bad" | |
123 | run_dump_test_lp64 "emit-relocs-270" | |
124 | run_dump_test_lp64 "emit-relocs-270-bad" | |
125 | run_dump_test_lp64 "emit-relocs-270-overflow" | |
126 | run_dump_test_lp64 "emit-relocs-271" | |
127 | run_dump_test_lp64 "emit-relocs-271-overflow" | |
128 | run_dump_test_lp64 "emit-relocs-272" | |
129 | run_dump_test_lp64 "emit-relocs-272-overflow" | |
130 | run_dump_test_lp64 "emit-relocs-273" | |
131 | run_dump_test_lp64 "emit-relocs-274" | |
132 | run_dump_test_lp64 "emit-relocs-275" | |
133 | run_dump_test_lp64 "emit-relocs-276" | |
134 | run_dump_test_lp64 "emit-relocs-277" | |
135 | run_dump_test_lp64 "emit-relocs-278" | |
136 | run_dump_test_lp64 "emit-relocs-279" | |
137 | run_dump_test_lp64 "emit-relocs-279-bad" | |
138 | run_dump_test_lp64 "emit-relocs-280" | |
a06ea964 | 139 | # 281 is unused |
971f1d27 JW |
140 | run_dump_test_lp64 "emit-relocs-282" |
141 | run_dump_test_lp64 "emit-relocs-283" | |
142 | run_dump_test_lp64 "emit-relocs-284" | |
143 | run_dump_test_lp64 "emit-relocs-285" | |
144 | run_dump_test_lp64 "emit-relocs-286" | |
145 | run_dump_test_lp64 "emit-relocs-286-bad" | |
1daf502a RL |
146 | run_dump_test_lp64 "emit-relocs-287" |
147 | run_dump_test_lp64 "emit-relocs-287-overflow" | |
148 | run_dump_test_lp64 "emit-relocs-288" | |
149 | run_dump_test_lp64 "emit-relocs-289" | |
150 | run_dump_test_lp64 "emit-relocs-289-overflow" | |
151 | run_dump_test_lp64 "emit-relocs-290" | |
152 | run_dump_test_lp64 "emit-relocs-291" | |
153 | run_dump_test_lp64 "emit-relocs-291-overflow" | |
154 | run_dump_test_lp64 "emit-relocs-292" | |
155 | run_dump_test_lp64 "emit-relocs-293" | |
156 | # 294-298 are not done yet | |
971f1d27 | 157 | run_dump_test_lp64 "emit-relocs-299" |
dc8008f5 | 158 | # 300 is not done yet |
971f1d27 JW |
159 | run_dump_test_lp64 "emit-relocs-301" |
160 | run_dump_test_lp64 "emit-relocs-301-be" | |
161 | run_dump_test_lp64 "emit-relocs-302" | |
162 | run_dump_test_lp64 "emit-relocs-302-be" | |
74a1bfe1 | 163 | # 303-308 are not done yet |
971f1d27 JW |
164 | run_dump_test_lp64 "emit-relocs-309-up" |
165 | run_dump_test_lp64 "emit-relocs-309-low" | |
166 | run_dump_test_lp64 "emit-relocs-309-up-bad" | |
167 | run_dump_test_lp64 "emit-relocs-309-low-bad" | |
168 | run_dump_test_lp64 "emit-relocs-310" | |
169 | run_dump_test_lp64 "emit-relocs-310-be" | |
170 | run_dump_test_lp64 "emit-relocs-311" | |
171 | run_dump_test_lp64 "emit-relocs-312" | |
172 | run_dump_test_lp64 "emit-relocs-313" | |
173 | run_dump_test_lp64 "emit-relocs-515" | |
174 | run_dump_test_lp64 "emit-relocs-515-be" | |
175 | run_dump_test_lp64 "emit-relocs-516" | |
176 | run_dump_test_lp64 "emit-relocs-516-be" | |
177 | run_dump_test_lp64 "emit-relocs-523" | |
178 | run_dump_test_lp64 "emit-relocs-524" | |
179 | run_dump_test_lp64 "emit-relocs-525" | |
180 | run_dump_test_lp64 "emit-relocs-526" | |
181 | run_dump_test_lp64 "emit-relocs-526-overflow" | |
182 | run_dump_test_lp64 "emit-relocs-527" | |
183 | run_dump_test_lp64 "emit-relocs-528" | |
184 | run_dump_test_lp64 "emit-relocs-528-overflow" | |
185 | run_dump_test_lp64 "emit-relocs-529" | |
186 | run_dump_test_lp64 "emit-relocs-529-overflow" | |
187 | run_dump_test_lp64 "emit-relocs-530" | |
188 | run_dump_test_lp64 "emit-relocs-531" | |
189 | run_dump_test_lp64 "emit-relocs-531-overflow" | |
190 | run_dump_test_lp64 "emit-relocs-532" | |
191 | run_dump_test_lp64 "emit-relocs-533" | |
192 | run_dump_test_lp64 "emit-relocs-533-overflow" | |
193 | run_dump_test_lp64 "emit-relocs-534" | |
194 | run_dump_test_lp64 "emit-relocs-535" | |
195 | run_dump_test_lp64 "emit-relocs-535-overflow" | |
196 | run_dump_test_lp64 "emit-relocs-536" | |
197 | run_dump_test_lp64 "emit-relocs-537" | |
198 | run_dump_test_lp64 "emit-relocs-537-overflow" | |
199 | run_dump_test_lp64 "emit-relocs-538" | |
a06ea964 | 200 | |
027e9c75 NC |
201 | run_dump_test "reloc-overflow-bad" |
202 | ||
2e0488d3 | 203 | # test addend correctness when --emit-relocs specified for non-relocatable obj. |
971f1d27 | 204 | run_dump_test_lp64 "emit-relocs-local-addend" |
2e0488d3 | 205 | # test addend correctness when -r specified. |
971f1d27 | 206 | run_dump_test_lp64 "local-addend-r" |
a06ea964 | 207 | |
dcbd20eb | 208 | # test error handling on pcrel relocation for shared libraries. |
971f1d27 | 209 | run_dump_test_lp64 "pcrel_pic_undefined" |
d68f1976 | 210 | run_dump_test_lp64 "pcrel_pic_defined" |
dcbd20eb | 211 | |
a06ea964 NC |
212 | run_dump_test "limit-b" |
213 | run_dump_test "limit-bl" | |
a06ea964 | 214 | run_dump_test "farcall-back" |
f678ded7 JW |
215 | run_dump_test "farcall-b-defsym" |
216 | run_dump_test "farcall-bl-defsym" | |
07f9ddfe JW |
217 | run_dump_test "farcall-b-gsym" |
218 | run_dump_test "farcall-b-plt" | |
219 | run_dump_test "farcall-bl-plt" | |
a06ea964 NC |
220 | run_dump_test "farcall-bl" |
221 | run_dump_test "farcall-b" | |
222 | run_dump_test "farcall-b-none-function" | |
223 | run_dump_test "farcall-bl-none-function" | |
2f340668 JW |
224 | run_dump_test "farcall-b-section" |
225 | run_dump_test "farcall-bl-section" | |
a06ea964 NC |
226 | |
227 | run_dump_test "tls-relax-all" | |
2d0ca824 | 228 | run_dump_test "tls-relax-all-ilp32" |
a06ea964 | 229 | run_dump_test "tls-relax-gd-le" |
2d0ca824 | 230 | run_dump_test "tls-relax-gd-le-ilp32" |
a06ea964 | 231 | run_dump_test "tls-relax-gdesc-le" |
2d0ca824 | 232 | run_dump_test "tls-relax-gdesc-le-ilp32" |
a06ea964 | 233 | run_dump_test "tls-relax-gd-ie" |
2d0ca824 | 234 | run_dump_test "tls-relax-gd-ie-ilp32" |
971f1d27 JW |
235 | run_dump_test_lp64 "tls-relax-large-gd-ie" |
236 | run_dump_test_lp64 "tls-relax-large-gd-ie-be" | |
237 | run_dump_test_lp64 "tls-relax-large-gd-le" | |
238 | run_dump_test_lp64 "tls-relax-large-gd-le-be" | |
239 | run_dump_test_lp64 "tls-relax-large-desc-ie" | |
240 | run_dump_test_lp64 "tls-relax-large-desc-ie-be" | |
241 | run_dump_test_lp64 "tls-relax-large-desc-le" | |
242 | run_dump_test_lp64 "tls-relax-large-desc-le-be" | |
a06ea964 NC |
243 | run_dump_test "tls-relax-gdesc-ie" |
244 | run_dump_test "tls-relax-ie-le" | |
2d0ca824 | 245 | run_dump_test "tls-relax-ie-le-ilp32" |
259364ad | 246 | run_dump_test "tls-relax-ld-le-small" |
c1fc2d7e | 247 | run_dump_test "tls-relax-ld-le-small-ilp32" |
259364ad | 248 | run_dump_test "tls-relax-ld-le-tiny" |
c1fc2d7e | 249 | run_dump_test "tls-relax-ld-le-tiny-ilp32" |
a06ea964 | 250 | run_dump_test "tls-desc-ie" |
2d0ca824 | 251 | run_dump_test "tls-desc-ie-ilp32" |
a06ea964 NC |
252 | run_dump_test "tls-relax-gdesc-ie-2" |
253 | run_dump_test "tls-relax-gdesc-le-2" | |
2d0ca824 | 254 | run_dump_test "tls-relax-gdesc-le-2-ilp32" |
a06ea964 | 255 | run_dump_test "tls-relax-ie-le-2" |
2d0ca824 | 256 | run_dump_test "tls-relax-ie-le-2-ilp32" |
a06ea964 | 257 | run_dump_test "tls-relax-ie-le-3" |
2d0ca824 | 258 | run_dump_test "tls-relax-ie-le-3-ilp32" |
b480a481 MS |
259 | run_dump_test "tls-tiny-gd" |
260 | run_dump_test "tls-tiny-gd-ie" | |
2d0ca824 | 261 | run_dump_test "tls-tiny-gd-ie-ilp32" |
b480a481 | 262 | run_dump_test "tls-tiny-gd-le" |
2d0ca824 | 263 | run_dump_test "tls-tiny-gd-le-ilp32" |
60d1b0d6 MS |
264 | run_dump_test "tls-tiny-desc" |
265 | run_dump_test "tls-tiny-desc-ie" | |
2d0ca824 | 266 | run_dump_test "tls-tiny-desc-ie-ilp32" |
60d1b0d6 | 267 | run_dump_test "tls-tiny-desc-le" |
2d0ca824 | 268 | run_dump_test "tls-tiny-desc-le-ilp32" |
b1089987 | 269 | run_dump_test "tls-tiny-ie" |
971f1d27 JW |
270 | run_dump_test_lp64 "tls-large-ie" |
271 | run_dump_test_lp64 "tls-large-ie-be" | |
272 | run_dump_test_lp64 "tls-large-desc" | |
273 | run_dump_test_lp64 "tls-large-desc-be" | |
77a69ff8 | 274 | run_dump_test "tls-tiny-ld" |
f69e4920 | 275 | run_dump_test "tls-small-ld" |
971f1d27 | 276 | run_dump_test_lp64 "tlsle" |
bb3f9ed8 | 277 | run_dump_test "tlsle-symbol-offset" |
cb8af559 NC |
278 | run_dump_test "gc-got-relocs" |
279 | run_dump_test "gc-tls-relocs" | |
971f1d27 JW |
280 | run_dump_test_lp64 "gc-plt-relocs" |
281 | run_dump_test_lp64 "gc-relocs-257-dyn" | |
282 | run_dump_test_lp64 "gc-relocs-257" | |
18f822a0 | 283 | run_dump_test "implicit_got_section_1" |
bab91cce | 284 | run_dump_test "pr17415" |
971f1d27 | 285 | run_dump_test_lp64 "tprel_g2_overflow" |
36e6c140 | 286 | run_dump_test "tprel_add_lo12_overflow" |
32f573bc | 287 | run_dump_test "protected-data" |
279b2f94 | 288 | run_dump_test_lp64 "pr22764" |
0c1ded8d | 289 | run_dump_test_lp64 "pr20402" |
1419bbe5 WN |
290 | |
291 | # ifunc tests | |
292 | run_dump_test "ifunc-1" | |
293 | run_dump_test "ifunc-1-local" | |
294 | run_dump_test "ifunc-2" | |
295 | run_dump_test "ifunc-2-local" | |
296 | run_dump_test "ifunc-3a" | |
297 | run_dump_test "ifunc-3b" | |
298 | run_dump_test "ifunc-4" | |
299 | run_dump_test "ifunc-4a" | |
300 | run_dump_test "ifunc-5a" | |
301 | run_dump_test "ifunc-5b" | |
302 | run_dump_test "ifunc-5a-local" | |
303 | run_dump_test "ifunc-5b-local" | |
304 | run_dump_test "ifunc-5r-local" | |
305 | run_dump_test "ifunc-6a" | |
306 | run_dump_test "ifunc-6b" | |
307 | run_dump_test "ifunc-7a" | |
308 | run_dump_test "ifunc-7b" | |
309 | run_dump_test "ifunc-7c" | |
310 | run_dump_test "ifunc-8" | |
971f1d27 JW |
311 | run_dump_test_lp64 "ifunc-9" |
312 | run_dump_test_lp64 "ifunc-10" | |
313 | run_dump_test_lp64 "ifunc-11" | |
314 | run_dump_test_lp64 "ifunc-12" | |
315 | run_dump_test_lp64 "ifunc-13" | |
1419bbe5 WN |
316 | run_dump_test "ifunc-14a" |
317 | run_dump_test "ifunc-14b" | |
318 | run_dump_test "ifunc-14c" | |
319 | run_dump_test "ifunc-14d" | |
320 | run_dump_test "ifunc-14e" | |
321 | run_dump_test "ifunc-14f" | |
322 | run_dump_test "ifunc-15" | |
323 | run_dump_test "ifunc-16" | |
324 | run_dump_test "ifunc-17a" | |
325 | run_dump_test "ifunc-17b" | |
971f1d27 JW |
326 | run_dump_test_lp64 "ifunc-18a" |
327 | run_dump_test_lp64 "ifunc-18b" | |
328 | run_dump_test_lp64 "ifunc-19a" | |
329 | run_dump_test_lp64 "ifunc-19b" | |
330 | run_dump_test_lp64 "ifunc-20" | |
331 | run_dump_test_lp64 "ifunc-21" | |
332 | run_dump_test_lp64 "ifunc-22" | |
c955de36 WN |
333 | |
334 | run_dump_test "relasz" | |
971f1d27 | 335 | run_dump_test_lp64 "relocs-1027-symbolic-func" |
614b09ce | 336 | |
971f1d27 | 337 | run_dump_test_lp64 "dt_textrel" |
c2170589 | 338 | |
73524045 RL |
339 | run_dump_test "plt_mapping_symbol" |
340 | ||
971f1d27 JW |
341 | run_dump_test_lp64 "rela-abs-relative" |
342 | run_dump_test_lp64 "rela-abs-relative-be" | |
343 | run_dump_test_lp64 "rela-abs-relative-opt" | |
1f56df9d | 344 | |
971f1d27 | 345 | run_dump_test_lp64 "pie-bind-locally" |
ac33b731 | 346 | |
614b09ce JW |
347 | set aarch64elflinktests { |
348 | {"ld-aarch64/so with global symbol" "-shared" "" "" {copy-reloc-so.s} | |
027e9c75 | 349 | {} "copy-reloc-so.so"} |
614b09ce | 350 | {"ld-aarch64/exe with copy relocation" "-e0 tmpdir/copy-reloc-so.so" "" "" |
027e9c75 | 351 | {copy-reloc-exe.s} {{objdump -R copy-reloc.d}} "copy-reloc"} |
6353d82b JW |
352 | {"ld-aarch64/exe with copy relocation 2" "-e0 tmpdir/copy-reloc-so.so" "" "" |
353 | {copy-reloc-exe-2.s} {{objdump -R copy-reloc-2.d}} "copy-reloc-2"} | |
354 | {"ld-aarch64/exe with copy relocation elimination" "-e0 tmpdir/copy-reloc-so.so" "" "" | |
355 | {copy-reloc-exe-eliminate.s} {{objdump -R copy-reloc-eliminate.d}} "copy-reloc-elimination"} | |
7f784814 JW |
356 | {"ld-aarch64/so with global func" "-shared" "" "" {func-in-so.s} |
357 | {} "func-in-so.so"} | |
358 | {"ld-aarch64/func sym hash opt for exe" | |
359 | "-e0 --hash-style=gnu tmpdir/func-in-so.so" "" "" | |
360 | {func-sym-hash-opt.s} {{readelf --dyn-sym func-sym-hash-opt.d}} "hash-opt"} | |
614b09ce JW |
361 | } |
362 | ||
363 | run_ld_link_tests $aarch64elflinktests |