[1/2][GAS][AARCH64]Add BFD_RELOC_AARCH64_TLSLE_LDST8/16/32/64_TPREL_LO12 support...
[deliverable/binutils-gdb.git] / ld / testsuite / ld-aarch64 / aarch64-elf.exp
CommitLineData
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.
22if { ![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
35set 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 46proc 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
59proc 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
72proc 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
78set 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 85run_ld_link_tests $aarch64elftests
971f1d27
JW
86run_ld_link_tests eh-frame-merge-lp64
87
4106101c 88run_dump_test "erratum843419"
a06ea964
NC
89
90# Relocation Tests
971f1d27 91run_dump_test_lp64 "weak-undefined"
7018c030 92run_dump_test "emit-relocs-28"
40fbed84
JW
93run_dump_test "emit-relocs-86"
94run_dump_test "emit-relocs-86-overflow"
6ffe9a1b
JW
95run_dump_test "emit-relocs-87"
96run_dump_test "emit-relocs-88"
97run_dump_test "emit-relocs-88-overflow"
98run_dump_test "emit-relocs-89"
99run_dump_test "emit-relocs-90"
100run_dump_test "emit-relocs-90-overflow"
753999c1 101run_dump_test "emit-relocs-92"
971f1d27
JW
102run_dump_test_lp64 "emit-relocs-257"
103run_dump_test_lp64 "emit-relocs-257-be"
a06ea964
NC
104# 258 is tested in 257
105# 259 is tested in 257
79e74192
RL
106run_dump_test_lp64 "emit-relocs-258-dyn-bad"
107run_dump_test_lp64 "emit-relocs-259-dyn-bad"
971f1d27
JW
108run_dump_test_lp64 "emit-relocs-260"
109run_dump_test_lp64 "emit-relocs-260-be"
a06ea964 110# 261 is tested by 260
971f1d27
JW
111run_dump_test_lp64 "emit-relocs-262"
112run_dump_test_lp64 "emit-relocs-263"
113run_dump_test_lp64 "emit-relocs-264"
114run_dump_test_lp64 "emit-relocs-264-bad"
115run_dump_test_lp64 "emit-relocs-265"
116run_dump_test_lp64 "emit-relocs-266"
117run_dump_test_lp64 "emit-relocs-266-bad"
118run_dump_test_lp64 "emit-relocs-267"
119run_dump_test_lp64 "emit-relocs-268"
120run_dump_test_lp64 "emit-relocs-268-bad"
121run_dump_test_lp64 "emit-relocs-269"
122run_dump_test_lp64 "emit-relocs-269-bad"
123run_dump_test_lp64 "emit-relocs-270"
124run_dump_test_lp64 "emit-relocs-270-bad"
125run_dump_test_lp64 "emit-relocs-270-overflow"
126run_dump_test_lp64 "emit-relocs-271"
127run_dump_test_lp64 "emit-relocs-271-overflow"
128run_dump_test_lp64 "emit-relocs-272"
129run_dump_test_lp64 "emit-relocs-272-overflow"
130run_dump_test_lp64 "emit-relocs-273"
131run_dump_test_lp64 "emit-relocs-274"
132run_dump_test_lp64 "emit-relocs-275"
133run_dump_test_lp64 "emit-relocs-276"
134run_dump_test_lp64 "emit-relocs-277"
135run_dump_test_lp64 "emit-relocs-278"
136run_dump_test_lp64 "emit-relocs-279"
137run_dump_test_lp64 "emit-relocs-279-bad"
138run_dump_test_lp64 "emit-relocs-280"
a06ea964 139# 281 is unused
971f1d27
JW
140run_dump_test_lp64 "emit-relocs-282"
141run_dump_test_lp64 "emit-relocs-283"
142run_dump_test_lp64 "emit-relocs-284"
143run_dump_test_lp64 "emit-relocs-285"
144run_dump_test_lp64 "emit-relocs-286"
145run_dump_test_lp64 "emit-relocs-286-bad"
1daf502a
RL
146run_dump_test_lp64 "emit-relocs-287"
147run_dump_test_lp64 "emit-relocs-287-overflow"
148run_dump_test_lp64 "emit-relocs-288"
149run_dump_test_lp64 "emit-relocs-289"
150run_dump_test_lp64 "emit-relocs-289-overflow"
151run_dump_test_lp64 "emit-relocs-290"
152run_dump_test_lp64 "emit-relocs-291"
153run_dump_test_lp64 "emit-relocs-291-overflow"
154run_dump_test_lp64 "emit-relocs-292"
155run_dump_test_lp64 "emit-relocs-293"
156# 294-298 are not done yet
971f1d27 157run_dump_test_lp64 "emit-relocs-299"
dc8008f5 158# 300 is not done yet
971f1d27
JW
159run_dump_test_lp64 "emit-relocs-301"
160run_dump_test_lp64 "emit-relocs-301-be"
161run_dump_test_lp64 "emit-relocs-302"
162run_dump_test_lp64 "emit-relocs-302-be"
74a1bfe1 163# 303-308 are not done yet
971f1d27
JW
164run_dump_test_lp64 "emit-relocs-309-up"
165run_dump_test_lp64 "emit-relocs-309-low"
166run_dump_test_lp64 "emit-relocs-309-up-bad"
167run_dump_test_lp64 "emit-relocs-309-low-bad"
168run_dump_test_lp64 "emit-relocs-310"
169run_dump_test_lp64 "emit-relocs-310-be"
170run_dump_test_lp64 "emit-relocs-311"
171run_dump_test_lp64 "emit-relocs-312"
172run_dump_test_lp64 "emit-relocs-313"
173run_dump_test_lp64 "emit-relocs-515"
174run_dump_test_lp64 "emit-relocs-515-be"
175run_dump_test_lp64 "emit-relocs-516"
176run_dump_test_lp64 "emit-relocs-516-be"
177run_dump_test_lp64 "emit-relocs-523"
178run_dump_test_lp64 "emit-relocs-524"
179run_dump_test_lp64 "emit-relocs-525"
180run_dump_test_lp64 "emit-relocs-526"
181run_dump_test_lp64 "emit-relocs-526-overflow"
182run_dump_test_lp64 "emit-relocs-527"
183run_dump_test_lp64 "emit-relocs-528"
184run_dump_test_lp64 "emit-relocs-528-overflow"
185run_dump_test_lp64 "emit-relocs-529"
186run_dump_test_lp64 "emit-relocs-529-overflow"
187run_dump_test_lp64 "emit-relocs-530"
188run_dump_test_lp64 "emit-relocs-531"
189run_dump_test_lp64 "emit-relocs-531-overflow"
190run_dump_test_lp64 "emit-relocs-532"
191run_dump_test_lp64 "emit-relocs-533"
192run_dump_test_lp64 "emit-relocs-533-overflow"
193run_dump_test_lp64 "emit-relocs-534"
194run_dump_test_lp64 "emit-relocs-535"
195run_dump_test_lp64 "emit-relocs-535-overflow"
196run_dump_test_lp64 "emit-relocs-536"
197run_dump_test_lp64 "emit-relocs-537"
198run_dump_test_lp64 "emit-relocs-537-overflow"
199run_dump_test_lp64 "emit-relocs-538"
a06ea964 200
027e9c75
NC
201run_dump_test "reloc-overflow-bad"
202
2e0488d3 203# test addend correctness when --emit-relocs specified for non-relocatable obj.
971f1d27 204run_dump_test_lp64 "emit-relocs-local-addend"
2e0488d3 205# test addend correctness when -r specified.
971f1d27 206run_dump_test_lp64 "local-addend-r"
a06ea964 207
dcbd20eb 208# test error handling on pcrel relocation for shared libraries.
971f1d27 209run_dump_test_lp64 "pcrel_pic_undefined"
d68f1976 210run_dump_test_lp64 "pcrel_pic_defined"
dcbd20eb 211
a06ea964
NC
212run_dump_test "limit-b"
213run_dump_test "limit-bl"
a06ea964 214run_dump_test "farcall-back"
f678ded7
JW
215run_dump_test "farcall-b-defsym"
216run_dump_test "farcall-bl-defsym"
07f9ddfe
JW
217run_dump_test "farcall-b-gsym"
218run_dump_test "farcall-b-plt"
219run_dump_test "farcall-bl-plt"
a06ea964
NC
220run_dump_test "farcall-bl"
221run_dump_test "farcall-b"
222run_dump_test "farcall-b-none-function"
223run_dump_test "farcall-bl-none-function"
2f340668
JW
224run_dump_test "farcall-b-section"
225run_dump_test "farcall-bl-section"
a06ea964
NC
226
227run_dump_test "tls-relax-all"
2d0ca824 228run_dump_test "tls-relax-all-ilp32"
a06ea964 229run_dump_test "tls-relax-gd-le"
2d0ca824 230run_dump_test "tls-relax-gd-le-ilp32"
a06ea964 231run_dump_test "tls-relax-gdesc-le"
2d0ca824 232run_dump_test "tls-relax-gdesc-le-ilp32"
a06ea964 233run_dump_test "tls-relax-gd-ie"
2d0ca824 234run_dump_test "tls-relax-gd-ie-ilp32"
971f1d27
JW
235run_dump_test_lp64 "tls-relax-large-gd-ie"
236run_dump_test_lp64 "tls-relax-large-gd-ie-be"
237run_dump_test_lp64 "tls-relax-large-gd-le"
238run_dump_test_lp64 "tls-relax-large-gd-le-be"
239run_dump_test_lp64 "tls-relax-large-desc-ie"
240run_dump_test_lp64 "tls-relax-large-desc-ie-be"
241run_dump_test_lp64 "tls-relax-large-desc-le"
242run_dump_test_lp64 "tls-relax-large-desc-le-be"
a06ea964
NC
243run_dump_test "tls-relax-gdesc-ie"
244run_dump_test "tls-relax-ie-le"
2d0ca824 245run_dump_test "tls-relax-ie-le-ilp32"
259364ad 246run_dump_test "tls-relax-ld-le-small"
c1fc2d7e 247run_dump_test "tls-relax-ld-le-small-ilp32"
259364ad 248run_dump_test "tls-relax-ld-le-tiny"
c1fc2d7e 249run_dump_test "tls-relax-ld-le-tiny-ilp32"
a06ea964 250run_dump_test "tls-desc-ie"
2d0ca824 251run_dump_test "tls-desc-ie-ilp32"
a06ea964
NC
252run_dump_test "tls-relax-gdesc-ie-2"
253run_dump_test "tls-relax-gdesc-le-2"
2d0ca824 254run_dump_test "tls-relax-gdesc-le-2-ilp32"
a06ea964 255run_dump_test "tls-relax-ie-le-2"
2d0ca824 256run_dump_test "tls-relax-ie-le-2-ilp32"
a06ea964 257run_dump_test "tls-relax-ie-le-3"
2d0ca824 258run_dump_test "tls-relax-ie-le-3-ilp32"
b480a481
MS
259run_dump_test "tls-tiny-gd"
260run_dump_test "tls-tiny-gd-ie"
2d0ca824 261run_dump_test "tls-tiny-gd-ie-ilp32"
b480a481 262run_dump_test "tls-tiny-gd-le"
2d0ca824 263run_dump_test "tls-tiny-gd-le-ilp32"
60d1b0d6
MS
264run_dump_test "tls-tiny-desc"
265run_dump_test "tls-tiny-desc-ie"
2d0ca824 266run_dump_test "tls-tiny-desc-ie-ilp32"
60d1b0d6 267run_dump_test "tls-tiny-desc-le"
2d0ca824 268run_dump_test "tls-tiny-desc-le-ilp32"
b1089987 269run_dump_test "tls-tiny-ie"
971f1d27
JW
270run_dump_test_lp64 "tls-large-ie"
271run_dump_test_lp64 "tls-large-ie-be"
272run_dump_test_lp64 "tls-large-desc"
273run_dump_test_lp64 "tls-large-desc-be"
77a69ff8 274run_dump_test "tls-tiny-ld"
f69e4920 275run_dump_test "tls-small-ld"
971f1d27 276run_dump_test_lp64 "tlsle"
bb3f9ed8 277run_dump_test "tlsle-symbol-offset"
cb8af559
NC
278run_dump_test "gc-got-relocs"
279run_dump_test "gc-tls-relocs"
971f1d27
JW
280run_dump_test_lp64 "gc-plt-relocs"
281run_dump_test_lp64 "gc-relocs-257-dyn"
282run_dump_test_lp64 "gc-relocs-257"
18f822a0 283run_dump_test "implicit_got_section_1"
bab91cce 284run_dump_test "pr17415"
971f1d27 285run_dump_test_lp64 "tprel_g2_overflow"
36e6c140 286run_dump_test "tprel_add_lo12_overflow"
32f573bc 287run_dump_test "protected-data"
279b2f94 288run_dump_test_lp64 "pr22764"
0c1ded8d 289run_dump_test_lp64 "pr20402"
1419bbe5
WN
290
291# ifunc tests
292run_dump_test "ifunc-1"
293run_dump_test "ifunc-1-local"
294run_dump_test "ifunc-2"
295run_dump_test "ifunc-2-local"
296run_dump_test "ifunc-3a"
297run_dump_test "ifunc-3b"
298run_dump_test "ifunc-4"
299run_dump_test "ifunc-4a"
300run_dump_test "ifunc-5a"
301run_dump_test "ifunc-5b"
302run_dump_test "ifunc-5a-local"
303run_dump_test "ifunc-5b-local"
304run_dump_test "ifunc-5r-local"
305run_dump_test "ifunc-6a"
306run_dump_test "ifunc-6b"
307run_dump_test "ifunc-7a"
308run_dump_test "ifunc-7b"
309run_dump_test "ifunc-7c"
310run_dump_test "ifunc-8"
971f1d27
JW
311run_dump_test_lp64 "ifunc-9"
312run_dump_test_lp64 "ifunc-10"
313run_dump_test_lp64 "ifunc-11"
314run_dump_test_lp64 "ifunc-12"
315run_dump_test_lp64 "ifunc-13"
1419bbe5
WN
316run_dump_test "ifunc-14a"
317run_dump_test "ifunc-14b"
318run_dump_test "ifunc-14c"
319run_dump_test "ifunc-14d"
320run_dump_test "ifunc-14e"
321run_dump_test "ifunc-14f"
322run_dump_test "ifunc-15"
323run_dump_test "ifunc-16"
324run_dump_test "ifunc-17a"
325run_dump_test "ifunc-17b"
971f1d27
JW
326run_dump_test_lp64 "ifunc-18a"
327run_dump_test_lp64 "ifunc-18b"
328run_dump_test_lp64 "ifunc-19a"
329run_dump_test_lp64 "ifunc-19b"
330run_dump_test_lp64 "ifunc-20"
331run_dump_test_lp64 "ifunc-21"
332run_dump_test_lp64 "ifunc-22"
c955de36
WN
333
334run_dump_test "relasz"
971f1d27 335run_dump_test_lp64 "relocs-1027-symbolic-func"
614b09ce 336
971f1d27 337run_dump_test_lp64 "dt_textrel"
c2170589 338
73524045
RL
339run_dump_test "plt_mapping_symbol"
340
971f1d27
JW
341run_dump_test_lp64 "rela-abs-relative"
342run_dump_test_lp64 "rela-abs-relative-be"
343run_dump_test_lp64 "rela-abs-relative-opt"
1f56df9d 344
971f1d27 345run_dump_test_lp64 "pie-bind-locally"
ac33b731 346
614b09ce
JW
347set 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
363run_ld_link_tests $aarch64elflinktests
This page took 0.279768 seconds and 4 git commands to generate.