annotate lld/test/ELF/gnu-ifunc.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 0572611fdcc8
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // REQUIRES: x86
anatofuz
parents:
diff changeset
2 // RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
anatofuz
parents:
diff changeset
3 // RUN: ld.lld -static %t.o -o %tout
anatofuz
parents:
diff changeset
4 // RUN: llvm-objdump -d %tout | FileCheck %s --check-prefix=DISASM
anatofuz
parents:
diff changeset
5 // RUN: llvm-readobj -r --symbols --sections %tout | FileCheck %s
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 // CHECK: Sections [
anatofuz
parents:
diff changeset
8 // CHECK: Section {
anatofuz
parents:
diff changeset
9 // CHECK: Index: 1
anatofuz
parents:
diff changeset
10 // CHECK-NEXT: Name: .rela.dyn
anatofuz
parents:
diff changeset
11 // CHECK-NEXT: Type: SHT_RELA
anatofuz
parents:
diff changeset
12 // CHECK-NEXT: Flags [
anatofuz
parents:
diff changeset
13 // CHECK-NEXT: SHF_ALLOC
anatofuz
parents:
diff changeset
14 // CHECK-NEXT: ]
anatofuz
parents:
diff changeset
15 // CHECK-NEXT: Address: [[RELA:.*]]
anatofuz
parents:
diff changeset
16 // CHECK-NEXT: Offset: 0x158
anatofuz
parents:
diff changeset
17 // CHECK-NEXT: Size: 48
anatofuz
parents:
diff changeset
18 // CHECK-NEXT: Link: 0
anatofuz
parents:
diff changeset
19 // CHECK-NEXT: Info: [[GOTPLT:.*]]
anatofuz
parents:
diff changeset
20 // CHECK-NEXT: AddressAlignment: 8
anatofuz
parents:
diff changeset
21 // CHECK-NEXT: EntrySize: 24
anatofuz
parents:
diff changeset
22 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
23 // CHECK: Index: [[GOTPLT]]
anatofuz
parents:
diff changeset
24 // CHECK-NEXT: Name: .got.plt
anatofuz
parents:
diff changeset
25 // CHECK: Relocations [
anatofuz
parents:
diff changeset
26 // CHECK-NEXT: Section ({{.*}}) .rela.dyn {
anatofuz
parents:
diff changeset
27 // CHECK-NEXT: 0x2021D0 R_X86_64_IRELATIVE
anatofuz
parents:
diff changeset
28 // CHECK-NEXT: 0x2021D8 R_X86_64_IRELATIVE
anatofuz
parents:
diff changeset
29 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
30 // CHECK-NEXT: ]
anatofuz
parents:
diff changeset
31 // CHECK: Symbols [
anatofuz
parents:
diff changeset
32 // CHECK-NEXT: Symbol {
anatofuz
parents:
diff changeset
33 // CHECK-NEXT: Name:
anatofuz
parents:
diff changeset
34 // CHECK-NEXT: Value: 0x0
anatofuz
parents:
diff changeset
35 // CHECK-NEXT: Size: 0
anatofuz
parents:
diff changeset
36 // CHECK-NEXT: Binding: Local
anatofuz
parents:
diff changeset
37 // CHECK-NEXT: Type: None
anatofuz
parents:
diff changeset
38 // CHECK-NEXT: Other: 0
anatofuz
parents:
diff changeset
39 // CHECK-NEXT: Section: Undefined
anatofuz
parents:
diff changeset
40 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
41 // CHECK-NEXT: Symbol {
anatofuz
parents:
diff changeset
42 // CHECK-NEXT: Name: __rela_iplt_end
anatofuz
parents:
diff changeset
43 // CHECK-NEXT: Value: 0x200188
anatofuz
parents:
diff changeset
44 // CHECK-NEXT: Size: 0
anatofuz
parents:
diff changeset
45 // CHECK-NEXT: Binding: Local
anatofuz
parents:
diff changeset
46 // CHECK-NEXT: Type: None
anatofuz
parents:
diff changeset
47 // CHECK-NEXT: Other [
anatofuz
parents:
diff changeset
48 // CHECK-NEXT: STV_HIDDEN
anatofuz
parents:
diff changeset
49 // CHECK-NEXT: ]
anatofuz
parents:
diff changeset
50 // CHECK-NEXT: Section: .rela.dyn
anatofuz
parents:
diff changeset
51 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
52 // CHECK-NEXT: Symbol {
anatofuz
parents:
diff changeset
53 // CHECK-NEXT: Name: __rela_iplt_start
anatofuz
parents:
diff changeset
54 // CHECK-NEXT: Value: [[RELA]]
anatofuz
parents:
diff changeset
55 // CHECK-NEXT: Size: 0
anatofuz
parents:
diff changeset
56 // CHECK-NEXT: Binding: Local
anatofuz
parents:
diff changeset
57 // CHECK-NEXT: Type: None
anatofuz
parents:
diff changeset
58 // CHECK-NEXT: Other [
anatofuz
parents:
diff changeset
59 // CHECK-NEXT: STV_HIDDEN
anatofuz
parents:
diff changeset
60 // CHECK-NEXT: ]
anatofuz
parents:
diff changeset
61 // CHECK-NEXT: Section: .rela.dyn
anatofuz
parents:
diff changeset
62 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
63 // CHECK-NEXT: Symbol {
anatofuz
parents:
diff changeset
64 // CHECK-NEXT: Name: _start
anatofuz
parents:
diff changeset
65 // CHECK-NEXT: Value: 0x20118A
anatofuz
parents:
diff changeset
66 // CHECK-NEXT: Size: 0
anatofuz
parents:
diff changeset
67 // CHECK-NEXT: Binding: Global
anatofuz
parents:
diff changeset
68 // CHECK-NEXT: Type: None
anatofuz
parents:
diff changeset
69 // CHECK-NEXT: Other: 0
anatofuz
parents:
diff changeset
70 // CHECK-NEXT: Section: .text
anatofuz
parents:
diff changeset
71 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
72 // CHECK-NEXT: Symbol {
anatofuz
parents:
diff changeset
73 // CHECK-NEXT: Name: bar
anatofuz
parents:
diff changeset
74 // CHECK-NEXT: Value: 0x201189
anatofuz
parents:
diff changeset
75 // CHECK-NEXT: Size: 0
anatofuz
parents:
diff changeset
76 // CHECK-NEXT: Binding: Global
anatofuz
parents:
diff changeset
77 // CHECK-NEXT: Type: GNU_IFunc
anatofuz
parents:
diff changeset
78 // CHECK-NEXT: Other: 0
anatofuz
parents:
diff changeset
79 // CHECK-NEXT: Section: .text
anatofuz
parents:
diff changeset
80 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
81 // CHECK-NEXT: Symbol {
anatofuz
parents:
diff changeset
82 // CHECK-NEXT: Name: foo
anatofuz
parents:
diff changeset
83 // CHECK-NEXT: Value: 0x201188
anatofuz
parents:
diff changeset
84 // CHECK-NEXT: Size: 0
anatofuz
parents:
diff changeset
85 // CHECK-NEXT: Binding: Global
anatofuz
parents:
diff changeset
86 // CHECK-NEXT: Type: GNU_IFunc
anatofuz
parents:
diff changeset
87 // CHECK-NEXT: Other: 0
anatofuz
parents:
diff changeset
88 // CHECK-NEXT: Section: .text
anatofuz
parents:
diff changeset
89 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
90 // CHECK-NEXT: ]
anatofuz
parents:
diff changeset
91
anatofuz
parents:
diff changeset
92 // DISASM: Disassembly of section .text:
anatofuz
parents:
diff changeset
93 // DISASM-EMPTY:
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
94 // DISASM-NEXT: <foo>:
150
anatofuz
parents:
diff changeset
95 // DISASM-NEXT: 201188: {{.*}} retq
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
96 // DISASM: <bar>:
150
anatofuz
parents:
diff changeset
97 // DISASM-NEXT: 201189: {{.*}} retq
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
98 // DISASM: <_start>:
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
99 // DISASM-NEXT: 20118a: {{.*}} callq 0x2011b0
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
100 // DISASM-NEXT: 20118f: {{.*}} callq 0x2011c0
150
anatofuz
parents:
diff changeset
101 // DISASM-NEXT: 201194: {{.*}} movl $2097496, %edx
anatofuz
parents:
diff changeset
102 // DISASM-NEXT: 201199: {{.*}} movl $2097544, %edx
anatofuz
parents:
diff changeset
103 // DISASM-NEXT: 20119e: {{.*}} movl $2097545, %edx
anatofuz
parents:
diff changeset
104 // DISASM-EMPTY:
anatofuz
parents:
diff changeset
105 // DISASM-NEXT: Disassembly of section .iplt:
anatofuz
parents:
diff changeset
106 // DISASM-EMPTY:
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
107 // DISASM-NEXT: <.iplt>:
150
anatofuz
parents:
diff changeset
108 // DISASM-NEXT: 2011b0: {{.*}} jmpq *4122(%rip)
anatofuz
parents:
diff changeset
109 // DISASM-NEXT: 2011b6: {{.*}} pushq $0
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
110 // DISASM-NEXT: 2011bb: {{.*}} jmp 0x0
150
anatofuz
parents:
diff changeset
111 // DISASM-NEXT: 2011c0: {{.*}} jmpq *4114(%rip)
anatofuz
parents:
diff changeset
112 // DISASM-NEXT: 2011c6: {{.*}} pushq $1
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
113 // DISASM-NEXT: 2011cb: {{.*}} jmp 0x0
150
anatofuz
parents:
diff changeset
114
anatofuz
parents:
diff changeset
115 .text
anatofuz
parents:
diff changeset
116 .type foo STT_GNU_IFUNC
anatofuz
parents:
diff changeset
117 .globl foo
anatofuz
parents:
diff changeset
118 foo:
anatofuz
parents:
diff changeset
119 ret
anatofuz
parents:
diff changeset
120
anatofuz
parents:
diff changeset
121 .type bar STT_GNU_IFUNC
anatofuz
parents:
diff changeset
122 .globl bar
anatofuz
parents:
diff changeset
123 bar:
anatofuz
parents:
diff changeset
124 ret
anatofuz
parents:
diff changeset
125
anatofuz
parents:
diff changeset
126 .globl _start
anatofuz
parents:
diff changeset
127 _start:
anatofuz
parents:
diff changeset
128 call foo
anatofuz
parents:
diff changeset
129 call bar
anatofuz
parents:
diff changeset
130 movl $__rela_iplt_start,%edx
anatofuz
parents:
diff changeset
131 movl $__rela_iplt_end,%edx
anatofuz
parents:
diff changeset
132 movl $__rela_iplt_end + 1,%edx