1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv32 -verify-machineinstrs < %s | FileCheck %s --check-prefixes=R32
3 ; RUN: llc -mtriple=riscv64 -verify-machineinstrs < %s | FileCheck %s --check-prefixes=R64
5 define float @maxnum_f32(float %x, float %y) nounwind {
6 ; R32-LABEL: maxnum_f32:
8 ; R32-NEXT: addi sp, sp, -16
9 ; R32-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
10 ; R32-NEXT: call fmaxf@plt
11 ; R32-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
12 ; R32-NEXT: addi sp, sp, 16
15 ; R64-LABEL: maxnum_f32:
17 ; R64-NEXT: addi sp, sp, -16
18 ; R64-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
19 ; R64-NEXT: call fmaxf@plt
20 ; R64-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
21 ; R64-NEXT: addi sp, sp, 16
23 %r = call float @llvm.maxnum.f32(float %x, float %y)
27 define float @maxnum_f32_fast(float %x, float %y) nounwind {
28 ; R32-LABEL: maxnum_f32_fast:
30 ; R32-NEXT: addi sp, sp, -16
31 ; R32-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
32 ; R32-NEXT: sw s0, 8(sp) # 4-byte Folded Spill
33 ; R32-NEXT: sw s1, 4(sp) # 4-byte Folded Spill
36 ; R32-NEXT: call __gtsf2@plt
37 ; R32-NEXT: bgtz a0, .LBB1_2
42 ; R32-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
43 ; R32-NEXT: lw s0, 8(sp) # 4-byte Folded Reload
44 ; R32-NEXT: lw s1, 4(sp) # 4-byte Folded Reload
45 ; R32-NEXT: addi sp, sp, 16
48 ; R64-LABEL: maxnum_f32_fast:
50 ; R64-NEXT: addi sp, sp, -32
51 ; R64-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
52 ; R64-NEXT: sd s0, 16(sp) # 8-byte Folded Spill
53 ; R64-NEXT: sd s1, 8(sp) # 8-byte Folded Spill
56 ; R64-NEXT: call __gtsf2@plt
57 ; R64-NEXT: bgtz a0, .LBB1_2
62 ; R64-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
63 ; R64-NEXT: ld s0, 16(sp) # 8-byte Folded Reload
64 ; R64-NEXT: ld s1, 8(sp) # 8-byte Folded Reload
65 ; R64-NEXT: addi sp, sp, 32
67 %r = call fast float @llvm.maxnum.f32(float %x, float %y)
71 define double @maxnum_f64(double %x, double %y) nounwind {
72 ; R32-LABEL: maxnum_f64:
74 ; R32-NEXT: addi sp, sp, -16
75 ; R32-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
76 ; R32-NEXT: call fmax@plt
77 ; R32-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
78 ; R32-NEXT: addi sp, sp, 16
81 ; R64-LABEL: maxnum_f64:
83 ; R64-NEXT: addi sp, sp, -16
84 ; R64-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
85 ; R64-NEXT: call fmax@plt
86 ; R64-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
87 ; R64-NEXT: addi sp, sp, 16
89 %r = call double @llvm.maxnum.f64(double %x, double %y)
93 define double @maxnum_f64_nnan(double %x, double %y) nounwind {
94 ; R32-LABEL: maxnum_f64_nnan:
96 ; R32-NEXT: addi sp, sp, -32
97 ; R32-NEXT: sw ra, 28(sp) # 4-byte Folded Spill
98 ; R32-NEXT: sw s0, 24(sp) # 4-byte Folded Spill
99 ; R32-NEXT: sw s1, 20(sp) # 4-byte Folded Spill
100 ; R32-NEXT: sw s2, 16(sp) # 4-byte Folded Spill
101 ; R32-NEXT: sw s3, 12(sp) # 4-byte Folded Spill
102 ; R32-NEXT: mv s1, a3
103 ; R32-NEXT: mv s2, a2
104 ; R32-NEXT: mv s0, a1
105 ; R32-NEXT: mv s3, a0
106 ; R32-NEXT: call __gtdf2@plt
107 ; R32-NEXT: mv a1, a0
108 ; R32-NEXT: mv a0, s3
109 ; R32-NEXT: bgtz a1, .LBB3_2
111 ; R32-NEXT: mv s3, s2
113 ; R32-NEXT: mv a1, s0
114 ; R32-NEXT: mv a2, s2
115 ; R32-NEXT: mv a3, s1
116 ; R32-NEXT: call __gtdf2@plt
117 ; R32-NEXT: bgtz a0, .LBB3_4
119 ; R32-NEXT: mv s0, s1
121 ; R32-NEXT: mv a0, s3
122 ; R32-NEXT: mv a1, s0
123 ; R32-NEXT: lw ra, 28(sp) # 4-byte Folded Reload
124 ; R32-NEXT: lw s0, 24(sp) # 4-byte Folded Reload
125 ; R32-NEXT: lw s1, 20(sp) # 4-byte Folded Reload
126 ; R32-NEXT: lw s2, 16(sp) # 4-byte Folded Reload
127 ; R32-NEXT: lw s3, 12(sp) # 4-byte Folded Reload
128 ; R32-NEXT: addi sp, sp, 32
131 ; R64-LABEL: maxnum_f64_nnan:
133 ; R64-NEXT: addi sp, sp, -32
134 ; R64-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
135 ; R64-NEXT: sd s0, 16(sp) # 8-byte Folded Spill
136 ; R64-NEXT: sd s1, 8(sp) # 8-byte Folded Spill
137 ; R64-NEXT: mv s1, a1
138 ; R64-NEXT: mv s0, a0
139 ; R64-NEXT: call __gtdf2@plt
140 ; R64-NEXT: bgtz a0, .LBB3_2
142 ; R64-NEXT: mv s0, s1
144 ; R64-NEXT: mv a0, s0
145 ; R64-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
146 ; R64-NEXT: ld s0, 16(sp) # 8-byte Folded Reload
147 ; R64-NEXT: ld s1, 8(sp) # 8-byte Folded Reload
148 ; R64-NEXT: addi sp, sp, 32
150 %r = call nnan double @llvm.maxnum.f64(double %x, double %y)
154 define float @minnum_f32(float %x, float %y) nounwind {
155 ; R32-LABEL: minnum_f32:
157 ; R32-NEXT: addi sp, sp, -16
158 ; R32-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
159 ; R32-NEXT: call fminf@plt
160 ; R32-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
161 ; R32-NEXT: addi sp, sp, 16
164 ; R64-LABEL: minnum_f32:
166 ; R64-NEXT: addi sp, sp, -16
167 ; R64-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
168 ; R64-NEXT: call fminf@plt
169 ; R64-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
170 ; R64-NEXT: addi sp, sp, 16
172 %r = call float @llvm.minnum.f32(float %x, float %y)
176 define float @minnum_f32_nnan(float %x, float %y) nounwind {
177 ; R32-LABEL: minnum_f32_nnan:
179 ; R32-NEXT: addi sp, sp, -16
180 ; R32-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
181 ; R32-NEXT: sw s0, 8(sp) # 4-byte Folded Spill
182 ; R32-NEXT: sw s1, 4(sp) # 4-byte Folded Spill
183 ; R32-NEXT: mv s1, a1
184 ; R32-NEXT: mv s0, a0
185 ; R32-NEXT: call __ltsf2@plt
186 ; R32-NEXT: bltz a0, .LBB5_2
188 ; R32-NEXT: mv s0, s1
190 ; R32-NEXT: mv a0, s0
191 ; R32-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
192 ; R32-NEXT: lw s0, 8(sp) # 4-byte Folded Reload
193 ; R32-NEXT: lw s1, 4(sp) # 4-byte Folded Reload
194 ; R32-NEXT: addi sp, sp, 16
197 ; R64-LABEL: minnum_f32_nnan:
199 ; R64-NEXT: addi sp, sp, -32
200 ; R64-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
201 ; R64-NEXT: sd s0, 16(sp) # 8-byte Folded Spill
202 ; R64-NEXT: sd s1, 8(sp) # 8-byte Folded Spill
203 ; R64-NEXT: mv s1, a1
204 ; R64-NEXT: mv s0, a0
205 ; R64-NEXT: call __ltsf2@plt
206 ; R64-NEXT: bltz a0, .LBB5_2
208 ; R64-NEXT: mv s0, s1
210 ; R64-NEXT: mv a0, s0
211 ; R64-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
212 ; R64-NEXT: ld s0, 16(sp) # 8-byte Folded Reload
213 ; R64-NEXT: ld s1, 8(sp) # 8-byte Folded Reload
214 ; R64-NEXT: addi sp, sp, 32
216 %r = call nnan float @llvm.minnum.f32(float %x, float %y)
220 define double @minnum_f64(double %x, double %y) nounwind {
221 ; R32-LABEL: minnum_f64:
223 ; R32-NEXT: addi sp, sp, -16
224 ; R32-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
225 ; R32-NEXT: call fmin@plt
226 ; R32-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
227 ; R32-NEXT: addi sp, sp, 16
230 ; R64-LABEL: minnum_f64:
232 ; R64-NEXT: addi sp, sp, -16
233 ; R64-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
234 ; R64-NEXT: call fmin@plt
235 ; R64-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
236 ; R64-NEXT: addi sp, sp, 16
238 %r = call double @llvm.minnum.f64(double %x, double %y)
242 define double @minnum_f64_fast(double %x, double %y) nounwind {
243 ; R32-LABEL: minnum_f64_fast:
245 ; R32-NEXT: addi sp, sp, -32
246 ; R32-NEXT: sw ra, 28(sp) # 4-byte Folded Spill
247 ; R32-NEXT: sw s0, 24(sp) # 4-byte Folded Spill
248 ; R32-NEXT: sw s1, 20(sp) # 4-byte Folded Spill
249 ; R32-NEXT: sw s2, 16(sp) # 4-byte Folded Spill
250 ; R32-NEXT: sw s3, 12(sp) # 4-byte Folded Spill
251 ; R32-NEXT: mv s1, a3
252 ; R32-NEXT: mv s2, a2
253 ; R32-NEXT: mv s0, a1
254 ; R32-NEXT: mv s3, a0
255 ; R32-NEXT: call __ltdf2@plt
256 ; R32-NEXT: mv a1, a0
257 ; R32-NEXT: mv a0, s3
258 ; R32-NEXT: bltz a1, .LBB7_2
260 ; R32-NEXT: mv s3, s2
262 ; R32-NEXT: mv a1, s0
263 ; R32-NEXT: mv a2, s2
264 ; R32-NEXT: mv a3, s1
265 ; R32-NEXT: call __ltdf2@plt
266 ; R32-NEXT: bltz a0, .LBB7_4
268 ; R32-NEXT: mv s0, s1
270 ; R32-NEXT: mv a0, s3
271 ; R32-NEXT: mv a1, s0
272 ; R32-NEXT: lw ra, 28(sp) # 4-byte Folded Reload
273 ; R32-NEXT: lw s0, 24(sp) # 4-byte Folded Reload
274 ; R32-NEXT: lw s1, 20(sp) # 4-byte Folded Reload
275 ; R32-NEXT: lw s2, 16(sp) # 4-byte Folded Reload
276 ; R32-NEXT: lw s3, 12(sp) # 4-byte Folded Reload
277 ; R32-NEXT: addi sp, sp, 32
280 ; R64-LABEL: minnum_f64_fast:
282 ; R64-NEXT: addi sp, sp, -32
283 ; R64-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
284 ; R64-NEXT: sd s0, 16(sp) # 8-byte Folded Spill
285 ; R64-NEXT: sd s1, 8(sp) # 8-byte Folded Spill
286 ; R64-NEXT: mv s1, a1
287 ; R64-NEXT: mv s0, a0
288 ; R64-NEXT: call __ltdf2@plt
289 ; R64-NEXT: bltz a0, .LBB7_2
291 ; R64-NEXT: mv s0, s1
293 ; R64-NEXT: mv a0, s0
294 ; R64-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
295 ; R64-NEXT: ld s0, 16(sp) # 8-byte Folded Reload
296 ; R64-NEXT: ld s1, 8(sp) # 8-byte Folded Reload
297 ; R64-NEXT: addi sp, sp, 32
299 %r = call fast double @llvm.minnum.f64(double %x, double %y)
303 declare float @llvm.maxnum.f32(float, float)
304 declare double @llvm.maxnum.f64(double, double)
305 declare float @llvm.minnum.f32(float, float)
306 declare double @llvm.minnum.f64(double, double)