Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / AArch64 / svtcf-fmul-fdiv-combine.ll
blobf78fcea9e3a1f5d29172f728445db8dceaf661b0
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
2 ; RUN: llc -mtriple aarch64-none-linux-gnu -enable-unsafe-fp-math -mattr=+fullfp16 < %s | FileCheck %s
4 define half @scvtf_f16_2(i32 %state) {
5 ; CHECK-LABEL: scvtf_f16_2:
6 ; CHECK:       // %bb.0: // %entry
7 ; CHECK-NEXT:    scvtf h0, w0, #1
8 ; CHECK-NEXT:    ret
9 entry:
10   %conv = sitofp i32 %state to half
11   %div = fmul half %conv, 5.000000e-01
12   ret half %div
15 define half @scvtf_f16_4(i32 %state) {
16 ; CHECK-LABEL: scvtf_f16_4:
17 ; CHECK:       // %bb.0: // %entry
18 ; CHECK-NEXT:    scvtf h0, w0, #2
19 ; CHECK-NEXT:    ret
20 entry:
21   %conv = sitofp i32 %state to half
22   %div = fmul half %conv, 2.500000e-01
23   ret half %div
26 define half @scvtf_f16_8(i32 %state) {
27 ; CHECK-LABEL: scvtf_f16_8:
28 ; CHECK:       // %bb.0: // %entry
29 ; CHECK-NEXT:    scvtf h0, w0, #3
30 ; CHECK-NEXT:    ret
31 entry:
32   %conv = sitofp i32 %state to half
33   %div = fmul half %conv, 1.250000e-01
34   ret half %div
37 define half @scvtf_f16_16(i32 %state) {
38 ; CHECK-LABEL: scvtf_f16_16:
39 ; CHECK:       // %bb.0: // %entry
40 ; CHECK-NEXT:    scvtf h0, w0, #4
41 ; CHECK-NEXT:    ret
42 entry:
43   %conv = sitofp i32 %state to half
44   %div = fmul half %conv, 6.250000e-02
45   ret half %div
48 define half @scvtf_f16_32(i32 %state) {
49 ; CHECK-LABEL: scvtf_f16_32:
50 ; CHECK:       // %bb.0: // %entry
51 ; CHECK-NEXT:    scvtf h0, w0, #5
52 ; CHECK-NEXT:    ret
53 entry:
54   %conv = sitofp i32 %state to half
55   %div = fmul half %conv, 3.125000e-02
56   ret half %div
59 define float @scvtf_f32_2(i32 %state) {
60 ; CHECK-LABEL: scvtf_f32_2:
61 ; CHECK:       // %bb.0: // %entry
62 ; CHECK-NEXT:    scvtf s0, w0, #1
63 ; CHECK-NEXT:    ret
64 entry:
65   %conv = sitofp i32 %state to float
66   %div = fmul float %conv, 5.000000e-01
67   ret float %div
70 define float @scvtf_f32_4(i32 %state) {
71 ; CHECK-LABEL: scvtf_f32_4:
72 ; CHECK:       // %bb.0: // %entry
73 ; CHECK-NEXT:    scvtf s0, w0, #2
74 ; CHECK-NEXT:    ret
75 entry:
76   %conv = sitofp i32 %state to float
77   %div = fmul float %conv, 2.500000e-01
78   ret float %div
81 define float @scvtf_f32_8(i32 %state) {
82 ; CHECK-LABEL: scvtf_f32_8:
83 ; CHECK:       // %bb.0: // %entry
84 ; CHECK-NEXT:    scvtf s0, w0, #3
85 ; CHECK-NEXT:    ret
86 entry:
87   %conv = sitofp i32 %state to float
88   %div = fmul float %conv, 1.250000e-01
89   ret float %div
92 define float @scvtf_f32_16(i32 %state) {
93 ; CHECK-LABEL: scvtf_f32_16:
94 ; CHECK:       // %bb.0: // %entry
95 ; CHECK-NEXT:    scvtf s0, w0, #4
96 ; CHECK-NEXT:    ret
97 entry:
98   %conv = sitofp i32 %state to float
99   %div = fmul float %conv, 6.250000e-02
100   ret float %div
103 define float @scvtf_f32_32(i32 %state) {
104 ; CHECK-LABEL: scvtf_f32_32:
105 ; CHECK:       // %bb.0: // %entry
106 ; CHECK-NEXT:    scvtf s0, w0, #5
107 ; CHECK-NEXT:    ret
108 entry:
109   %conv = sitofp i32 %state to float
110   %div = fmul float %conv, 3.125000e-02
111   ret float %div
114 define double @scvtf_f64_2(i64 %state) {
115 ; CHECK-LABEL: scvtf_f64_2:
116 ; CHECK:       // %bb.0: // %entry
117 ; CHECK-NEXT:    scvtf d0, x0, #1
118 ; CHECK-NEXT:    ret
119 entry:
120   %conv = sitofp i64 %state to double
121   %div = fmul double %conv, 5.000000e-01
122   ret double %div
125 define double @scvtf_f64_4(i64 %state) {
126 ; CHECK-LABEL: scvtf_f64_4:
127 ; CHECK:       // %bb.0: // %entry
128 ; CHECK-NEXT:    scvtf d0, x0, #2
129 ; CHECK-NEXT:    ret
130 entry:
131   %conv = sitofp i64 %state to double
132   %div = fmul double %conv, 2.500000e-01
133   ret double %div
136 define double @scvtf_f64_8(i64 %state) {
137 ; CHECK-LABEL: scvtf_f64_8:
138 ; CHECK:       // %bb.0: // %entry
139 ; CHECK-NEXT:    scvtf d0, x0, #3
140 ; CHECK-NEXT:    ret
141 entry:
142   %conv = sitofp i64 %state to double
143   %div = fmul double %conv, 1.250000e-01
144   ret double %div
147 define double @scvtf_f64_16(i64 %state) {
148 ; CHECK-LABEL: scvtf_f64_16:
149 ; CHECK:       // %bb.0: // %entry
150 ; CHECK-NEXT:    scvtf d0, x0, #4
151 ; CHECK-NEXT:    ret
152 entry:
153   %conv = sitofp i64 %state to double
154   %div = fmul double %conv, 6.250000e-02
155   ret double %div
158 define double @scvtf_f64_32(i64 %state) {
159 ; CHECK-LABEL: scvtf_f64_32:
160 ; CHECK:       // %bb.0: // %entry
161 ; CHECK-NEXT:    scvtf d0, x0, #5
162 ; CHECK-NEXT:    ret
163 entry:
164   %conv = sitofp i64 %state to double
165   %div = fmul double %conv, 3.125000e-02
166   ret double %div