Split out small-code-model MCJIT testcase in order to xfail for AArch64, where
authorLang Hames <lhames@gmail.com>
Fri, 31 Jan 2014 23:36:25 +0000 (23:36 +0000)
committerLang Hames <lhames@gmail.com>
Fri, 31 Jan 2014 23:36:25 +0000 (23:36 +0000)
PC-rel relocations aren't yet fully implemented.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@200592 91177308-0d34-0410-b5e6-96231b3b80d8

test/ExecutionEngine/MCJIT/non-extern-addend-smallcodemodel.ll [new file with mode: 0644]
test/ExecutionEngine/MCJIT/non-extern-addend.ll

diff --git a/test/ExecutionEngine/MCJIT/non-extern-addend-smallcodemodel.ll b/test/ExecutionEngine/MCJIT/non-extern-addend-smallcodemodel.ll
new file mode 100644 (file)
index 0000000..5035bc5
--- /dev/null
@@ -0,0 +1,25 @@
+; RUN: %lli_mcjit -code-model=small %s > /dev/null
+; XFAIL: aarch64
+;
+; FIXME: Merge this file with non-extern-addend.ll once AArch64 supports PC-rel
+;        relocations in ELF. (The code is identical, only the run line differs).
+;
+define i32 @foo(i32 %x, i32 %y, double %d) {
+entry:
+  %d.int64 = bitcast double %d to i64
+  %d.top64 = lshr i64 %d.int64, 32
+  %d.top   = trunc i64 %d.top64 to i32
+  %d.bottom = trunc i64 %d.int64 to i32
+  %topCorrect = icmp eq i32 %d.top, 3735928559
+  %bottomCorrect = icmp eq i32 %d.bottom, 4277009102
+  %right = and i1 %topCorrect, %bottomCorrect
+  %nRight = xor i1 %right, true
+  %retVal = zext i1 %nRight to i32
+  ret i32 %retVal
+}
+
+define i32 @main() {
+entry:
+  %call = call i32 @foo(i32 0, i32 1, double 0xDEADBEEFFEEDFACE)
+  ret i32 %call
+}
index cf3ddea6b34c567878e8068238866eed1f8e1282..e0827f6add939a990c3c40f91ed848384b2bb76e 100644 (file)
@@ -1,5 +1,4 @@
 ; RUN: %lli_mcjit %s > /dev/null
-; RUN: %lli_mcjit -code-model=small %s > /dev/null
 
 define i32 @foo(i32 %x, i32 %y, double %d) {
 entry: