[llvm] r200592 - Split out small-code-model MCJIT testcase in order to xfail for AArch64, where

Lang Hames lhames at gmail.com
Fri Jan 31 15:36:26 PST 2014


Author: lhames
Date: Fri Jan 31 17:36:25 2014
New Revision: 200592

URL: http://llvm.org/viewvc/llvm-project?rev=200592&view=rev
Log:
Split out small-code-model MCJIT testcase in order to xfail for AArch64, where
PC-rel relocations aren't yet fully implemented.

Added:
    llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend-smallcodemodel.ll
Modified:
    llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend.ll

Added: llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend-smallcodemodel.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend-smallcodemodel.ll?rev=200592&view=auto
==============================================================================
--- llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend-smallcodemodel.ll (added)
+++ llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend-smallcodemodel.ll Fri Jan 31 17:36:25 2014
@@ -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
+}

Modified: llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend.ll?rev=200592&r1=200591&r2=200592&view=diff
==============================================================================
--- llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend.ll (original)
+++ llvm/trunk/test/ExecutionEngine/MCJIT/non-extern-addend.ll Fri Jan 31 17:36:25 2014
@@ -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:





More information about the llvm-commits mailing list