annotate lld/test/ELF/ppc32-call-stub-pic.s @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 0572611fdcc8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 # REQUIRES: ppc
anatofuz
parents:
diff changeset
2 # RUN: llvm-mc -filetype=obj -triple=powerpc %s -o %t.o
anatofuz
parents:
diff changeset
3 # RUN: echo '.globl f, g, h; f: g: h:' | llvm-mc -filetype=obj -triple=powerpc - -o %t1.o
anatofuz
parents:
diff changeset
4 # RUN: ld.lld -shared %t1.o -soname t1.so -o %t1.so
anatofuz
parents:
diff changeset
5 # RUN: echo 'bl f+0x8000@plt' | llvm-mc -filetype=obj -triple=powerpc - -o %t2.o
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 ## Check we can create PLT entries for -fPIE or -fpie executable.
anatofuz
parents:
diff changeset
8 # RUN: ld.lld -pie %t.o %t1.so %t2.o -o %t
anatofuz
parents:
diff changeset
9 # RUN: llvm-readobj -r %t | FileCheck --check-prefix=RELOC %s
anatofuz
parents:
diff changeset
10 # RUN: llvm-readobj -d %t | FileCheck --check-prefix=DYN %s
anatofuz
parents:
diff changeset
11 # RUN: llvm-readelf -S %t | FileCheck --check-prefix=SEC %s
anatofuz
parents:
diff changeset
12 # RUN: llvm-readelf -x .plt %t | FileCheck --check-prefix=HEX %s
anatofuz
parents:
diff changeset
13 # RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck --check-prefixes=CHECK,PIE %s
anatofuz
parents:
diff changeset
14
anatofuz
parents:
diff changeset
15 ## Check we can create PLT entries for -fPIC or -fpic DSO.
anatofuz
parents:
diff changeset
16 # RUN: ld.lld -shared %t.o %t1.so %t2.o -o %t
anatofuz
parents:
diff changeset
17 # RUN: llvm-readobj -r %t | FileCheck --check-prefix=RELOC %s
anatofuz
parents:
diff changeset
18 # RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck --check-prefixes=CHECK,SHARED %s
anatofuz
parents:
diff changeset
19
anatofuz
parents:
diff changeset
20 # RELOC: .rela.dyn {
anatofuz
parents:
diff changeset
21 # RELOC-NEXT: R_PPC_ADDR32 f 0x0
anatofuz
parents:
diff changeset
22 # RELOC-NEXT: R_PPC_ADDR32 g 0x0
anatofuz
parents:
diff changeset
23 # RELOC-NEXT: R_PPC_ADDR32 h 0x0
anatofuz
parents:
diff changeset
24 # RELOC-NEXT: }
anatofuz
parents:
diff changeset
25 # RELOC-NEXT: .rela.plt {
anatofuz
parents:
diff changeset
26 # RELOC-NEXT: R_PPC_JMP_SLOT f 0x0
anatofuz
parents:
diff changeset
27 # RELOC-NEXT: R_PPC_JMP_SLOT g 0x0
anatofuz
parents:
diff changeset
28 # RELOC-NEXT: R_PPC_JMP_SLOT h 0x0
anatofuz
parents:
diff changeset
29 # RELOC-NEXT: }
anatofuz
parents:
diff changeset
30
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
31 # SEC: .got PROGBITS 00020370
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
32 # DYN: PPC_GOT 0x20370
150
anatofuz
parents:
diff changeset
33
anatofuz
parents:
diff changeset
34 ## .got2+0x8000-0x10004 = 0x30000+0x8000-0x10004 = 65536*2+32764
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
35 # CHECK-LABEL: <_start>:
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
36 # PIE-NEXT: bcl 20, 31, 0x10210
150
anatofuz
parents:
diff changeset
37 # PIE-NEXT: 10210: mflr 30
anatofuz
parents:
diff changeset
38 # PIE-NEXT: addis 30, 30, 3
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
39 # PIE-NEXT: addi 30, 30, -32404
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
40 ## Two bl 00008000.got2.plt_pic32.f
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
41 # PIE-NEXT: bl 0x10244
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
42 # PIE-NEXT: bl 0x10244
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
43 ## Two bl 00008000.got2.plt_pic32.g
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
44 # PIE-NEXT: bl 0x10254
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
45 # PIE-NEXT: bl 0x10254
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
46 ## Two bl 00008000.got2.plt_pic32.h
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
47 # PIE-NEXT: bl 0x10264
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
48 # PIE-NEXT: bl 0x10264
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
49 # PIE-NEXT: addis 30, 30, {{.*}}
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
50 # PIE-NEXT: addi 30, 30, {{.*}}
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
51 ## bl 00008000.plt_pic32.f
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
52 # PIE-NEXT: bl 0x10274
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
53 ## bl 00008000.plt_pic32.f
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
54 # PIE-NEXT: bl 0x10284
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
55 # SHARED-NEXT: bcl 20, 31, 0x10230
150
anatofuz
parents:
diff changeset
56 # SHARED-NEXT: 10230: mflr 30
anatofuz
parents:
diff changeset
57 # SHARED-NEXT: addis 30, 30, 3
anatofuz
parents:
diff changeset
58 # SHARED-NEXT: addi 30, 30, -32420
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
59 # SHARED-NEXT: bl 0x10264
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
60 # SHARED-NEXT: bl 0x10264
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
61 # SHARED-NEXT: bl 0x10274
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
62 # SHARED-NEXT: bl 0x10274
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
63 # SHARED-NEXT: bl 0x10284
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
64 # SHARED-NEXT: bl 0x10284
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
65 # SHARED-NEXT: addis 30, 30, {{.*}}
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
66 # SHARED-NEXT: addi 30, 30, {{.*}}
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
67 # SHARED-NEXT: bl 0x10294
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
68 # SHARED-NEXT: bl 0x102a4
150
anatofuz
parents:
diff changeset
69 # CHECK-EMPTY:
anatofuz
parents:
diff changeset
70
anatofuz
parents:
diff changeset
71 ## -fPIC call stubs of f and g.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
72 # CHECK-NEXT: <00008000.got2.plt_pic32.f>:
150
anatofuz
parents:
diff changeset
73 # CHECK-NEXT: lwz 11, 32760(30)
anatofuz
parents:
diff changeset
74 # CHECK-NEXT: mtctr 11
anatofuz
parents:
diff changeset
75 # CHECK-NEXT: bctr
anatofuz
parents:
diff changeset
76 # CHECK-NEXT: nop
anatofuz
parents:
diff changeset
77 # CHECK-EMPTY:
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
78 # CHECK-NEXT: <00008000.got2.plt_pic32.g>:
150
anatofuz
parents:
diff changeset
79 # CHECK-NEXT: lwz 11, 32764(30)
anatofuz
parents:
diff changeset
80 # CHECK-NEXT: mtctr 11
anatofuz
parents:
diff changeset
81 # CHECK-NEXT: bctr
anatofuz
parents:
diff changeset
82 # CHECK-NEXT: nop
anatofuz
parents:
diff changeset
83 # CHECK-EMPTY:
anatofuz
parents:
diff changeset
84
anatofuz
parents:
diff changeset
85 ## The -fPIC call stub of h needs two instructions addis+lwz to represent the offset 65536*1-32768.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
86 # CHECK-NEXT: <00008000.got2.plt_pic32.h>:
150
anatofuz
parents:
diff changeset
87 # CHECK-NEXT: addis 11, 30, 1
anatofuz
parents:
diff changeset
88 # CHECK-NEXT: lwz 11, -32768(11)
anatofuz
parents:
diff changeset
89 # CHECK-NEXT: mtctr 11
anatofuz
parents:
diff changeset
90 # CHECK-NEXT: bctr
anatofuz
parents:
diff changeset
91 # CHECK-EMPTY:
anatofuz
parents:
diff changeset
92
anatofuz
parents:
diff changeset
93 ## -fpic call stub of f.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
94 # CHECK-NEXT: <00000000.plt_pic32.f>:
150
anatofuz
parents:
diff changeset
95 # CHECK-NEXT: addis 11, 30, 2
anatofuz
parents:
diff changeset
96 # CHECK-NEXT: lwz 11, 4(11)
anatofuz
parents:
diff changeset
97 # CHECK-NEXT: mtctr 11
anatofuz
parents:
diff changeset
98 # CHECK-NEXT: bctr
anatofuz
parents:
diff changeset
99 # CHECK-EMPTY:
anatofuz
parents:
diff changeset
100
anatofuz
parents:
diff changeset
101 ## Another -fPIC call stub of f from another object file %t2.o
anatofuz
parents:
diff changeset
102 ## .got2 may have different addresses in different object files,
anatofuz
parents:
diff changeset
103 ## so the call stub cannot be shared.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
104 # CHECK-NEXT: <00008000.got2.plt_pic32.f>:
150
anatofuz
parents:
diff changeset
105
anatofuz
parents:
diff changeset
106 ## In Secure PLT ABI, .plt stores function pointers to first instructions of .glink
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
107 # HEX: 0x00040374 00010294 00010298 0001029c
150
anatofuz
parents:
diff changeset
108
anatofuz
parents:
diff changeset
109 ## These instructions are referenced by .plt entries.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
110 # CHECK: [[#%x,GLINK:]] <.glink>:
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
111 # CHECK-NEXT: b 0x[[#%x,GLINK+12]]
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
112 # CHECK-NEXT: b 0x[[#%x,GLINK+12]]
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
113 # CHECK-NEXT: b 0x[[#%x,GLINK+12]]
150
anatofuz
parents:
diff changeset
114
anatofuz
parents:
diff changeset
115 ## PLTresolve
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
116 ## Operand of addi: 0x102cc-.glink = 24
150
anatofuz
parents:
diff changeset
117 # CHECK-NEXT: addis 11, 11, 0
anatofuz
parents:
diff changeset
118 # CHECK-NEXT: mflr 0
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
119 # CHECK-NEXT: bcl 20, 31, 0x[[#%x,NEXT:]]
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
120 # CHECK-NEXT: [[#%x,NEXT]]: addi 11, 11, 24
150
anatofuz
parents:
diff changeset
121
anatofuz
parents:
diff changeset
122 # CHECK-NEXT: mflr 12
anatofuz
parents:
diff changeset
123 # CHECK-NEXT: mtlr 0
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
124 # CHECK-NEXT: sub 11, 11, 12
150
anatofuz
parents:
diff changeset
125
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
126 ## Operand of lwz in -pie mode: &.got[1] - 0x102bc = 0x20380+4 - 0x102bc = 65536*1+200
150
anatofuz
parents:
diff changeset
127 # CHECK-NEXT: addis 12, 12, 1
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
128 # PIE-NEXT: lwz 0, 200(12)
150
anatofuz
parents:
diff changeset
129 # SHARED-NEXT: lwz 0, 184(12)
anatofuz
parents:
diff changeset
130
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
131 # PIE-NEXT: lwz 12, 204(12)
150
anatofuz
parents:
diff changeset
132 # SHARED-NEXT: lwz 12, 188(12)
anatofuz
parents:
diff changeset
133 # CHECK-NEXT: mtctr 0
anatofuz
parents:
diff changeset
134 # CHECK-NEXT: add 0, 11, 11
anatofuz
parents:
diff changeset
135 # CHECK-NEXT: add 11, 0, 11
anatofuz
parents:
diff changeset
136 # CHECK-NEXT: bctr
anatofuz
parents:
diff changeset
137
anatofuz
parents:
diff changeset
138 .section .got2,"aw"
anatofuz
parents:
diff changeset
139 .space 65516
anatofuz
parents:
diff changeset
140 .long f
anatofuz
parents:
diff changeset
141 .long g
anatofuz
parents:
diff changeset
142 .long h
anatofuz
parents:
diff changeset
143
anatofuz
parents:
diff changeset
144 .text
anatofuz
parents:
diff changeset
145 .globl _start
anatofuz
parents:
diff changeset
146 _start:
anatofuz
parents:
diff changeset
147 bcl 20,31,.L
anatofuz
parents:
diff changeset
148 .L:
anatofuz
parents:
diff changeset
149 mflr 30
anatofuz
parents:
diff changeset
150 addis 30, 30, .got2+0x8000-.L@ha
anatofuz
parents:
diff changeset
151 addi 30, 30, .got2+0x8000-.L@l
anatofuz
parents:
diff changeset
152 bl f+0x8000@plt
anatofuz
parents:
diff changeset
153 bl f+0x8000@plt
anatofuz
parents:
diff changeset
154 bl g+0x8000@plt
anatofuz
parents:
diff changeset
155 bl g+0x8000@plt
anatofuz
parents:
diff changeset
156 bl h+0x8000@plt
anatofuz
parents:
diff changeset
157 bl h+0x8000@plt
anatofuz
parents:
diff changeset
158
anatofuz
parents:
diff changeset
159 ## An addend of 0 indicates r30 is stored in _GLOBAL_OFFSET_TABLE_.
anatofuz
parents:
diff changeset
160 ## The existing thunk is incompatible, thus it cannot be reused.
anatofuz
parents:
diff changeset
161 addis 30, 30, _GLOBAL_OFFSET_TABLE_-.L@ha
anatofuz
parents:
diff changeset
162 addi 30, 30, _GLOBAL_OFFSET_TABLE_-.L@l
anatofuz
parents:
diff changeset
163 bl f@plt