annotate lld/test/ELF/aarch64-gnu-ifunc-nonpreemptable.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: aarch64
anatofuz
parents:
diff changeset
2 # RUN: llvm-mc -filetype=obj -triple=aarch64-none-linux-gnu %s -o %t.o
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 # RUN: ld.lld %t.o -o %t
anatofuz
parents:
diff changeset
5 # RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s --check-prefix=PDE
anatofuz
parents:
diff changeset
6 # RUN: llvm-readobj -r %t | FileCheck %s --check-prefix=PDE-RELOC
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 # RUN: ld.lld -pie %t.o -o %t
anatofuz
parents:
diff changeset
9 # RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s --check-prefix=PIE
anatofuz
parents:
diff changeset
10 # RUN: llvm-readobj -r %t | FileCheck %s --check-prefix=PIE-RELOC
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 ## When compiling with -fno-PIE or -fPIE, if the ifunc is in the same
anatofuz
parents:
diff changeset
13 ## translation unit as the address taker, the compiler knows that ifunc is not
anatofuz
parents:
diff changeset
14 ## defined in a shared library so it can use a non GOT generating relative reference.
anatofuz
parents:
diff changeset
15 .text
anatofuz
parents:
diff changeset
16 .globl myfunc
anatofuz
parents:
diff changeset
17 .type myfunc,@gnu_indirect_function
anatofuz
parents:
diff changeset
18 myfunc:
anatofuz
parents:
diff changeset
19 .globl myfunc_resolver
anatofuz
parents:
diff changeset
20 .type myfunc_resolver,@function
anatofuz
parents:
diff changeset
21 myfunc_resolver:
anatofuz
parents:
diff changeset
22 ret
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 .text
anatofuz
parents:
diff changeset
25 .globl main
anatofuz
parents:
diff changeset
26 .type main,@function
anatofuz
parents:
diff changeset
27 main:
anatofuz
parents:
diff changeset
28 adrp x8, myfunc
anatofuz
parents:
diff changeset
29 add x8, x8, :lo12: myfunc
anatofuz
parents:
diff changeset
30 ret
anatofuz
parents:
diff changeset
31
anatofuz
parents:
diff changeset
32 ## The address of myfunc is the address of the PLT entry for myfunc.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
33 # PDE: <myfunc_resolver>:
150
anatofuz
parents:
diff changeset
34 # PDE-NEXT: 210170: ret
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
35 # PDE: <main>:
150
anatofuz
parents:
diff changeset
36 # PDE-NEXT: 210174: adrp x8, #0
anatofuz
parents:
diff changeset
37 # PDE-NEXT: 210178: add x8, x8, #384
anatofuz
parents:
diff changeset
38 # PDE-NEXT: 21017c: ret
anatofuz
parents:
diff changeset
39 # PDE-EMPTY:
anatofuz
parents:
diff changeset
40 # PDE-NEXT: Disassembly of section .iplt:
anatofuz
parents:
diff changeset
41 # PDE-EMPTY:
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
42 # PDE-NEXT: <myfunc>:
150
anatofuz
parents:
diff changeset
43 ## page(.got.plt) - page(0x210010) = 65536
anatofuz
parents:
diff changeset
44 # PDE-NEXT: 210180: adrp x16, #65536
anatofuz
parents:
diff changeset
45 # PDE-NEXT: 210184: ldr x17, [x16, #400]
anatofuz
parents:
diff changeset
46 # PDE-NEXT: 210188: add x16, x16, #400
anatofuz
parents:
diff changeset
47 # PDE-NEXT: 21018c: br x17
anatofuz
parents:
diff changeset
48
anatofuz
parents:
diff changeset
49 ## The adrp to myfunc should generate a PLT entry and a GOT entry with an
anatofuz
parents:
diff changeset
50 ## irelative relocation.
anatofuz
parents:
diff changeset
51 # PDE-RELOC: .rela.dyn {
anatofuz
parents:
diff changeset
52 # PDE-RELOC-NEXT: 0x220190 R_AARCH64_IRELATIVE - 0x210170
anatofuz
parents:
diff changeset
53 # PDE-RELOC-NEXT: }
anatofuz
parents:
diff changeset
54
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
55 # PIE: <myfunc_resolver>:
150
anatofuz
parents:
diff changeset
56 # PIE-NEXT: 10260: ret
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
57 # PIE: <main>:
150
anatofuz
parents:
diff changeset
58 # PIE-NEXT: 10264: adrp x8, #0
anatofuz
parents:
diff changeset
59 # PIE-NEXT: 10268: add x8, x8, #624
anatofuz
parents:
diff changeset
60 # PIE-NEXT: 1026c: ret
anatofuz
parents:
diff changeset
61 # PIE-EMPTY:
anatofuz
parents:
diff changeset
62 # PIE-NEXT: Disassembly of section .iplt:
anatofuz
parents:
diff changeset
63 # PIE-EMPTY:
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
64 # PIE-NEXT: <myfunc>:
150
anatofuz
parents:
diff changeset
65 # PIE-NEXT: 10270: adrp x16, #131072
anatofuz
parents:
diff changeset
66 # PIE-NEXT: 10274: ldr x17, [x16, #880]
anatofuz
parents:
diff changeset
67 # PIE-NEXT: 10278: add x16, x16, #880
anatofuz
parents:
diff changeset
68 # PIE-NEXT: 1027c: br x17
anatofuz
parents:
diff changeset
69
anatofuz
parents:
diff changeset
70 # PIE-RELOC: .rela.dyn {
anatofuz
parents:
diff changeset
71 # PIE-RELOC-NEXT: 0x30370 R_AARCH64_IRELATIVE - 0x10260
anatofuz
parents:
diff changeset
72 # PIE-RELOC-NEXT: }