forked from OSchip/llvm-project
47 lines
1.1 KiB
ArmAsm
47 lines
1.1 KiB
ArmAsm
# REQUIRES: ppc
|
|
# RUN: llvm-mc -filetype=obj -triple=powerpc %s -o %t.o
|
|
# RUN: ld.lld -pie %t.o -o %t
|
|
# RUN: llvm-readobj -r %t | FileCheck --check-prefix=RELOC %s
|
|
# RUN: llvm-readelf -s %t | FileCheck --check-prefix=SYM %s
|
|
# RUN: llvm-readelf -x .got2 %t | FileCheck --check-prefix=HEX %s
|
|
# RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s
|
|
|
|
# RELOC: .rela.dyn {
|
|
# RELOC-NEXT: 0x30240 R_PPC_RELATIVE - 0x101A8
|
|
# RELOC-NEXT: 0x30244 R_PPC_IRELATIVE - 0x10188
|
|
# RELOC-NEXT: }
|
|
|
|
# SYM: 000101a8 0 FUNC GLOBAL DEFAULT {{.*}} func
|
|
# HEX: 0x00030240 00000000
|
|
|
|
.section .got2,"aw"
|
|
.long func
|
|
|
|
# CHECK: Disassembly of section .text:
|
|
# CHECK: <.text>:
|
|
# CHECK-NEXT: 10188: blr
|
|
# CHECK: <_start>:
|
|
# CHECK-NEXT: bl .+12
|
|
# CHECK-NEXT: lis 9, 1
|
|
# CHECK-NEXT: addi 9, 9, 424
|
|
# CHECK-EMPTY:
|
|
# CHECK-NEXT: <00008000.got2.plt_pic32.func>:
|
|
## 0x10020114 = 65536*4098+276
|
|
# CHECK-NEXT: lwz 11, -32764(30)
|
|
# CHECK-NEXT: mtctr 11
|
|
# CHECK-NEXT: bctr
|
|
# CHECK-NEXT: nop
|
|
|
|
.text
|
|
.globl func
|
|
.type func, @gnu_indirect_function
|
|
func:
|
|
blr
|
|
|
|
.globl _start
|
|
_start:
|
|
bl func+0x8000@plt
|
|
|
|
lis 9, func@ha
|
|
la 9, func@l(9)
|