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

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
This commit is contained in:
Lang Hames 2014-01-31 23:36:25 +00:00
parent 6f4efee6cb
commit 1cf770889f
2 changed files with 25 additions and 1 deletions

View File

@ -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
}

View 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: