mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
47fd5639bc
This ensures that we're building and testing the CompileOnDemand layer, at least in a basic way. Currently x86-64 only, and with limited to no library calls enabled (depending on host platform). Patches welcome. ;) To enable access to the lazy JIT, this patch replaces the '-use-orcmcjit' lli option with a new option: '-jit-kind={ mcjit | orc-mcjit | orc-lazy }'. All regression tests are updated to use the new option, and one trivial test of the new lazy JIT is added. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@233182 91177308-0d34-0410-b5e6-96231b3b80d8
22 lines
597 B
LLVM
22 lines
597 B
LLVM
; RUN: %lli -jit-kind=orc-mcjit %s > /dev/null
|
|
|
|
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
|
|
}
|