# 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