summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorLang Hames <lhames@gmail.com>2013-12-07 03:05:51 +0000
committerLang Hames <lhames@gmail.com>2013-12-07 03:05:51 +0000
commite7777cdc643d15671c5a7bc7c24753820298c100 (patch)
tree474612a707de090c7ca2651c5d1d391c2c855fff /test
parenteb2934e78230f0a03db4b35b33ba9eda77755967 (diff)
downloadllvm-e7777cdc643d15671c5a7bc7c24753820298c100.tar.gz
llvm-e7777cdc643d15671c5a7bc7c24753820298c100.tar.bz2
llvm-e7777cdc643d15671c5a7bc7c24753820298c100.tar.xz
Add support for archives and object file caching under MCJIT.
Patch by Andy Kaylor, with minor edits to resolve merge conflicts. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@196639 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test')
-rw-r--r--test/ExecutionEngine/MCJIT/load-object-a.ll28
1 files changed, 28 insertions, 0 deletions
diff --git a/test/ExecutionEngine/MCJIT/load-object-a.ll b/test/ExecutionEngine/MCJIT/load-object-a.ll
new file mode 100644
index 0000000000..9e5c3d5858
--- /dev/null
+++ b/test/ExecutionEngine/MCJIT/load-object-a.ll
@@ -0,0 +1,28 @@
+; REQUIRES: shell
+
+; This first line will generate the .o files for the next run line
+; RUN: %lli_mcjit -extra-module=%p/Inputs/multi-module-b.ll -extra-module=%p/Inputs/multi-module-c.ll -enable-cache-manager %s
+
+; This line tests MCJIT object loading
+; RUN: %lli_mcjit -extra-object=%p/Inputs/multi-module-b.o -extra-object=%p/Inputs/multi-module-c.o %s
+
+; These lines put the object files into an archive
+; RUN: llvm-ar r %p/Inputs/load-object.a %p/Inputs/multi-module-b.o
+; RUN: llvm-ar r %p/Inputs/load-object.a %p/Inputs/multi-module-c.o
+
+; This line test MCJIT archive loading
+; RUN: %lli_mcjit -extra-archive=%p/Inputs/load-object.a %s
+
+; These lines clean up our temporary files
+; RUN: rm -f %p/Inputs/load-object-a.o
+; RUN: rm -f %p/Inputs/multi-module-b.o
+; RUN: rm -f %p/Inputs/multi-module-c.o
+; RUN: rm -f %p/Inputs/load-object.a
+
+declare i32 @FB()
+
+define i32 @main() {
+ %r = call i32 @FB( ) ; <i32> [#uses=1]
+ ret i32 %r
+}
+