xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2009-03-03-BitcastLongDouble.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86
2*9880d681SAndroid Build Coastguard Worker; PR3686
3*9880d681SAndroid Build Coastguard Worker; rdar://6661799
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdefine i32 @x(i32 %y) nounwind readnone {
6*9880d681SAndroid Build Coastguard Workerentry:
7*9880d681SAndroid Build Coastguard Worker	%tmp14 = zext i32 %y to i80		; <i80> [#uses=1]
8*9880d681SAndroid Build Coastguard Worker	%tmp15 = bitcast i80 %tmp14 to x86_fp80		; <x86_fp80> [#uses=1]
9*9880d681SAndroid Build Coastguard Worker	%add = fadd x86_fp80 %tmp15, 0xK3FFF8000000000000000		; <x86_fp80> [#uses=1]
10*9880d681SAndroid Build Coastguard Worker	%tmp11 = bitcast x86_fp80 %add to i80		; <i80> [#uses=1]
11*9880d681SAndroid Build Coastguard Worker	%tmp10 = trunc i80 %tmp11 to i32		; <i32> [#uses=1]
12*9880d681SAndroid Build Coastguard Worker	ret i32 %tmp10
13*9880d681SAndroid Build Coastguard Worker}
14*9880d681SAndroid Build Coastguard Worker
15