mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 11:42:57 +01:00
[RuntimeDyld][PowerPC] Add a test case for r329335.
Checks that calls to different sections go to the function's global entry point, rather than the local one. llvm-svn: 329355
This commit is contained in:
parent
731a02af04
commit
d867d186f3
@ -0,0 +1,42 @@
|
||||
# This module contains a function with its local and global entry points
|
||||
# exposed. It is used by the ppc64_elf test to verify that functions with
|
||||
# different TOCs are called via their global entry points.
|
||||
.text
|
||||
.abiversion 2
|
||||
.file "ppc64_elf_module_b.ll"
|
||||
.section .rodata.cst4,"aM",@progbits,4
|
||||
.p2align 2 # -- Begin function foo
|
||||
.LCPI0_0:
|
||||
.long 1093664768 # float 11
|
||||
.text
|
||||
.globl foo
|
||||
.p2align 4
|
||||
.type foo,@function
|
||||
.Lfunc_toc0: # @foo
|
||||
.quad .TOC.-foo_gep
|
||||
foo:
|
||||
.Lfunc_begin0:
|
||||
.cfi_startproc
|
||||
.globl foo_gep
|
||||
foo_gep:
|
||||
ld 2, .Lfunc_toc0-foo_gep(12)
|
||||
add 2, 2, 12
|
||||
.globl foo_lep
|
||||
foo_lep:
|
||||
.localentry foo, foo_lep-foo_gep
|
||||
# %bb.0:
|
||||
addis 3, 2, .LC0@toc@ha
|
||||
ld 3, .LC0@toc@l(3)
|
||||
lfsx 1, 0, 3
|
||||
blr
|
||||
.long 0
|
||||
.quad 0
|
||||
.Lfunc_end0:
|
||||
.size foo, .Lfunc_end0-.Lfunc_begin0
|
||||
.cfi_endproc
|
||||
# -- End function
|
||||
.section .toc,"aw",@progbits
|
||||
.LC0:
|
||||
.tc .LCPI0_0[TC],.LCPI0_0
|
||||
|
||||
.section ".note.GNU-stack","",@progbits
|
47
test/ExecutionEngine/RuntimeDyld/PowerPC/ppc64_elf.s
Normal file
47
test/ExecutionEngine/RuntimeDyld/PowerPC/ppc64_elf.s
Normal file
@ -0,0 +1,47 @@
|
||||
# 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 [16: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
|
Loading…
Reference in New Issue
Block a user