diff options
author | Danil Malyshev <dmalyshev@accesssoftek.com> | 2012-05-17 21:07:47 +0000 |
---|---|---|
committer | Danil Malyshev <dmalyshev@accesssoftek.com> | 2012-05-17 21:07:47 +0000 |
commit | bb8cef51dfe7bb59109786a0ca46ad165c39aa38 (patch) | |
tree | 47107748cff082496775ef833af69b4cc385cc19 /test/ExecutionEngine/MCJIT/stubs.ll | |
parent | 9133783d5483e38b16af6c10df7a8bbe655d3446 (diff) | |
download | llvm-bb8cef51dfe7bb59109786a0ca46ad165c39aa38.tar.gz llvm-bb8cef51dfe7bb59109786a0ca46ad165c39aa38.tar.bz2 llvm-bb8cef51dfe7bb59109786a0ca46ad165c39aa38.tar.xz |
- Added ExecutionEngine/MCJIT tests
- Added HOST_ARCH to Makefile.config.in
The HOST_ARCH will be used by MCJIT tests filter, because MCJIT supported only x86 and ARM architectures now.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157015 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/ExecutionEngine/MCJIT/stubs.ll')
-rw-r--r-- | test/ExecutionEngine/MCJIT/stubs.ll | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/test/ExecutionEngine/MCJIT/stubs.ll b/test/ExecutionEngine/MCJIT/stubs.ll new file mode 100644 index 0000000000..b285b0eadb --- /dev/null +++ b/test/ExecutionEngine/MCJIT/stubs.ll @@ -0,0 +1,35 @@ +; RUN: %lli -use-mcjit -disable-lazy-compilation=false %s + +define i32 @main() nounwind { +entry: + call void @lazily_compiled_address_is_consistent() + ret i32 0 +} + +; Test PR3043: @test should have the same address before and after +; it's JIT-compiled. +@funcPtr = common global i1 ()* null, align 4 +@lcaic_failure = internal constant [46 x i8] c"@lazily_compiled_address_is_consistent failed\00" + +define void @lazily_compiled_address_is_consistent() nounwind { +entry: + store i1 ()* @test, i1 ()** @funcPtr + %pass = tail call i1 @test() ; <i32> [#uses=1] + br i1 %pass, label %pass_block, label %fail_block +pass_block: + ret void +fail_block: + call i32 @puts(i8* getelementptr([46 x i8]* @lcaic_failure, i32 0, i32 0)) + call void @exit(i32 1) + unreachable +} + +define i1 @test() nounwind { +entry: + %tmp = load i1 ()** @funcPtr + %eq = icmp eq i1 ()* %tmp, @test + ret i1 %eq +} + +declare i32 @puts(i8*) noreturn +declare void @exit(i32) noreturn |