1# Expect script for various AARCH64 ELF tests. 2# Copyright (C) 2009-2017 Free Software Foundation, Inc. 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: 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 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 { 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"} 44} 45 46proc aarch64_choose_ilp32_emul {} { 47 if [istarget *linux*] then { 48 if [istarget aarch64_be-*] { 49 return "aarch64linux32b" 50 } 51 return "aarch64linux32" 52 } 53 if [istarget aarch64_be-*] { 54 return "aarch64elf32b" 55 } 56 return "aarch64elf32" 57} 58 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 85run_ld_link_tests $aarch64elftests 86run_ld_link_tests eh-frame-merge-lp64 87 88run_dump_test "erratum843419" 89 90# Relocation Tests 91run_dump_test_lp64 "weak-undefined" 92run_dump_test "emit-relocs-28" 93run_dump_test "emit-relocs-86" 94run_dump_test "emit-relocs-86-overflow" 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" 101run_dump_test "emit-relocs-92" 102run_dump_test_lp64 "emit-relocs-257" 103run_dump_test_lp64 "emit-relocs-257-be" 104# 258 is tested in 257 105# 259 is tested in 257 106run_dump_test_lp64 "emit-relocs-260" 107run_dump_test_lp64 "emit-relocs-260-be" 108# 261 is tested by 260 109run_dump_test_lp64 "emit-relocs-262" 110run_dump_test_lp64 "emit-relocs-263" 111run_dump_test_lp64 "emit-relocs-264" 112run_dump_test_lp64 "emit-relocs-264-bad" 113run_dump_test_lp64 "emit-relocs-265" 114run_dump_test_lp64 "emit-relocs-266" 115run_dump_test_lp64 "emit-relocs-266-bad" 116run_dump_test_lp64 "emit-relocs-267" 117run_dump_test_lp64 "emit-relocs-268" 118run_dump_test_lp64 "emit-relocs-268-bad" 119run_dump_test_lp64 "emit-relocs-269" 120run_dump_test_lp64 "emit-relocs-269-bad" 121run_dump_test_lp64 "emit-relocs-270" 122run_dump_test_lp64 "emit-relocs-270-bad" 123run_dump_test_lp64 "emit-relocs-270-overflow" 124run_dump_test_lp64 "emit-relocs-271" 125run_dump_test_lp64 "emit-relocs-271-overflow" 126run_dump_test_lp64 "emit-relocs-272" 127run_dump_test_lp64 "emit-relocs-272-overflow" 128run_dump_test_lp64 "emit-relocs-273" 129run_dump_test_lp64 "emit-relocs-274" 130run_dump_test_lp64 "emit-relocs-275" 131run_dump_test_lp64 "emit-relocs-276" 132run_dump_test_lp64 "emit-relocs-277" 133run_dump_test_lp64 "emit-relocs-278" 134run_dump_test_lp64 "emit-relocs-279" 135run_dump_test_lp64 "emit-relocs-279-bad" 136run_dump_test_lp64 "emit-relocs-280" 137# 281 is unused 138run_dump_test_lp64 "emit-relocs-282" 139run_dump_test_lp64 "emit-relocs-283" 140run_dump_test_lp64 "emit-relocs-284" 141run_dump_test_lp64 "emit-relocs-285" 142run_dump_test_lp64 "emit-relocs-286" 143run_dump_test_lp64 "emit-relocs-286-bad" 144# 287-298 are not done yet 145run_dump_test_lp64 "emit-relocs-299" 146# 300 is not done yet 147run_dump_test_lp64 "emit-relocs-301" 148run_dump_test_lp64 "emit-relocs-301-be" 149run_dump_test_lp64 "emit-relocs-302" 150run_dump_test_lp64 "emit-relocs-302-be" 151# 303-308 are not done yet 152run_dump_test_lp64 "emit-relocs-309-up" 153run_dump_test_lp64 "emit-relocs-309-low" 154run_dump_test_lp64 "emit-relocs-309-up-bad" 155run_dump_test_lp64 "emit-relocs-309-low-bad" 156run_dump_test_lp64 "emit-relocs-310" 157run_dump_test_lp64 "emit-relocs-310-be" 158run_dump_test_lp64 "emit-relocs-311" 159run_dump_test_lp64 "emit-relocs-312" 160run_dump_test_lp64 "emit-relocs-313" 161run_dump_test_lp64 "emit-relocs-515" 162run_dump_test_lp64 "emit-relocs-515-be" 163run_dump_test_lp64 "emit-relocs-516" 164run_dump_test_lp64 "emit-relocs-516-be" 165run_dump_test_lp64 "emit-relocs-523" 166run_dump_test_lp64 "emit-relocs-524" 167run_dump_test_lp64 "emit-relocs-525" 168run_dump_test_lp64 "emit-relocs-526" 169run_dump_test_lp64 "emit-relocs-526-overflow" 170run_dump_test_lp64 "emit-relocs-527" 171run_dump_test_lp64 "emit-relocs-528" 172run_dump_test_lp64 "emit-relocs-528-overflow" 173run_dump_test_lp64 "emit-relocs-529" 174run_dump_test_lp64 "emit-relocs-529-overflow" 175run_dump_test_lp64 "emit-relocs-530" 176run_dump_test_lp64 "emit-relocs-531" 177run_dump_test_lp64 "emit-relocs-531-overflow" 178run_dump_test_lp64 "emit-relocs-532" 179run_dump_test_lp64 "emit-relocs-533" 180run_dump_test_lp64 "emit-relocs-533-overflow" 181run_dump_test_lp64 "emit-relocs-534" 182run_dump_test_lp64 "emit-relocs-535" 183run_dump_test_lp64 "emit-relocs-535-overflow" 184run_dump_test_lp64 "emit-relocs-536" 185run_dump_test_lp64 "emit-relocs-537" 186run_dump_test_lp64 "emit-relocs-537-overflow" 187run_dump_test_lp64 "emit-relocs-538" 188 189run_dump_test "reloc-overflow-bad" 190 191# test addend correctness when --emit-relocs specified for non-relocatable obj. 192run_dump_test_lp64 "emit-relocs-local-addend" 193# test addend correctness when -r specified. 194run_dump_test_lp64 "local-addend-r" 195 196# test error handling on pcrel relocation for shared libraries. 197run_dump_test_lp64 "pcrel_pic_undefined" 198run_dump_test_lp64 "pcrel_pic_defined_local" 199 200run_dump_test "limit-b" 201run_dump_test "limit-bl" 202run_dump_test "farcall-back" 203run_dump_test "farcall-b-defsym" 204run_dump_test "farcall-bl-defsym" 205run_dump_test "farcall-b-gsym" 206run_dump_test "farcall-b-plt" 207run_dump_test "farcall-bl-plt" 208run_dump_test "farcall-bl" 209run_dump_test "farcall-b" 210run_dump_test "farcall-b-none-function" 211run_dump_test "farcall-bl-none-function" 212run_dump_test "farcall-b-section" 213run_dump_test "farcall-bl-section" 214 215run_dump_test "tls-relax-all" 216run_dump_test "tls-relax-gd-le" 217run_dump_test "tls-relax-gdesc-le" 218run_dump_test "tls-relax-gd-ie-ilp32" 219run_dump_test "tls-relax-gd-ie" 220run_dump_test_lp64 "tls-relax-large-gd-ie" 221run_dump_test_lp64 "tls-relax-large-gd-ie-be" 222run_dump_test_lp64 "tls-relax-large-gd-le" 223run_dump_test_lp64 "tls-relax-large-gd-le-be" 224run_dump_test_lp64 "tls-relax-large-desc-ie" 225run_dump_test_lp64 "tls-relax-large-desc-ie-be" 226run_dump_test_lp64 "tls-relax-large-desc-le" 227run_dump_test_lp64 "tls-relax-large-desc-le-be" 228run_dump_test "tls-relax-gdesc-ie" 229run_dump_test "tls-relax-ie-le" 230run_dump_test "tls-relax-ld-le-small" 231run_dump_test "tls-relax-ld-le-small-ilp32" 232run_dump_test "tls-relax-ld-le-tiny" 233run_dump_test "tls-relax-ld-le-tiny-ilp32" 234run_dump_test "tls-desc-ie" 235run_dump_test "tls-relax-gdesc-ie-2" 236run_dump_test "tls-relax-gdesc-le-2" 237run_dump_test "tls-relax-ie-le-2" 238run_dump_test "tls-relax-ie-le-3" 239run_dump_test "tls-tiny-gd" 240run_dump_test "tls-tiny-gd-ie" 241run_dump_test "tls-tiny-gd-le" 242run_dump_test "tls-tiny-desc" 243run_dump_test "tls-tiny-desc-ie" 244run_dump_test "tls-tiny-desc-le" 245run_dump_test "tls-tiny-ie" 246run_dump_test_lp64 "tls-large-ie" 247run_dump_test_lp64 "tls-large-ie-be" 248run_dump_test_lp64 "tls-large-desc" 249run_dump_test_lp64 "tls-large-desc-be" 250run_dump_test "tls-tiny-ld" 251run_dump_test "tls-small-ld" 252run_dump_test_lp64 "tlsle" 253run_dump_test "tlsle-symbol-offset" 254run_dump_test "gc-got-relocs" 255run_dump_test "gc-tls-relocs" 256run_dump_test_lp64 "gc-plt-relocs" 257run_dump_test_lp64 "gc-relocs-257-dyn" 258run_dump_test_lp64 "gc-relocs-257" 259run_dump_test "implicit_got_section_1" 260run_dump_test "pr17415" 261run_dump_test_lp64 "tprel_g2_overflow" 262run_dump_test "tprel_add_lo12_overflow" 263run_dump_test "protected-data" 264 265# ifunc tests 266run_dump_test "ifunc-1" 267run_dump_test "ifunc-1-local" 268run_dump_test "ifunc-2" 269run_dump_test "ifunc-2-local" 270run_dump_test "ifunc-3a" 271run_dump_test "ifunc-3b" 272run_dump_test "ifunc-4" 273run_dump_test "ifunc-4a" 274run_dump_test "ifunc-5a" 275run_dump_test "ifunc-5b" 276run_dump_test "ifunc-5a-local" 277run_dump_test "ifunc-5b-local" 278run_dump_test "ifunc-5r-local" 279run_dump_test "ifunc-6a" 280run_dump_test "ifunc-6b" 281run_dump_test "ifunc-7a" 282run_dump_test "ifunc-7b" 283run_dump_test "ifunc-7c" 284run_dump_test "ifunc-8" 285run_dump_test_lp64 "ifunc-9" 286run_dump_test_lp64 "ifunc-10" 287run_dump_test_lp64 "ifunc-11" 288run_dump_test_lp64 "ifunc-12" 289run_dump_test_lp64 "ifunc-13" 290run_dump_test "ifunc-14a" 291run_dump_test "ifunc-14b" 292run_dump_test "ifunc-14c" 293run_dump_test "ifunc-14d" 294run_dump_test "ifunc-14e" 295run_dump_test "ifunc-14f" 296run_dump_test "ifunc-15" 297run_dump_test "ifunc-16" 298run_dump_test "ifunc-17a" 299run_dump_test "ifunc-17b" 300run_dump_test_lp64 "ifunc-18a" 301run_dump_test_lp64 "ifunc-18b" 302run_dump_test_lp64 "ifunc-19a" 303run_dump_test_lp64 "ifunc-19b" 304run_dump_test_lp64 "ifunc-20" 305run_dump_test_lp64 "ifunc-21" 306run_dump_test_lp64 "ifunc-22" 307 308run_dump_test "relasz" 309run_dump_test_lp64 "relocs-1027-symbolic-func" 310 311run_dump_test_lp64 "dt_textrel" 312 313run_dump_test "plt_mapping_symbol" 314 315run_dump_test_lp64 "rela-abs-relative" 316run_dump_test_lp64 "rela-abs-relative-be" 317run_dump_test_lp64 "rela-abs-relative-opt" 318 319run_dump_test_lp64 "pie-bind-locally" 320 321set aarch64elflinktests { 322 {"ld-aarch64/so with global symbol" "-shared" "" "" {copy-reloc-so.s} 323 {} "copy-reloc-so.so"} 324 {"ld-aarch64/exe with copy relocation" "-e0 tmpdir/copy-reloc-so.so" "" "" 325 {copy-reloc-exe.s} {{objdump -R copy-reloc.d}} "copy-reloc"} 326} 327 328run_ld_link_tests $aarch64elflinktests 329