annotate lld/test/ELF/ppc64-entry-point.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
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
anatofuz
parents:
diff changeset
3 # RUN: llvm-mc -filetype=obj -triple=powerpc64le-unknown-linux %s -o %t.o
anatofuz
parents:
diff changeset
4 # RUN: ld.lld %t.o -o %t
anatofuz
parents:
diff changeset
5 # RUN: llvm-nm %t | FileCheck --check-prefix=NM %s
anatofuz
parents:
diff changeset
6 # RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 # RUN: llvm-mc -filetype=obj -triple=powerpc64-unknown-linux %s -o %t.o
anatofuz
parents:
diff changeset
9 # RUN: ld.lld %t.o -o %t
anatofuz
parents:
diff changeset
10 # RUN: llvm-nm %t | FileCheck --check-prefix=NM %s
anatofuz
parents:
diff changeset
11 # RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s
anatofuz
parents:
diff changeset
12
anatofuz
parents:
diff changeset
13 .text
anatofuz
parents:
diff changeset
14 .abiversion 2
anatofuz
parents:
diff changeset
15 .globl _start
anatofuz
parents:
diff changeset
16 .p2align 4
anatofuz
parents:
diff changeset
17 .type _start,@function
anatofuz
parents:
diff changeset
18
anatofuz
parents:
diff changeset
19 _start:
anatofuz
parents:
diff changeset
20 .Lfunc_begin0:
anatofuz
parents:
diff changeset
21 .Lfunc_gep0:
anatofuz
parents:
diff changeset
22 lis 4, .Lfunc_gep0@ha
anatofuz
parents:
diff changeset
23 addi 4, 4, .Lfunc_gep0@l
anatofuz
parents:
diff changeset
24 # now r4 should contain the address of _start
anatofuz
parents:
diff changeset
25
anatofuz
parents:
diff changeset
26 lis 5, .TOC.-.Lfunc_gep0@ha # R_PPC64_REL16_HA
anatofuz
parents:
diff changeset
27 addi 5, 5, .TOC.-.Lfunc_gep0@l # R_PPC64_REL16_LO
anatofuz
parents:
diff changeset
28 # now r5 should contain the offset s.t. r4 + r5 = TOC base
anatofuz
parents:
diff changeset
29
anatofuz
parents:
diff changeset
30 # exit 55
anatofuz
parents:
diff changeset
31 li 0, 1
anatofuz
parents:
diff changeset
32 li 3, 55
anatofuz
parents:
diff changeset
33 sc
anatofuz
parents:
diff changeset
34 .Lfunc_end0:
anatofuz
parents:
diff changeset
35 .size _start, .Lfunc_end0-.Lfunc_begin0
anatofuz
parents:
diff changeset
36
anatofuz
parents:
diff changeset
37 # NM-DAG: 00000000100281f0 d .TOC.
anatofuz
parents:
diff changeset
38 # NM-DAG: 00000000100101d0 T _start
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 # 0x100101d0 = (4097<<16) + 464
anatofuz
parents:
diff changeset
41 # CHECK: 100101d0: lis 4, 4097
anatofuz
parents:
diff changeset
42 # CHECK-NEXT: 100101d4: addi 4, 4, 464
anatofuz
parents:
diff changeset
43 # .TOC. - _start = (2<<16) - 32736
anatofuz
parents:
diff changeset
44 # CHECK-NEXT: 100101d8: lis 5, 2
anatofuz
parents:
diff changeset
45 # CHECK-NEXT: 100101dc: addi 5, 5, -32736