forked from OSchip/llvm-project
83 lines
2.6 KiB
ArmAsm
83 lines
2.6 KiB
ArmAsm
# 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-LE %s
|
|
# RUN: ld.lld %t.o -o %t2
|
|
# RUN: llvm-objdump -D %t2 | FileCheck %s
|
|
# RUN: llvm-objdump -D %t2 | FileCheck -check-prefix=CHECK-LE %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 %s
|
|
# 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-LE: Relocations [
|
|
# RELOCS-LE-NEXT: .rela.text {
|
|
# RELOCS-LE: 0x8 R_PPC64_TOC16_HA global_a 0x0
|
|
# RELOCS-LE: 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-BE: 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-LE: Disassembly of section .got:
|
|
# CHECK-LE-NEXT: .got:
|
|
# CHECK-LE-NEXT: 10030000: 00 80 03 10
|
|
|
|
# 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
|