[AArch64,ELF] Restrict MOVZ/MOVK to non-PIC large code model (#70178)
[llvm-project.git] / llvm / test / CodeGen / X86 / fp2sint.ll
blob722a85d852be035e40265570548d1c8c3091bb41
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ;; LowerFP_TO_SINT should not create a stack object if it's not needed.
4 ; RUN: llc < %s -mtriple=i686-- -mattr=+sse2 | FileCheck %s
6 define i32 @main(i32 %argc, ptr %argv) {
7 ; CHECK-LABEL: main:
8 ; CHECK:       # %bb.0: # %cond_false.i.i.i
9 ; CHECK-NEXT:    cvttsd2si 0, %eax
10 ; CHECK-NEXT:    movl %eax, 0
11 ; CHECK-NEXT:    xorl %eax, %eax
12 ; CHECK-NEXT:    retl
13 cond_false.i.i.i:               ; preds = %bb.i5
14        %tmp35.i = load double, ptr null, align 8           ; <double> [#uses=1]
15        %tmp3536.i = fptosi double %tmp35.i to i32              ; <i32> [#uses=1]
16        %tmp3536140.i = zext i32 %tmp3536.i to i64              ; <i64> [#uses=1]
17        %tmp39.i = load double, ptr null, align 4           ; <double> [#uses=1]
18        %tmp3940.i = fptosi double %tmp39.i to i32              ; <i32> [#uses=1]
19        %tmp3940137.i = zext i32 %tmp3940.i to i64              ; <i64> [#uses=1]
20        %tmp3940137138.i = shl i64 %tmp3940137.i, 32            ; <i64> [#uses=1]
21        %tmp3940137138.ins.i = or i64 %tmp3940137138.i, %tmp3536140.i           ; <i64> [#uses=1]
22        %tmp95.i.i = trunc i64 %tmp3940137138.ins.i to i32              ; <i32> [#uses=1]
23        store i32 %tmp95.i.i, ptr null, align 4
24        ret i32 0