forked from OSchip/llvm-project
43 lines
1.1 KiB
ArmAsm
43 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: 0x3024C R_PPC_RELATIVE - 0x101A0
|
|
# RELOC-NEXT: 0x30250 R_PPC_IRELATIVE - 0x10188
|
|
# RELOC-NEXT: }
|
|
|
|
# SYM: 000101a0 0 FUNC GLOBAL DEFAULT {{.*}} func
|
|
# HEX: Hex dump of section '.got2':
|
|
# HEX-NEXT: 0x0003024c 00000000 ....
|
|
|
|
.section .got2,"aw"
|
|
.long func
|
|
|
|
# CHECK: Disassembly of section .text:
|
|
# CHECK: <.text>:
|
|
# CHECK-NEXT: 10188: blr
|
|
# CHECK: <_start>:
|
|
# CHECK-NEXT: bl 0x10190
|
|
# 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
|