annotate lld/test/ELF/mips-plt-copy.s @ 192:d7606dcf6fce

Added tag llvm10 for changeset 0572611fdcc8
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 14 Dec 2020 18:01:34 +0900
parents 1d019706d866
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 # REQUIRES: mips
anatofuz
parents:
diff changeset
2 # Check creating of R_MIPS_COPY and R_MIPS_JUMP_SLOT dynamic relocations
anatofuz
parents:
diff changeset
3 # and corresponding PLT entries.
anatofuz
parents:
diff changeset
4
anatofuz
parents:
diff changeset
5 # RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux %s -o %t.o
anatofuz
parents:
diff changeset
6 # RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux \
anatofuz
parents:
diff changeset
7 # RUN: %S/Inputs/mips-dynamic.s -o %t.so.o
anatofuz
parents:
diff changeset
8 # RUN: ld.lld %t.so.o -shared -soname=t.so -o %t.so
anatofuz
parents:
diff changeset
9 # RUN: ld.lld %t.o %t.so -o %t.exe
anatofuz
parents:
diff changeset
10 # RUN: llvm-readobj -r -A %t.exe | FileCheck %s
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 # CHECK: Relocations [
anatofuz
parents:
diff changeset
13 # CHECK-NEXT: Section ({{.*}}) .rel.dyn {
anatofuz
parents:
diff changeset
14 # CHECK-DAG: 0x{{[0-9A-F]+}} R_MIPS_COPY data0 0x0
anatofuz
parents:
diff changeset
15 # CHECK-DAG: 0x{{[0-9A-F]+}} R_MIPS_COPY data1 0x0
anatofuz
parents:
diff changeset
16 # CHECK-NEXT: }
anatofuz
parents:
diff changeset
17 # CHECK-NEXT: Section ({{.*}}) .rel.plt {
anatofuz
parents:
diff changeset
18 # CHECK-DAG: 0x{{[0-9A-F]+}} R_MIPS_JUMP_SLOT foo0 0x0
anatofuz
parents:
diff changeset
19 # CHECK-DAG: 0x{{[0-9A-F]+}} R_MIPS_JUMP_SLOT foo1 0x0
anatofuz
parents:
diff changeset
20 # CHECK-NEXT: }
anatofuz
parents:
diff changeset
21 # CHECK-NEXT: ]
anatofuz
parents:
diff changeset
22
anatofuz
parents:
diff changeset
23 # CHECK: Primary GOT {
anatofuz
parents:
diff changeset
24 # CHECK: Local entries [
anatofuz
parents:
diff changeset
25 # CHECK-NEXT: ]
anatofuz
parents:
diff changeset
26 # CHECK-NEXT: Global entries [
anatofuz
parents:
diff changeset
27 # CHECK-NEXT: ]
anatofuz
parents:
diff changeset
28 # CHECK-NEXT: Number of TLS and multi-GOT entries: 0
anatofuz
parents:
diff changeset
29 # CHECK-NEXT: }
anatofuz
parents:
diff changeset
30
anatofuz
parents:
diff changeset
31 # CHECK: PLT GOT {
anatofuz
parents:
diff changeset
32 # CHECK: Entries [
anatofuz
parents:
diff changeset
33 # CHECK-NEXT: Entry {
anatofuz
parents:
diff changeset
34 # CHECK-NEXT: Address: 0x{{[0-9A-F]+}}
anatofuz
parents:
diff changeset
35 # CHECK-NEXT: Initial: 0x{{[0-9A-F]+}}
anatofuz
parents:
diff changeset
36 # CHECK-NEXT: Value: 0x{{[0-9A-F]+}}
anatofuz
parents:
diff changeset
37 # CHECK-NEXT: Type: Function
anatofuz
parents:
diff changeset
38 # CHECK-NEXT: Section: Undefined
anatofuz
parents:
diff changeset
39 # CHECK-NEXT: Name: foo0
anatofuz
parents:
diff changeset
40 # CHECK-NEXT: }
anatofuz
parents:
diff changeset
41 # CHECK-NEXT: Entry {
anatofuz
parents:
diff changeset
42 # CHECK-NEXT: Address: 0x{{[0-9A-F]+}}
anatofuz
parents:
diff changeset
43 # CHECK-NEXT: Initial: 0x{{[0-9A-F]+}}
anatofuz
parents:
diff changeset
44 # CHECK-NEXT: Value: 0x{{[0-9A-F]+}}
anatofuz
parents:
diff changeset
45 # CHECK-NEXT: Type: Function
anatofuz
parents:
diff changeset
46 # CHECK-NEXT: Section: Undefined
anatofuz
parents:
diff changeset
47 # CHECK-NEXT: Name: foo1
anatofuz
parents:
diff changeset
48 # CHECK-NEXT: }
anatofuz
parents:
diff changeset
49 # CHECK-NEXT: ]
anatofuz
parents:
diff changeset
50 # CHECK-NEXT: }
anatofuz
parents:
diff changeset
51
anatofuz
parents:
diff changeset
52 .text
anatofuz
parents:
diff changeset
53 .globl __start
anatofuz
parents:
diff changeset
54 __start:
anatofuz
parents:
diff changeset
55 lui $t0,%hi(foo0) # R_MIPS_HI16 requires JUMP_SLOT/PLT entry
anatofuz
parents:
diff changeset
56 # for DSO defined func.
anatofuz
parents:
diff changeset
57 addi $t0,$t0,%lo(foo0)
anatofuz
parents:
diff changeset
58 lui $t0,%hi(bar) # Does not require PLT for locally defined func.
anatofuz
parents:
diff changeset
59 addi $t0,$t0,%lo(bar)
anatofuz
parents:
diff changeset
60 lui $t0,%hi(loc) # Does not require PLT for local func.
anatofuz
parents:
diff changeset
61 addi $t0,$t0,%lo(loc)
anatofuz
parents:
diff changeset
62
anatofuz
parents:
diff changeset
63 lui $t0,%hi(data0) # R_MIPS_HI16 requires COPY rel for DSO defined data.
anatofuz
parents:
diff changeset
64 addi $t0,$t0,%lo(data0)
anatofuz
parents:
diff changeset
65 lui $t0,%hi(gd) # Does not require COPY rel for locally defined data.
anatofuz
parents:
diff changeset
66 addi $t0,$t0,%lo(gd)
anatofuz
parents:
diff changeset
67 lui $t0,%hi(ld) # Does not require COPY rel for local data.
anatofuz
parents:
diff changeset
68 addi $t0,$t0,%lo(ld)
anatofuz
parents:
diff changeset
69
anatofuz
parents:
diff changeset
70 .globl bar
anatofuz
parents:
diff changeset
71 .type bar, @function
anatofuz
parents:
diff changeset
72 bar:
anatofuz
parents:
diff changeset
73 nop
anatofuz
parents:
diff changeset
74 loc:
anatofuz
parents:
diff changeset
75 nop
anatofuz
parents:
diff changeset
76
anatofuz
parents:
diff changeset
77 .rodata
anatofuz
parents:
diff changeset
78 .globl gd
anatofuz
parents:
diff changeset
79 gd:
anatofuz
parents:
diff changeset
80 .word 0
anatofuz
parents:
diff changeset
81 ld:
anatofuz
parents:
diff changeset
82 .word data1+8 # R_MIPS_32 requires REL32 dnamic relocation
anatofuz
parents:
diff changeset
83 # for DSO defined data. For now we generate COPY one.
anatofuz
parents:
diff changeset
84 .word foo1+8 # R_MIPS_32 requires PLT entry for DSO defined func.