xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2009-01-16-UIntToFP.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86
2*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
3*9880d681SAndroid Build Coastguard Workertarget triple = "i386-apple-darwin8"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdefine hidden float @__floatundisf(i64 %u) nounwind readnone {
6*9880d681SAndroid Build Coastguard Workerentry:
7*9880d681SAndroid Build Coastguard Worker	%0 = icmp ugt i64 %u, 9007199254740991		; <i1> [#uses=1]
8*9880d681SAndroid Build Coastguard Worker	br i1 %0, label %bb, label %bb2
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerbb:		; preds = %entry
11*9880d681SAndroid Build Coastguard Worker	%1 = and i64 %u, 2047		; <i64> [#uses=1]
12*9880d681SAndroid Build Coastguard Worker	%2 = icmp eq i64 %1, 0		; <i1> [#uses=1]
13*9880d681SAndroid Build Coastguard Worker	br i1 %2, label %bb2, label %bb1
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Workerbb1:		; preds = %bb
16*9880d681SAndroid Build Coastguard Worker	%3 = or i64 %u, 2048		; <i64> [#uses=1]
17*9880d681SAndroid Build Coastguard Worker	%4 = and i64 %3, -2048		; <i64> [#uses=1]
18*9880d681SAndroid Build Coastguard Worker	br label %bb2
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Workerbb2:		; preds = %bb1, %bb, %entry
21*9880d681SAndroid Build Coastguard Worker	%u_addr.0 = phi i64 [ %4, %bb1 ], [ %u, %entry ], [ %u, %bb ]		; <i64> [#uses=2]
22*9880d681SAndroid Build Coastguard Worker	%5 = lshr i64 %u_addr.0, 32		; <i64> [#uses=1]
23*9880d681SAndroid Build Coastguard Worker	%6 = trunc i64 %5 to i32		; <i32> [#uses=1]
24*9880d681SAndroid Build Coastguard Worker	%7 = uitofp i32 %6 to double		; <double> [#uses=1]
25*9880d681SAndroid Build Coastguard Worker	%8 = fmul double %7, 0x41F0000000000000		; <double> [#uses=1]
26*9880d681SAndroid Build Coastguard Worker	%9 = trunc i64 %u_addr.0 to i32		; <i32> [#uses=1]
27*9880d681SAndroid Build Coastguard Worker	%10 = uitofp i32 %9 to double		; <double> [#uses=1]
28*9880d681SAndroid Build Coastguard Worker	%11 = fadd double %10, %8		; <double> [#uses=1]
29*9880d681SAndroid Build Coastguard Worker	%12 = fptrunc double %11 to float		; <float> [#uses=1]
30*9880d681SAndroid Build Coastguard Worker	ret float %12
31*9880d681SAndroid Build Coastguard Worker}
32