annotate lld/test/ELF/ppc32-call-stub-nopic.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
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
anatofuz
parents:
diff changeset
6 ## Check we can create PLT entries for -fno-PIE executable.
anatofuz
parents:
diff changeset
7 # RUN: ld.lld %t.o %t1.so -o %t
anatofuz
parents:
diff changeset
8 # RUN: llvm-readobj -r -d %t | FileCheck --check-prefix=RELOC %s
anatofuz
parents:
diff changeset
9 # RUN: llvm-readelf -S %t | FileCheck --check-prefix=SEC %s
anatofuz
parents:
diff changeset
10 # RUN: llvm-readelf -x .plt %t | FileCheck --check-prefix=HEX %s
anatofuz
parents:
diff changeset
11 # RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s
anatofuz
parents:
diff changeset
12
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
13 # SEC: .got PROGBITS 100202b8
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
14 # RELOC: PPC_GOT 0x100202B8
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
15
150
anatofuz
parents:
diff changeset
16 # RELOC: .rela.plt {
anatofuz
parents:
diff changeset
17 # RELOC-NEXT: 0x100302C4 R_PPC_JMP_SLOT f 0x0
anatofuz
parents:
diff changeset
18 # RELOC-NEXT: 0x100302C8 R_PPC_JMP_SLOT g 0x0
anatofuz
parents:
diff changeset
19 # RELOC-NEXT: }
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 ## .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
22 # CHECK-LABEL: <_start>:
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
23 # CHECK-NEXT: bl 0x100101d0
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
24 # CHECK-NEXT: bl 0x100101d0
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
25 # CHECK-NEXT: bl 0x100101e0
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
26 # CHECK-NEXT: bl 0x100101e0
150
anatofuz
parents:
diff changeset
27 # CHECK-EMPTY:
anatofuz
parents:
diff changeset
28
anatofuz
parents:
diff changeset
29 ## -fno-PIC call stubs of f and g.
anatofuz
parents:
diff changeset
30 ## .plt[0] = 0x100302c4 = 65536*4099+708
anatofuz
parents:
diff changeset
31 ## .plt[1] = 0x100302c8 = 65536*4099+712
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
32 # CHECK-NEXT: <00000000.plt_call32.f>:
150
anatofuz
parents:
diff changeset
33 # CHECK-NEXT: lis 11, 4099
anatofuz
parents:
diff changeset
34 # CHECK-NEXT: lwz 11, 708(11)
anatofuz
parents:
diff changeset
35 # CHECK-NEXT: mtctr 11
anatofuz
parents:
diff changeset
36 # CHECK-NEXT: bctr
anatofuz
parents:
diff changeset
37 # CHECK-EMPTY:
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
38 # CHECK-NEXT: <00000000.plt_call32.g>:
150
anatofuz
parents:
diff changeset
39 # CHECK-NEXT: lis 11, 4099
anatofuz
parents:
diff changeset
40 # CHECK-NEXT: lwz 11, 712(11)
anatofuz
parents:
diff changeset
41 # CHECK-NEXT: mtctr 11
anatofuz
parents:
diff changeset
42 # CHECK-NEXT: bctr
anatofuz
parents:
diff changeset
43 # CHECK-EMPTY:
anatofuz
parents:
diff changeset
44
anatofuz
parents:
diff changeset
45 ## In Secure PLT ABI, .plt stores function pointers to first instructions of .glink
anatofuz
parents:
diff changeset
46 # HEX: 0x100302c4 10010200 10010204
anatofuz
parents:
diff changeset
47
anatofuz
parents:
diff changeset
48 ## These instructions are referenced by .plt entries.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
49 # CHECK: 10010200 <.glink>:
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
50 # CHECK-NEXT: b 0x10010208
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
51 # CHECK-NEXT: b 0x10010208
150
anatofuz
parents:
diff changeset
52
anatofuz
parents:
diff changeset
53 ## PLTresolve
anatofuz
parents:
diff changeset
54 ## Operands of lis & lwz: .got+4 = 0x10020070+4 = 65536*4098+700
anatofuz
parents:
diff changeset
55 ## Operands of addis & addi: -.glink = -0x10010200 = 65536*-4097-512
anatofuz
parents:
diff changeset
56 # CHECK-NEXT: lis 12, 4098
anatofuz
parents:
diff changeset
57 # CHECK-NEXT: addis 11, 11, -4097
anatofuz
parents:
diff changeset
58 # CHECK-NEXT: lwz 0, 700(12)
anatofuz
parents:
diff changeset
59 # CHECK-NEXT: addi 11, 11, -512
anatofuz
parents:
diff changeset
60
anatofuz
parents:
diff changeset
61 # CHECK-NEXT: mtctr 0
anatofuz
parents:
diff changeset
62 # CHECK-NEXT: add 0, 11, 11
anatofuz
parents:
diff changeset
63 # CHECK-NEXT: lwz 12, 704(12)
anatofuz
parents:
diff changeset
64 # CHECK-NEXT: add 11, 0, 11
anatofuz
parents:
diff changeset
65 # CHECK-NEXT: bctr
anatofuz
parents:
diff changeset
66
anatofuz
parents:
diff changeset
67 ## glibc crti.o references _GLOBAL_OFFSET_TABLE_.
anatofuz
parents:
diff changeset
68 .section .init
anatofuz
parents:
diff changeset
69 bcl 20, 31, .+4
anatofuz
parents:
diff changeset
70 .L:
anatofuz
parents:
diff changeset
71 mflr 30
anatofuz
parents:
diff changeset
72 addis 30, 30, _GLOBAL_OFFSET_TABLE_-.L@ha
anatofuz
parents:
diff changeset
73 addi 30, 30, _GLOBAL_OFFSET_TABLE_-.L@l
anatofuz
parents:
diff changeset
74
anatofuz
parents:
diff changeset
75 .text
anatofuz
parents:
diff changeset
76 .globl _start
anatofuz
parents:
diff changeset
77 _start:
anatofuz
parents:
diff changeset
78 bl f
anatofuz
parents:
diff changeset
79 bl f
anatofuz
parents:
diff changeset
80 bl g
anatofuz
parents:
diff changeset
81 bl g