RISC-V: Fix lui relaxation issue with code at address 0.
[external/binutils.git] / ld / testsuite / ld-riscv-elf / ld-riscv-elf.exp
1 # Expect script for RISC-V ELF linker tests
2 #   Copyright (C) 2017-2019 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
22 if [istarget "riscv*-*-*"] {
23     run_dump_test "c-lui"
24     run_dump_test "c-lui-2"
25     run_dump_test "disas-jalr"
26     run_dump_test "pcrel-lo-addend"
27     run_dump_test "pcrel-lo-addend-2"
28     run_dump_test "attr-merge-arch-01"
29     run_dump_test "attr-merge-arch-02"
30     run_dump_test "attr-merge-arch-03"
31     run_dump_test "attr-merge-strict-align-01"
32     run_dump_test "attr-merge-strict-align-02"
33     run_dump_test "attr-merge-strict-align-03"
34     run_dump_test "attr-merge-strict-align-04"
35     run_dump_test "attr-merge-strict-align-05"
36     run_dump_test "attr-merge-stack-align"
37     run_dump_test "attr-merge-priv-spec"
38     run_dump_test "attr-merge-arch-failed-01"
39     run_dump_test "attr-merge-stack-align-failed"
40     run_ld_link_tests {
41         { "Weak reference 32" "-T weakref.ld -melf32lriscv" ""
42             "-march=rv32i -mabi=ilp32" {weakref32.s}
43             {{objdump -d weakref32.d}} "weakref32"}
44         { "Weak reference 64" "-T weakref.ld -melf64lriscv" ""
45             "-march=rv64i -mabi=lp64" {weakref64.s}
46             {{objdump -d weakref64.d}} "weakref64"}
47     }
48
49     # The following tests require shared library support.
50     if ![check_shared_lib_support] {
51         return
52     }
53
54     set abis { rv32gc ilp32 elf32lriscv rv64gc lp64 elf64lriscv }
55     foreach { arch abi emul } $abis {
56         # This checks whether our linker scripts handle __global_pointer$
57         # correctly.  It should be defined in executables and PIE, but not
58         # in shared libraries.
59         set suff64 [string map {ilp32 "" lp64 -64} $abi]
60         run_ld_link_tests [list \
61                                [list "gp test ($abi shared library)" \
62                                     "-m$emul -shared" "" \
63                                     "-march=$arch -mabi=$abi -fpic" \
64                                     { gp-test.s } \
65                                     [list "readelf --syms gp-test-lib.sd"] \
66                                     "gp-test-lib-${abi}.so"] \
67                                [list "gp test ($abi executable)" \
68                                     "-m$emul" "" \
69                                     "-march=$arch -mabi=$abi" \
70                                     { gp-test.s } \
71                                     [list "readelf --syms gp-test.sd"] \
72                                     "gp-test-${abi}"]]
73     }
74 }