# This test has been observed to fail on 32-bit architectures (see e.g.
# https://github.com/llvm/llvm-project/issues/62184). Since we're aiming to
# bring up JITLink support for ppc64{le} anyway (see
# https://github.com/llvm/llvm-project/issues/62253) I've opted to just disable
# it on 32-bit architectures for now.
# REQUIRES: llvm-64-bits
#
# RUN: rm -rf %t && mkdir -p %t
# RUN: llvm-mc -triple=powerpc64le-unknown-linux-gnu -filetype=obj -o %t/ppc64_elf.o %s
# RUN: llvm-mc -triple=powerpc64le-unknown-linux-gnu -filetype=obj -o %t/ppc64_elf_module_b.o %S/Inputs/ppc64_elf_module_b.s
# RUN: llvm-rtdyld -triple=powerpc64le-unknown-linux-gnu -verify -check=%s %t/ppc64_elf.o %t/ppc64_elf_module_b.o
.text
.abiversion 2
.file "Module2.ll"
.globl bar # -- Begin function bar
.p2align 4
.type bar,@function
.Lfunc_toc0: # @bar
.quad .TOC.-.Lfunc_gep0
bar:
.Lfunc_begin0:
.cfi_startproc
.Lfunc_gep0:
ld 2, .Lfunc_toc0-.Lfunc_gep0(12)
add 2, 2, 12
.Lfunc_lep0:
.localentry bar, .Lfunc_lep0-.Lfunc_gep0
# %bb.0:
mflr 0
std 0, 16(1)
stdu 1, -32(1)
.cfi_def_cfa_offset 32
.cfi_offset lr, 16
# rtdyld-check: (*{4}(stub_addr(ppc64_elf.o/.text, foo) + 0)) [15:0] = foo_gep [63:48]
# rtdyld-check: (*{4}(stub_addr(ppc64_elf.o/.text, foo) + 4)) [15:0] = foo_gep [47:32]
# rtdyld-check: (*{4}(stub_addr(ppc64_elf.o/.text, foo) + 12)) [15:0] = foo_gep [31:16]
# rtdyld-check: (*{4}(stub_addr(ppc64_elf.o/.text, foo) + 16)) [15:0] = foo_gep [15:0]
# rtdyld-check: decode_operand(foo_call, 0) = (stub_addr(ppc64_elf.o/.text, foo) - foo_call) >> 2
foo_call:
bl foo
nop
addi 1, 1, 32
ld 0, 16(1)
mtlr 0
blr
.long 0
.quad 0
.Lfunc_end0:
.size bar, .Lfunc_end0-.Lfunc_begin0
.cfi_endproc
# -- End function
.section ".note.GNU-stack","",@progbits