Re-add support for lbarx, lharx, stbcx. and sthcx. insns back to the E6500 cpu.
[binutils-gdb.git] / ld / testsuite / ld-aarch64 / aarch64-elf.exp
blobb27da52acd8f11e017492e45122d96dc462c4d63
1 # Expect script for various AARCH64 ELF tests.
2 # Copyright (C) 2009-2016 Free Software Foundation, Inc.
4 # This file is part of the GNU Binutils.
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.
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.
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.
21 # Exclude non-aarch64-ELF targets.
22 if { ![is_elf_format] || ![istarget "aarch64*-*-*"] } {
23     return
26 # List contains test-items with 3 items followed by 2 lists:
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
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).
35 set aarch64elftests {
36     {"EH Frame merge" "-Ttext 0x8000" "" "" {eh-frame-bar.s eh-frame-foo.s}
37         {{objdump --dwarf=frames eh-frame.d}} "eh-frame"}
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"}
48 proc aarch64_choose_ilp32_emul {} {
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] {
56         return "aarch64elf32b"
57     } else {
58       perror "Unknown target triple."
59       exit 1
60     }
63 run_ld_link_tests $aarch64elftests
64 run_dump_test "erratum843419"
66 # Relocation Tests
67 run_dump_test "weak-undefined"
68 run_dump_test "emit-relocs-28"
69 run_dump_test "emit-relocs-86"
70 run_dump_test "emit-relocs-86-overflow"
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"
77 run_dump_test "emit-relocs-92"
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"
88 run_dump_test "emit-relocs-264-bad"
89 run_dump_test "emit-relocs-265"
90 run_dump_test "emit-relocs-266"
91 run_dump_test "emit-relocs-266-bad"
92 run_dump_test "emit-relocs-267"
93 run_dump_test "emit-relocs-268"
94 run_dump_test "emit-relocs-268-bad"
95 run_dump_test "emit-relocs-269"
96 run_dump_test "emit-relocs-269-bad"
97 run_dump_test "emit-relocs-270"
98 run_dump_test "emit-relocs-270-bad"
99 run_dump_test "emit-relocs-270-overflow"
100 run_dump_test "emit-relocs-271"
101 run_dump_test "emit-relocs-271-overflow"
102 run_dump_test "emit-relocs-272"
103 run_dump_test "emit-relocs-272-overflow"
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"
122 # 300 is not done yet
123 run_dump_test "emit-relocs-301"
124 run_dump_test "emit-relocs-301-be"
125 run_dump_test "emit-relocs-302"
126 run_dump_test "emit-relocs-302-be"
127 # 303-308 are not done yet
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"
132 run_dump_test "emit-relocs-310"
133 run_dump_test "emit-relocs-310-be"
134 run_dump_test "emit-relocs-311"
135 run_dump_test "emit-relocs-312"
136 run_dump_test "emit-relocs-313"
137 run_dump_test "emit-relocs-515"
138 run_dump_test "emit-relocs-515-be"
139 run_dump_test "emit-relocs-516"
140 run_dump_test "emit-relocs-516-be"
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"
149 run_dump_test "emit-relocs-529"
150 run_dump_test "emit-relocs-529-overflow"
151 run_dump_test "emit-relocs-530"
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"
165 run_dump_test "reloc-overflow-bad"
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"
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"
176 run_dump_test "limit-b"
177 run_dump_test "limit-bl"
178 run_dump_test "farcall-back"
179 run_dump_test "farcall-b-defsym"
180 run_dump_test "farcall-bl-defsym"
181 run_dump_test "farcall-b-gsym"
182 run_dump_test "farcall-b-plt"
183 run_dump_test "farcall-bl-plt"
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"
188 run_dump_test "farcall-b-section"
189 run_dump_test "farcall-bl-section"
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"
195 run_dump_test "tls-relax-large-gd-ie"
196 run_dump_test "tls-relax-large-gd-ie-be"
197 run_dump_test "tls-relax-large-gd-le"
198 run_dump_test "tls-relax-large-gd-le-be"
199 run_dump_test "tls-relax-large-desc-ie"
200 run_dump_test "tls-relax-large-desc-ie-be"
201 run_dump_test "tls-relax-large-desc-le"
202 run_dump_test "tls-relax-large-desc-le-be"
203 run_dump_test "tls-relax-gdesc-ie"
204 run_dump_test "tls-relax-ie-le"
205 run_dump_test "tls-relax-ld-le-small"
206 run_dump_test "tls-relax-ld-le-tiny"
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"
212 run_dump_test "tls-tiny-gd"
213 run_dump_test "tls-tiny-gd-ie"
214 run_dump_test "tls-tiny-gd-le"
215 run_dump_test "tls-tiny-desc"
216 run_dump_test "tls-tiny-desc-ie"
217 run_dump_test "tls-tiny-desc-le"
218 run_dump_test "tls-tiny-ie"
219 run_dump_test "tls-large-ie"
220 run_dump_test "tls-large-ie-be"
221 run_dump_test "tls-large-desc"
222 run_dump_test "tls-large-desc-be"
223 run_dump_test "tls-tiny-ld"
224 run_dump_test "tls-small-ld"
225 run_dump_test "tlsle"
226 run_dump_test "tlsle-symbol-offset"
227 run_dump_test "gc-got-relocs"
228 run_dump_test "gc-tls-relocs"
229 run_dump_test "gc-plt-relocs"
230 run_dump_test "gc-relocs-257-dyn"
231 run_dump_test "gc-relocs-257"
232 run_dump_test "implicit_got_section_1"
233 run_dump_test "pr17415"
234 run_dump_test "tprel_g2_overflow"
235 run_dump_test "tprel_add_lo12_overflow"
236 run_dump_test "protected-data"
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"
278 run_dump_test "ifunc-21"
279 run_dump_test "ifunc-22"
281 run_dump_test "relasz"
282 run_dump_test "relocs-1027-symbolic-func"
284 run_dump_test "dt_textrel"
286 run_dump_test "plt_mapping_symbol"
288 run_dump_test "rela-abs-relative"
289 run_dump_test "rela-abs-relative-be"
290 run_dump_test "rela-abs-relative-opt"
292 set aarch64elflinktests {
293   {"ld-aarch64/so with global symbol" "-shared" "" "" {copy-reloc-so.s}
294     {} "copy-reloc-so.so"}
295   {"ld-aarch64/exe with copy relocation" "-e0 tmpdir/copy-reloc-so.so" "" ""
296     {copy-reloc-exe.s} {{objdump -R copy-reloc.d}} "copy-reloc"}
299 run_ld_link_tests $aarch64elflinktests