Commit | Line | Data |
---|---|---|
a06ea964 | 1 | # Expect script for various AARCH64 ELF tests. |
6f2750fe | 2 | # Copyright (C) 2009-2016 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 { | |
897aea50 | 36 | {"EH Frame merge" "-Ttext 0x8000" "" "" {eh-frame-bar.s eh-frame-foo.s} |
a06ea964 | 37 | {{objdump --dwarf=frames eh-frame.d}} "eh-frame"} |
68fcca92 JW |
38 | {"Erratum 835769 dump test" |
39 | "--fix-cortex-a53-835769" "" "" {erratum835769.s} | |
40 | {{objdump -dr erratum835769.d}} | |
41 | "erratum835769"} | |
42 | {"Erratum 835769 dump test -shared" | |
43 | "--fix-cortex-a53-835769 -shared" "" "" {erratum835769.s} | |
44 | {{objdump -dr erratum835769.d}} | |
45 | "erratum835769"} | |
a06ea964 NC |
46 | } |
47 | ||
696ddf4b | 48 | proc aarch64_choose_ilp32_emul {} { |
87ad46af JW |
49 | if [istarget aarch64-*-linux*] then { |
50 | return "aarch64linux32" | |
51 | } elseif [istarget aarch64-*-elf] { | |
52 | return "aarch64elf32" | |
53 | } elseif [istarget aarch64_be-*-linux*] { | |
54 | return "aarch64linux32b" | |
55 | } elseif [istarget aarch64_be-*-elf] { | |
696ddf4b JW |
56 | return "aarch64elf32b" |
57 | } else { | |
87ad46af JW |
58 | perror "Unknown target triple." |
59 | exit 1 | |
696ddf4b JW |
60 | } |
61 | } | |
62 | ||
a06ea964 | 63 | run_ld_link_tests $aarch64elftests |
4106101c | 64 | run_dump_test "erratum843419" |
a06ea964 NC |
65 | |
66 | # Relocation Tests | |
67 | run_dump_test "weak-undefined" | |
7018c030 | 68 | run_dump_test "emit-relocs-28" |
40fbed84 JW |
69 | run_dump_test "emit-relocs-86" |
70 | run_dump_test "emit-relocs-86-overflow" | |
6ffe9a1b JW |
71 | run_dump_test "emit-relocs-87" |
72 | run_dump_test "emit-relocs-88" | |
73 | run_dump_test "emit-relocs-88-overflow" | |
74 | run_dump_test "emit-relocs-89" | |
75 | run_dump_test "emit-relocs-90" | |
76 | run_dump_test "emit-relocs-90-overflow" | |
753999c1 | 77 | run_dump_test "emit-relocs-92" |
a06ea964 NC |
78 | run_dump_test "emit-relocs-257" |
79 | run_dump_test "emit-relocs-257-be" | |
80 | # 258 is tested in 257 | |
81 | # 259 is tested in 257 | |
82 | run_dump_test "emit-relocs-260" | |
83 | run_dump_test "emit-relocs-260-be" | |
84 | # 261 is tested by 260 | |
85 | run_dump_test "emit-relocs-262" | |
86 | run_dump_test "emit-relocs-263" | |
87 | run_dump_test "emit-relocs-264" | |
614b09ce | 88 | run_dump_test "emit-relocs-264-bad" |
a06ea964 NC |
89 | run_dump_test "emit-relocs-265" |
90 | run_dump_test "emit-relocs-266" | |
614b09ce | 91 | run_dump_test "emit-relocs-266-bad" |
a06ea964 NC |
92 | run_dump_test "emit-relocs-267" |
93 | run_dump_test "emit-relocs-268" | |
614b09ce | 94 | run_dump_test "emit-relocs-268-bad" |
a06ea964 | 95 | run_dump_test "emit-relocs-269" |
614b09ce | 96 | run_dump_test "emit-relocs-269-bad" |
a06ea964 NC |
97 | run_dump_test "emit-relocs-270" |
98 | run_dump_test "emit-relocs-270-bad" | |
c5e3a364 | 99 | run_dump_test "emit-relocs-270-overflow" |
a06ea964 | 100 | run_dump_test "emit-relocs-271" |
c5e3a364 | 101 | run_dump_test "emit-relocs-271-overflow" |
a06ea964 | 102 | run_dump_test "emit-relocs-272" |
c5e3a364 | 103 | run_dump_test "emit-relocs-272-overflow" |
a06ea964 NC |
104 | run_dump_test "emit-relocs-273" |
105 | run_dump_test "emit-relocs-274" | |
106 | run_dump_test "emit-relocs-275" | |
107 | run_dump_test "emit-relocs-276" | |
108 | run_dump_test "emit-relocs-277" | |
109 | run_dump_test "emit-relocs-278" | |
110 | run_dump_test "emit-relocs-279" | |
111 | run_dump_test "emit-relocs-279-bad" | |
112 | run_dump_test "emit-relocs-280" | |
113 | # 281 is unused | |
114 | run_dump_test "emit-relocs-282" | |
115 | run_dump_test "emit-relocs-283" | |
116 | run_dump_test "emit-relocs-284" | |
117 | run_dump_test "emit-relocs-285" | |
118 | run_dump_test "emit-relocs-286" | |
119 | run_dump_test "emit-relocs-286-bad" | |
120 | # 287-298 are not done yet | |
121 | run_dump_test "emit-relocs-299" | |
dc8008f5 RL |
122 | # 300 is not done yet |
123 | run_dump_test "emit-relocs-301" | |
1ac688f8 | 124 | run_dump_test "emit-relocs-301-be" |
74a1bfe1 | 125 | run_dump_test "emit-relocs-302" |
1ac688f8 | 126 | run_dump_test "emit-relocs-302-be" |
74a1bfe1 | 127 | # 303-308 are not done yet |
f41aef5f RE |
128 | run_dump_test "emit-relocs-309-up" |
129 | run_dump_test "emit-relocs-309-low" | |
130 | run_dump_test "emit-relocs-309-up-bad" | |
131 | run_dump_test "emit-relocs-309-low-bad" | |
a2e1db00 | 132 | run_dump_test "emit-relocs-310" |
1ac688f8 | 133 | run_dump_test "emit-relocs-310-be" |
a06ea964 NC |
134 | run_dump_test "emit-relocs-311" |
135 | run_dump_test "emit-relocs-312" | |
99ad26cb | 136 | run_dump_test "emit-relocs-313" |
94facae3 | 137 | run_dump_test "emit-relocs-515" |
1ac688f8 | 138 | run_dump_test "emit-relocs-515-be" |
7ba7cfe4 | 139 | run_dump_test "emit-relocs-516" |
1ac688f8 | 140 | run_dump_test "emit-relocs-516-be" |
6ffe9a1b JW |
141 | run_dump_test "emit-relocs-523" |
142 | run_dump_test "emit-relocs-524" | |
143 | run_dump_test "emit-relocs-525" | |
144 | run_dump_test "emit-relocs-526" | |
145 | run_dump_test "emit-relocs-526-overflow" | |
146 | run_dump_test "emit-relocs-527" | |
147 | run_dump_test "emit-relocs-528" | |
148 | run_dump_test "emit-relocs-528-overflow" | |
40fbed84 JW |
149 | run_dump_test "emit-relocs-529" |
150 | run_dump_test "emit-relocs-529-overflow" | |
753999c1 | 151 | run_dump_test "emit-relocs-530" |
07c9aa07 JW |
152 | run_dump_test "emit-relocs-531" |
153 | run_dump_test "emit-relocs-531-overflow" | |
154 | run_dump_test "emit-relocs-532" | |
155 | run_dump_test "emit-relocs-533" | |
156 | run_dump_test "emit-relocs-533-overflow" | |
157 | run_dump_test "emit-relocs-534" | |
158 | run_dump_test "emit-relocs-535" | |
159 | run_dump_test "emit-relocs-535-overflow" | |
160 | run_dump_test "emit-relocs-536" | |
161 | run_dump_test "emit-relocs-537" | |
162 | run_dump_test "emit-relocs-537-overflow" | |
163 | run_dump_test "emit-relocs-538" | |
a06ea964 | 164 | |
027e9c75 NC |
165 | run_dump_test "reloc-overflow-bad" |
166 | ||
2e0488d3 JW |
167 | # test addend correctness when --emit-relocs specified for non-relocatable obj. |
168 | run_dump_test "emit-relocs-local-addend" | |
169 | # test addend correctness when -r specified. | |
170 | run_dump_test "local-addend-r" | |
a06ea964 | 171 | |
dcbd20eb JW |
172 | # test error handling on pcrel relocation for shared libraries. |
173 | run_dump_test "pcrel_pic_undefined" | |
174 | run_dump_test "pcrel_pic_defined_local" | |
175 | ||
a06ea964 NC |
176 | run_dump_test "limit-b" |
177 | run_dump_test "limit-bl" | |
a06ea964 | 178 | run_dump_test "farcall-back" |
f678ded7 JW |
179 | run_dump_test "farcall-b-defsym" |
180 | run_dump_test "farcall-bl-defsym" | |
07f9ddfe JW |
181 | run_dump_test "farcall-b-gsym" |
182 | run_dump_test "farcall-b-plt" | |
183 | run_dump_test "farcall-bl-plt" | |
a06ea964 NC |
184 | run_dump_test "farcall-bl" |
185 | run_dump_test "farcall-b" | |
186 | run_dump_test "farcall-b-none-function" | |
187 | run_dump_test "farcall-bl-none-function" | |
2f340668 JW |
188 | run_dump_test "farcall-b-section" |
189 | run_dump_test "farcall-bl-section" | |
a06ea964 NC |
190 | |
191 | run_dump_test "tls-relax-all" | |
192 | run_dump_test "tls-relax-gd-le" | |
193 | run_dump_test "tls-relax-gdesc-le" | |
194 | run_dump_test "tls-relax-gd-ie" | |
ac734732 | 195 | run_dump_test "tls-relax-large-gd-ie" |
1ac688f8 | 196 | run_dump_test "tls-relax-large-gd-ie-be" |
ac734732 | 197 | run_dump_test "tls-relax-large-gd-le" |
1ac688f8 | 198 | run_dump_test "tls-relax-large-gd-le-be" |
0484b454 | 199 | run_dump_test "tls-relax-large-desc-ie" |
1ac688f8 | 200 | run_dump_test "tls-relax-large-desc-ie-be" |
0484b454 | 201 | run_dump_test "tls-relax-large-desc-le" |
1ac688f8 | 202 | run_dump_test "tls-relax-large-desc-le-be" |
a06ea964 NC |
203 | run_dump_test "tls-relax-gdesc-ie" |
204 | run_dump_test "tls-relax-ie-le" | |
259364ad JW |
205 | run_dump_test "tls-relax-ld-le-small" |
206 | run_dump_test "tls-relax-ld-le-tiny" | |
a06ea964 NC |
207 | run_dump_test "tls-desc-ie" |
208 | run_dump_test "tls-relax-gdesc-ie-2" | |
209 | run_dump_test "tls-relax-gdesc-le-2" | |
210 | run_dump_test "tls-relax-ie-le-2" | |
211 | run_dump_test "tls-relax-ie-le-3" | |
b480a481 MS |
212 | run_dump_test "tls-tiny-gd" |
213 | run_dump_test "tls-tiny-gd-ie" | |
214 | run_dump_test "tls-tiny-gd-le" | |
60d1b0d6 MS |
215 | run_dump_test "tls-tiny-desc" |
216 | run_dump_test "tls-tiny-desc-ie" | |
217 | run_dump_test "tls-tiny-desc-le" | |
b1089987 | 218 | run_dump_test "tls-tiny-ie" |
3b957e5b | 219 | run_dump_test "tls-large-ie" |
1ac688f8 | 220 | run_dump_test "tls-large-ie-be" |
0484b454 | 221 | run_dump_test "tls-large-desc" |
1ac688f8 | 222 | run_dump_test "tls-large-desc-be" |
77a69ff8 | 223 | run_dump_test "tls-tiny-ld" |
f69e4920 | 224 | run_dump_test "tls-small-ld" |
e09ab7ac | 225 | run_dump_test "tlsle" |
bb3f9ed8 | 226 | run_dump_test "tlsle-symbol-offset" |
cb8af559 NC |
227 | run_dump_test "gc-got-relocs" |
228 | run_dump_test "gc-tls-relocs" | |
edb2fa9a MS |
229 | run_dump_test "gc-plt-relocs" |
230 | run_dump_test "gc-relocs-257-dyn" | |
231 | run_dump_test "gc-relocs-257" | |
18f822a0 | 232 | run_dump_test "implicit_got_section_1" |
bab91cce | 233 | run_dump_test "pr17415" |
0172429c | 234 | run_dump_test "tprel_g2_overflow" |
36e6c140 | 235 | run_dump_test "tprel_add_lo12_overflow" |
32f573bc | 236 | run_dump_test "protected-data" |
1419bbe5 WN |
237 | |
238 | # ifunc tests | |
239 | run_dump_test "ifunc-1" | |
240 | run_dump_test "ifunc-1-local" | |
241 | run_dump_test "ifunc-2" | |
242 | run_dump_test "ifunc-2-local" | |
243 | run_dump_test "ifunc-3a" | |
244 | run_dump_test "ifunc-3b" | |
245 | run_dump_test "ifunc-4" | |
246 | run_dump_test "ifunc-4a" | |
247 | run_dump_test "ifunc-5a" | |
248 | run_dump_test "ifunc-5b" | |
249 | run_dump_test "ifunc-5a-local" | |
250 | run_dump_test "ifunc-5b-local" | |
251 | run_dump_test "ifunc-5r-local" | |
252 | run_dump_test "ifunc-6a" | |
253 | run_dump_test "ifunc-6b" | |
254 | run_dump_test "ifunc-7a" | |
255 | run_dump_test "ifunc-7b" | |
256 | run_dump_test "ifunc-7c" | |
257 | run_dump_test "ifunc-8" | |
258 | run_dump_test "ifunc-9" | |
259 | run_dump_test "ifunc-10" | |
260 | run_dump_test "ifunc-11" | |
261 | run_dump_test "ifunc-12" | |
262 | run_dump_test "ifunc-13" | |
263 | run_dump_test "ifunc-14a" | |
264 | run_dump_test "ifunc-14b" | |
265 | run_dump_test "ifunc-14c" | |
266 | run_dump_test "ifunc-14d" | |
267 | run_dump_test "ifunc-14e" | |
268 | run_dump_test "ifunc-14f" | |
269 | run_dump_test "ifunc-15" | |
270 | run_dump_test "ifunc-16" | |
271 | run_dump_test "ifunc-17a" | |
272 | run_dump_test "ifunc-17b" | |
273 | run_dump_test "ifunc-18a" | |
274 | run_dump_test "ifunc-18b" | |
275 | run_dump_test "ifunc-19a" | |
276 | run_dump_test "ifunc-19b" | |
277 | run_dump_test "ifunc-20" | |
b1ee0cc4 | 278 | run_dump_test "ifunc-21" |
49206388 | 279 | run_dump_test "ifunc-22" |
c955de36 WN |
280 | |
281 | run_dump_test "relasz" | |
f63d6d96 | 282 | run_dump_test "relocs-1027-symbolic-func" |
614b09ce | 283 | |
c2170589 JW |
284 | run_dump_test "dt_textrel" |
285 | ||
73524045 RL |
286 | run_dump_test "plt_mapping_symbol" |
287 | ||
1f56df9d JW |
288 | run_dump_test "rela-abs-relative" |
289 | run_dump_test "rela-abs-relative-be" | |
290 | run_dump_test "rela-abs-relative-opt" | |
291 | ||
614b09ce JW |
292 | set aarch64elflinktests { |
293 | {"ld-aarch64/so with global symbol" "-shared" "" "" {copy-reloc-so.s} | |
027e9c75 | 294 | {} "copy-reloc-so.so"} |
614b09ce | 295 | {"ld-aarch64/exe with copy relocation" "-e0 tmpdir/copy-reloc-so.so" "" "" |
027e9c75 | 296 | {copy-reloc-exe.s} {{objdump -R copy-reloc.d}} "copy-reloc"} |
614b09ce JW |
297 | } |
298 | ||
299 | run_ld_link_tests $aarch64elflinktests |