aboutsummaryrefslogtreecommitdiff
path: root/test/ELF/ppc64-toc-rel.s
blob: ac156c78b3a449fe543dc942e1a6899309300726 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
# REQUIRES: ppc

# RUN: llvm-mc -filetype=obj -triple=powerpc64le-unknown-linux %s -o %t.o
# RUN: llvm-readobj -relocations %t.o | FileCheck -check-prefix=RELOCS %s
# RUN: ld.lld %t.o -o %t2
# RUN: llvm-objdump -D %t2 | FileCheck %s

# RUN: llvm-mc -filetype=obj -triple=powerpc64-unknown-linux %s -o %t.o
# RUN: llvm-readobj -relocations %t.o | FileCheck -check-prefix=RELOCS-BE %s
# RUN: ld.lld %t.o -o %t2
# RUN: llvm-objdump -D %t2 | FileCheck -check-prefix=CHECK-BE %s

# Make sure we calculate the offset correctly for a toc-relative access to a
# global variable as described by the PPC64 Elf V2 abi.
.abiversion 2

#  int global_a = 55
   .globl      global_a
   .section    ".data"
   .align      2
   .type       global_a, @object
   .size       global_a, 4
   .p2align    2
global_a:
   .long   41


   .section        ".text"
   .align 2
   .global _start
   .type   _start, @function
_start:
.Lfunc_gep0:
    addis 2, 12, .TOC.-.Lfunc_gep0@ha
    addi 2, 2, .TOC.-.Lfunc_gep0@l
.Lfunc_lep0:
    .localentry _start, .Lfunc_lep0-.Lfunc_gep0

    addis 3, 2, global_a@toc@ha
    addi 3, 3, global_a@toc@l
    li 0,1
    lwa 3, 0(3)
    sc
.size   _start,.-_start

# Verify the relocations that get emitted for the global variable are the
# expected ones.
# RELOCS:      Relocations [
# RELOCS-NEXT:   .rela.text {
# RELOCS:          0x8 R_PPC64_TOC16_HA global_a 0x0
# RELOCS:          0xC R_PPC64_TOC16_LO global_a 0x0

# RELOCS-BE:      Relocations [
# RELOCS-BE-NEXT:   .rela.text {
# RELOCS-BE:          0xA R_PPC64_TOC16_HA global_a 0x0
# RELOCS-NE:          0xE R_PPC64_TOC16_LO global_a 0x0

# Want to check _start for the values used to build the offset from the TOC base
# to global_a. The .TOC. symbol is expected at address 0x10030000, and the
# TOC base is address-of(.TOC.) + 0x8000.  The expected offset is:
# 0x10020000(global_a) - 0x10038000(Toc base) = -0x18000(Offset)
# which gets materialized into r3 as ((-1 << 16) - 32768).

# CHECK:      Disassembly of section .text:
# CHECK-NEXT: _start:
# CHECK:      10010008:       {{.*}}     addis 3, 2, -1
# CHECK-NEXT: 1001000c:       {{.*}}     addi 3, 3, -32768

# CHECK:      Disassembly of section .data:
# CHECK-NEXT: global_a:
# CHECK-NEXT: 10020000:       {{.*}}

# CHECK:      Disassembly of section .got:
# CHECK-NEXT: .got:
# CHECK-NEXT: 10030000:       00 80 03 10


# CHECK-BE:      Disassembly of section .text:
# CHECK-BE-NEXT: _start:
# CHECK-BE:      10010008:       {{.*}}     addis 3, 2, -1
# CHECK-BE-NEXT: 1001000c:       {{.*}}     addi 3, 3, -32768

# CHECK-BE:      Disassembly of section .data:
# CHECK-BE-NEXT: global_a:
# CHECK-BE-NEXT: 10020000:       {{.*}}

# CHECK-BE:      Disassembly of section .got:
# CHECK-BE-NEXT: .got:
# CHECK-BE-NEXT: 10030000:       00 00 00 00
# CHECK-BE-NEXT: 10030004:       10 03 80 00