Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / RISCV / rvv / fixed-vectors-vfmax-vp.ll
blobca033c26dba1f776d33fae0574ae412d510de8cb
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv32 -mattr=+d,+zfh,+zvfh,+v -target-abi=ilp32d \
3 ; RUN:   -verify-machineinstrs < %s | FileCheck %s --check-prefixes=CHECK,ZVFH
4 ; RUN: llc -mtriple=riscv64 -mattr=+d,+zfh,+zvfh,+v -target-abi=lp64d \
5 ; RUN:   -verify-machineinstrs < %s | FileCheck %s --check-prefixes=CHECK,ZVFH
6 ; RUN: llc -mtriple=riscv32 -mattr=+d,+zfh,+zvfhmin,+v -target-abi=ilp32d \
7 ; RUN:   -verify-machineinstrs < %s | FileCheck %s --check-prefixes=CHECK,ZVFHMIN
8 ; RUN: llc -mtriple=riscv64 -mattr=+d,+zfh,+zvfhmin,+v -target-abi=lp64d \
9 ; RUN:   -verify-machineinstrs < %s | FileCheck %s --check-prefixes=CHECK,ZVFHMIN
11 declare <2 x half> @llvm.vp.maxnum.v2f16(<2 x half>, <2 x half>, <2 x i1>, i32)
13 define <2 x half> @vfmax_vv_v2f16(<2 x half> %va, <2 x half> %vb, <2 x i1> %m, i32 zeroext %evl) {
14 ; ZVFH-LABEL: vfmax_vv_v2f16:
15 ; ZVFH:       # %bb.0:
16 ; ZVFH-NEXT:    vsetvli zero, a0, e16, mf4, ta, ma
17 ; ZVFH-NEXT:    vfmax.vv v8, v8, v9, v0.t
18 ; ZVFH-NEXT:    ret
20 ; ZVFHMIN-LABEL: vfmax_vv_v2f16:
21 ; ZVFHMIN:       # %bb.0:
22 ; ZVFHMIN-NEXT:    vsetivli zero, 2, e16, mf4, ta, ma
23 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v10, v9
24 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v9, v8
25 ; ZVFHMIN-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
26 ; ZVFHMIN-NEXT:    vfmax.vv v9, v9, v10, v0.t
27 ; ZVFHMIN-NEXT:    vsetivli zero, 2, e16, mf4, ta, ma
28 ; ZVFHMIN-NEXT:    vfncvt.f.f.w v8, v9
29 ; ZVFHMIN-NEXT:    ret
30   %v = call <2 x half> @llvm.vp.maxnum.v2f16(<2 x half> %va, <2 x half> %vb, <2 x i1> %m, i32 %evl)
31   ret <2 x half> %v
34 define <2 x half> @vfmax_vv_v2f16_unmasked(<2 x half> %va, <2 x half> %vb, i32 zeroext %evl) {
35 ; ZVFH-LABEL: vfmax_vv_v2f16_unmasked:
36 ; ZVFH:       # %bb.0:
37 ; ZVFH-NEXT:    vsetvli zero, a0, e16, mf4, ta, ma
38 ; ZVFH-NEXT:    vfmax.vv v8, v8, v9
39 ; ZVFH-NEXT:    ret
41 ; ZVFHMIN-LABEL: vfmax_vv_v2f16_unmasked:
42 ; ZVFHMIN:       # %bb.0:
43 ; ZVFHMIN-NEXT:    vsetivli zero, 2, e16, mf4, ta, ma
44 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v10, v9
45 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v9, v8
46 ; ZVFHMIN-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
47 ; ZVFHMIN-NEXT:    vfmax.vv v9, v9, v10
48 ; ZVFHMIN-NEXT:    vsetivli zero, 2, e16, mf4, ta, ma
49 ; ZVFHMIN-NEXT:    vfncvt.f.f.w v8, v9
50 ; ZVFHMIN-NEXT:    ret
51   %head = insertelement <2 x i1> poison, i1 true, i32 0
52   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
53   %v = call <2 x half> @llvm.vp.maxnum.v2f16(<2 x half> %va, <2 x half> %vb, <2 x i1> %m, i32 %evl)
54   ret <2 x half> %v
57 declare <4 x half> @llvm.vp.maxnum.v4f16(<4 x half>, <4 x half>, <4 x i1>, i32)
59 define <4 x half> @vfmax_vv_v4f16(<4 x half> %va, <4 x half> %vb, <4 x i1> %m, i32 zeroext %evl) {
60 ; ZVFH-LABEL: vfmax_vv_v4f16:
61 ; ZVFH:       # %bb.0:
62 ; ZVFH-NEXT:    vsetvli zero, a0, e16, mf2, ta, ma
63 ; ZVFH-NEXT:    vfmax.vv v8, v8, v9, v0.t
64 ; ZVFH-NEXT:    ret
66 ; ZVFHMIN-LABEL: vfmax_vv_v4f16:
67 ; ZVFHMIN:       # %bb.0:
68 ; ZVFHMIN-NEXT:    vsetivli zero, 4, e16, mf2, ta, ma
69 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v10, v9
70 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v9, v8
71 ; ZVFHMIN-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
72 ; ZVFHMIN-NEXT:    vfmax.vv v9, v9, v10, v0.t
73 ; ZVFHMIN-NEXT:    vsetivli zero, 4, e16, mf2, ta, ma
74 ; ZVFHMIN-NEXT:    vfncvt.f.f.w v8, v9
75 ; ZVFHMIN-NEXT:    ret
76   %v = call <4 x half> @llvm.vp.maxnum.v4f16(<4 x half> %va, <4 x half> %vb, <4 x i1> %m, i32 %evl)
77   ret <4 x half> %v
80 define <4 x half> @vfmax_vv_v4f16_unmasked(<4 x half> %va, <4 x half> %vb, i32 zeroext %evl) {
81 ; ZVFH-LABEL: vfmax_vv_v4f16_unmasked:
82 ; ZVFH:       # %bb.0:
83 ; ZVFH-NEXT:    vsetvli zero, a0, e16, mf2, ta, ma
84 ; ZVFH-NEXT:    vfmax.vv v8, v8, v9
85 ; ZVFH-NEXT:    ret
87 ; ZVFHMIN-LABEL: vfmax_vv_v4f16_unmasked:
88 ; ZVFHMIN:       # %bb.0:
89 ; ZVFHMIN-NEXT:    vsetivli zero, 4, e16, mf2, ta, ma
90 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v10, v9
91 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v9, v8
92 ; ZVFHMIN-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
93 ; ZVFHMIN-NEXT:    vfmax.vv v9, v9, v10
94 ; ZVFHMIN-NEXT:    vsetivli zero, 4, e16, mf2, ta, ma
95 ; ZVFHMIN-NEXT:    vfncvt.f.f.w v8, v9
96 ; ZVFHMIN-NEXT:    ret
97   %head = insertelement <4 x i1> poison, i1 true, i32 0
98   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
99   %v = call <4 x half> @llvm.vp.maxnum.v4f16(<4 x half> %va, <4 x half> %vb, <4 x i1> %m, i32 %evl)
100   ret <4 x half> %v
103 declare <8 x half> @llvm.vp.maxnum.v8f16(<8 x half>, <8 x half>, <8 x i1>, i32)
105 define <8 x half> @vfmax_vv_v8f16(<8 x half> %va, <8 x half> %vb, <8 x i1> %m, i32 zeroext %evl) {
106 ; ZVFH-LABEL: vfmax_vv_v8f16:
107 ; ZVFH:       # %bb.0:
108 ; ZVFH-NEXT:    vsetvli zero, a0, e16, m1, ta, ma
109 ; ZVFH-NEXT:    vfmax.vv v8, v8, v9, v0.t
110 ; ZVFH-NEXT:    ret
112 ; ZVFHMIN-LABEL: vfmax_vv_v8f16:
113 ; ZVFHMIN:       # %bb.0:
114 ; ZVFHMIN-NEXT:    vsetivli zero, 8, e16, m1, ta, ma
115 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v10, v9
116 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v12, v8
117 ; ZVFHMIN-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
118 ; ZVFHMIN-NEXT:    vfmax.vv v10, v12, v10, v0.t
119 ; ZVFHMIN-NEXT:    vsetivli zero, 8, e16, m1, ta, ma
120 ; ZVFHMIN-NEXT:    vfncvt.f.f.w v8, v10
121 ; ZVFHMIN-NEXT:    ret
122   %v = call <8 x half> @llvm.vp.maxnum.v8f16(<8 x half> %va, <8 x half> %vb, <8 x i1> %m, i32 %evl)
123   ret <8 x half> %v
126 define <8 x half> @vfmax_vv_v8f16_unmasked(<8 x half> %va, <8 x half> %vb, i32 zeroext %evl) {
127 ; ZVFH-LABEL: vfmax_vv_v8f16_unmasked:
128 ; ZVFH:       # %bb.0:
129 ; ZVFH-NEXT:    vsetvli zero, a0, e16, m1, ta, ma
130 ; ZVFH-NEXT:    vfmax.vv v8, v8, v9
131 ; ZVFH-NEXT:    ret
133 ; ZVFHMIN-LABEL: vfmax_vv_v8f16_unmasked:
134 ; ZVFHMIN:       # %bb.0:
135 ; ZVFHMIN-NEXT:    vsetivli zero, 8, e16, m1, ta, ma
136 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v10, v9
137 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v12, v8
138 ; ZVFHMIN-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
139 ; ZVFHMIN-NEXT:    vfmax.vv v10, v12, v10
140 ; ZVFHMIN-NEXT:    vsetivli zero, 8, e16, m1, ta, ma
141 ; ZVFHMIN-NEXT:    vfncvt.f.f.w v8, v10
142 ; ZVFHMIN-NEXT:    ret
143   %head = insertelement <8 x i1> poison, i1 true, i32 0
144   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
145   %v = call <8 x half> @llvm.vp.maxnum.v8f16(<8 x half> %va, <8 x half> %vb, <8 x i1> %m, i32 %evl)
146   ret <8 x half> %v
149 declare <16 x half> @llvm.vp.maxnum.v16f16(<16 x half>, <16 x half>, <16 x i1>, i32)
151 define <16 x half> @vfmax_vv_v16f16(<16 x half> %va, <16 x half> %vb, <16 x i1> %m, i32 zeroext %evl) {
152 ; ZVFH-LABEL: vfmax_vv_v16f16:
153 ; ZVFH:       # %bb.0:
154 ; ZVFH-NEXT:    vsetvli zero, a0, e16, m2, ta, ma
155 ; ZVFH-NEXT:    vfmax.vv v8, v8, v10, v0.t
156 ; ZVFH-NEXT:    ret
158 ; ZVFHMIN-LABEL: vfmax_vv_v16f16:
159 ; ZVFHMIN:       # %bb.0:
160 ; ZVFHMIN-NEXT:    vsetivli zero, 16, e16, m2, ta, ma
161 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v12, v10
162 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v16, v8
163 ; ZVFHMIN-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
164 ; ZVFHMIN-NEXT:    vfmax.vv v12, v16, v12, v0.t
165 ; ZVFHMIN-NEXT:    vsetivli zero, 16, e16, m2, ta, ma
166 ; ZVFHMIN-NEXT:    vfncvt.f.f.w v8, v12
167 ; ZVFHMIN-NEXT:    ret
168   %v = call <16 x half> @llvm.vp.maxnum.v16f16(<16 x half> %va, <16 x half> %vb, <16 x i1> %m, i32 %evl)
169   ret <16 x half> %v
172 define <16 x half> @vfmax_vv_v16f16_unmasked(<16 x half> %va, <16 x half> %vb, i32 zeroext %evl) {
173 ; ZVFH-LABEL: vfmax_vv_v16f16_unmasked:
174 ; ZVFH:       # %bb.0:
175 ; ZVFH-NEXT:    vsetvli zero, a0, e16, m2, ta, ma
176 ; ZVFH-NEXT:    vfmax.vv v8, v8, v10
177 ; ZVFH-NEXT:    ret
179 ; ZVFHMIN-LABEL: vfmax_vv_v16f16_unmasked:
180 ; ZVFHMIN:       # %bb.0:
181 ; ZVFHMIN-NEXT:    vsetivli zero, 16, e16, m2, ta, ma
182 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v12, v10
183 ; ZVFHMIN-NEXT:    vfwcvt.f.f.v v16, v8
184 ; ZVFHMIN-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
185 ; ZVFHMIN-NEXT:    vfmax.vv v12, v16, v12
186 ; ZVFHMIN-NEXT:    vsetivli zero, 16, e16, m2, ta, ma
187 ; ZVFHMIN-NEXT:    vfncvt.f.f.w v8, v12
188 ; ZVFHMIN-NEXT:    ret
189   %head = insertelement <16 x i1> poison, i1 true, i32 0
190   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
191   %v = call <16 x half> @llvm.vp.maxnum.v16f16(<16 x half> %va, <16 x half> %vb, <16 x i1> %m, i32 %evl)
192   ret <16 x half> %v
195 declare <2 x float> @llvm.vp.maxnum.v2f32(<2 x float>, <2 x float>, <2 x i1>, i32)
197 define <2 x float> @vfmax_vv_v2f32(<2 x float> %va, <2 x float> %vb, <2 x i1> %m, i32 zeroext %evl) {
198 ; CHECK-LABEL: vfmax_vv_v2f32:
199 ; CHECK:       # %bb.0:
200 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
201 ; CHECK-NEXT:    vfmax.vv v8, v8, v9, v0.t
202 ; CHECK-NEXT:    ret
203   %v = call <2 x float> @llvm.vp.maxnum.v2f32(<2 x float> %va, <2 x float> %vb, <2 x i1> %m, i32 %evl)
204   ret <2 x float> %v
207 define <2 x float> @vfmax_vv_v2f32_unmasked(<2 x float> %va, <2 x float> %vb, i32 zeroext %evl) {
208 ; CHECK-LABEL: vfmax_vv_v2f32_unmasked:
209 ; CHECK:       # %bb.0:
210 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
211 ; CHECK-NEXT:    vfmax.vv v8, v8, v9
212 ; CHECK-NEXT:    ret
213   %head = insertelement <2 x i1> poison, i1 true, i32 0
214   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
215   %v = call <2 x float> @llvm.vp.maxnum.v2f32(<2 x float> %va, <2 x float> %vb, <2 x i1> %m, i32 %evl)
216   ret <2 x float> %v
219 declare <4 x float> @llvm.vp.maxnum.v4f32(<4 x float>, <4 x float>, <4 x i1>, i32)
221 define <4 x float> @vfmax_vv_v4f32(<4 x float> %va, <4 x float> %vb, <4 x i1> %m, i32 zeroext %evl) {
222 ; CHECK-LABEL: vfmax_vv_v4f32:
223 ; CHECK:       # %bb.0:
224 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
225 ; CHECK-NEXT:    vfmax.vv v8, v8, v9, v0.t
226 ; CHECK-NEXT:    ret
227   %v = call <4 x float> @llvm.vp.maxnum.v4f32(<4 x float> %va, <4 x float> %vb, <4 x i1> %m, i32 %evl)
228   ret <4 x float> %v
231 define <4 x float> @vfmax_vv_v4f32_unmasked(<4 x float> %va, <4 x float> %vb, i32 zeroext %evl) {
232 ; CHECK-LABEL: vfmax_vv_v4f32_unmasked:
233 ; CHECK:       # %bb.0:
234 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
235 ; CHECK-NEXT:    vfmax.vv v8, v8, v9
236 ; CHECK-NEXT:    ret
237   %head = insertelement <4 x i1> poison, i1 true, i32 0
238   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
239   %v = call <4 x float> @llvm.vp.maxnum.v4f32(<4 x float> %va, <4 x float> %vb, <4 x i1> %m, i32 %evl)
240   ret <4 x float> %v
243 declare <8 x float> @llvm.vp.maxnum.v8f32(<8 x float>, <8 x float>, <8 x i1>, i32)
245 define <8 x float> @vfmax_vv_v8f32(<8 x float> %va, <8 x float> %vb, <8 x i1> %m, i32 zeroext %evl) {
246 ; CHECK-LABEL: vfmax_vv_v8f32:
247 ; CHECK:       # %bb.0:
248 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
249 ; CHECK-NEXT:    vfmax.vv v8, v8, v10, v0.t
250 ; CHECK-NEXT:    ret
251   %v = call <8 x float> @llvm.vp.maxnum.v8f32(<8 x float> %va, <8 x float> %vb, <8 x i1> %m, i32 %evl)
252   ret <8 x float> %v
255 define <8 x float> @vfmax_vv_v8f32_unmasked(<8 x float> %va, <8 x float> %vb, i32 zeroext %evl) {
256 ; CHECK-LABEL: vfmax_vv_v8f32_unmasked:
257 ; CHECK:       # %bb.0:
258 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
259 ; CHECK-NEXT:    vfmax.vv v8, v8, v10
260 ; CHECK-NEXT:    ret
261   %head = insertelement <8 x i1> poison, i1 true, i32 0
262   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
263   %v = call <8 x float> @llvm.vp.maxnum.v8f32(<8 x float> %va, <8 x float> %vb, <8 x i1> %m, i32 %evl)
264   ret <8 x float> %v
267 declare <16 x float> @llvm.vp.maxnum.v16f32(<16 x float>, <16 x float>, <16 x i1>, i32)
269 define <16 x float> @vfmax_vv_v16f32(<16 x float> %va, <16 x float> %vb, <16 x i1> %m, i32 zeroext %evl) {
270 ; CHECK-LABEL: vfmax_vv_v16f32:
271 ; CHECK:       # %bb.0:
272 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
273 ; CHECK-NEXT:    vfmax.vv v8, v8, v12, v0.t
274 ; CHECK-NEXT:    ret
275   %v = call <16 x float> @llvm.vp.maxnum.v16f32(<16 x float> %va, <16 x float> %vb, <16 x i1> %m, i32 %evl)
276   ret <16 x float> %v
279 define <16 x float> @vfmax_vv_v16f32_unmasked(<16 x float> %va, <16 x float> %vb, i32 zeroext %evl) {
280 ; CHECK-LABEL: vfmax_vv_v16f32_unmasked:
281 ; CHECK:       # %bb.0:
282 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
283 ; CHECK-NEXT:    vfmax.vv v8, v8, v12
284 ; CHECK-NEXT:    ret
285   %head = insertelement <16 x i1> poison, i1 true, i32 0
286   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
287   %v = call <16 x float> @llvm.vp.maxnum.v16f32(<16 x float> %va, <16 x float> %vb, <16 x i1> %m, i32 %evl)
288   ret <16 x float> %v
291 declare <2 x double> @llvm.vp.maxnum.v2f64(<2 x double>, <2 x double>, <2 x i1>, i32)
293 define <2 x double> @vfmax_vv_v2f64(<2 x double> %va, <2 x double> %vb, <2 x i1> %m, i32 zeroext %evl) {
294 ; CHECK-LABEL: vfmax_vv_v2f64:
295 ; CHECK:       # %bb.0:
296 ; CHECK-NEXT:    vsetvli zero, a0, e64, m1, ta, ma
297 ; CHECK-NEXT:    vfmax.vv v8, v8, v9, v0.t
298 ; CHECK-NEXT:    ret
299   %v = call <2 x double> @llvm.vp.maxnum.v2f64(<2 x double> %va, <2 x double> %vb, <2 x i1> %m, i32 %evl)
300   ret <2 x double> %v
303 define <2 x double> @vfmax_vv_v2f64_unmasked(<2 x double> %va, <2 x double> %vb, i32 zeroext %evl) {
304 ; CHECK-LABEL: vfmax_vv_v2f64_unmasked:
305 ; CHECK:       # %bb.0:
306 ; CHECK-NEXT:    vsetvli zero, a0, e64, m1, ta, ma
307 ; CHECK-NEXT:    vfmax.vv v8, v8, v9
308 ; CHECK-NEXT:    ret
309   %head = insertelement <2 x i1> poison, i1 true, i32 0
310   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
311   %v = call <2 x double> @llvm.vp.maxnum.v2f64(<2 x double> %va, <2 x double> %vb, <2 x i1> %m, i32 %evl)
312   ret <2 x double> %v
315 declare <4 x double> @llvm.vp.maxnum.v4f64(<4 x double>, <4 x double>, <4 x i1>, i32)
317 define <4 x double> @vfmax_vv_v4f64(<4 x double> %va, <4 x double> %vb, <4 x i1> %m, i32 zeroext %evl) {
318 ; CHECK-LABEL: vfmax_vv_v4f64:
319 ; CHECK:       # %bb.0:
320 ; CHECK-NEXT:    vsetvli zero, a0, e64, m2, ta, ma
321 ; CHECK-NEXT:    vfmax.vv v8, v8, v10, v0.t
322 ; CHECK-NEXT:    ret
323   %v = call <4 x double> @llvm.vp.maxnum.v4f64(<4 x double> %va, <4 x double> %vb, <4 x i1> %m, i32 %evl)
324   ret <4 x double> %v
327 define <4 x double> @vfmax_vv_v4f64_unmasked(<4 x double> %va, <4 x double> %vb, i32 zeroext %evl) {
328 ; CHECK-LABEL: vfmax_vv_v4f64_unmasked:
329 ; CHECK:       # %bb.0:
330 ; CHECK-NEXT:    vsetvli zero, a0, e64, m2, ta, ma
331 ; CHECK-NEXT:    vfmax.vv v8, v8, v10
332 ; CHECK-NEXT:    ret
333   %head = insertelement <4 x i1> poison, i1 true, i32 0
334   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
335   %v = call <4 x double> @llvm.vp.maxnum.v4f64(<4 x double> %va, <4 x double> %vb, <4 x i1> %m, i32 %evl)
336   ret <4 x double> %v
339 declare <8 x double> @llvm.vp.maxnum.v8f64(<8 x double>, <8 x double>, <8 x i1>, i32)
341 define <8 x double> @vfmax_vv_v8f64(<8 x double> %va, <8 x double> %vb, <8 x i1> %m, i32 zeroext %evl) {
342 ; CHECK-LABEL: vfmax_vv_v8f64:
343 ; CHECK:       # %bb.0:
344 ; CHECK-NEXT:    vsetvli zero, a0, e64, m4, ta, ma
345 ; CHECK-NEXT:    vfmax.vv v8, v8, v12, v0.t
346 ; CHECK-NEXT:    ret
347   %v = call <8 x double> @llvm.vp.maxnum.v8f64(<8 x double> %va, <8 x double> %vb, <8 x i1> %m, i32 %evl)
348   ret <8 x double> %v
351 define <8 x double> @vfmax_vv_v8f64_unmasked(<8 x double> %va, <8 x double> %vb, i32 zeroext %evl) {
352 ; CHECK-LABEL: vfmax_vv_v8f64_unmasked:
353 ; CHECK:       # %bb.0:
354 ; CHECK-NEXT:    vsetvli zero, a0, e64, m4, ta, ma
355 ; CHECK-NEXT:    vfmax.vv v8, v8, v12
356 ; CHECK-NEXT:    ret
357   %head = insertelement <8 x i1> poison, i1 true, i32 0
358   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
359   %v = call <8 x double> @llvm.vp.maxnum.v8f64(<8 x double> %va, <8 x double> %vb, <8 x i1> %m, i32 %evl)
360   ret <8 x double> %v
363 declare <15 x double> @llvm.vp.maxnum.v15f64(<15 x double>, <15 x double>, <15 x i1>, i32)
365 define <15 x double> @vfmax_vv_v15f64(<15 x double> %va, <15 x double> %vb, <15 x i1> %m, i32 zeroext %evl) {
366 ; CHECK-LABEL: vfmax_vv_v15f64:
367 ; CHECK:       # %bb.0:
368 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
369 ; CHECK-NEXT:    vfmax.vv v8, v8, v16, v0.t
370 ; CHECK-NEXT:    ret
371   %v = call <15 x double> @llvm.vp.maxnum.v15f64(<15 x double> %va, <15 x double> %vb, <15 x i1> %m, i32 %evl)
372   ret <15 x double> %v
375 define <15 x double> @vfmax_vv_v15f64_unmasked(<15 x double> %va, <15 x double> %vb, i32 zeroext %evl) {
376 ; CHECK-LABEL: vfmax_vv_v15f64_unmasked:
377 ; CHECK:       # %bb.0:
378 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
379 ; CHECK-NEXT:    vfmax.vv v8, v8, v16
380 ; CHECK-NEXT:    ret
381   %head = insertelement <15 x i1> poison, i1 true, i32 0
382   %m = shufflevector <15 x i1> %head, <15 x i1> poison, <15 x i32> zeroinitializer
383   %v = call <15 x double> @llvm.vp.maxnum.v15f64(<15 x double> %va, <15 x double> %vb, <15 x i1> %m, i32 %evl)
384   ret <15 x double> %v
387 declare <16 x double> @llvm.vp.maxnum.v16f64(<16 x double>, <16 x double>, <16 x i1>, i32)
389 define <16 x double> @vfmax_vv_v16f64(<16 x double> %va, <16 x double> %vb, <16 x i1> %m, i32 zeroext %evl) {
390 ; CHECK-LABEL: vfmax_vv_v16f64:
391 ; CHECK:       # %bb.0:
392 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
393 ; CHECK-NEXT:    vfmax.vv v8, v8, v16, v0.t
394 ; CHECK-NEXT:    ret
395   %v = call <16 x double> @llvm.vp.maxnum.v16f64(<16 x double> %va, <16 x double> %vb, <16 x i1> %m, i32 %evl)
396   ret <16 x double> %v
399 define <16 x double> @vfmax_vv_v16f64_unmasked(<16 x double> %va, <16 x double> %vb, i32 zeroext %evl) {
400 ; CHECK-LABEL: vfmax_vv_v16f64_unmasked:
401 ; CHECK:       # %bb.0:
402 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
403 ; CHECK-NEXT:    vfmax.vv v8, v8, v16
404 ; CHECK-NEXT:    ret
405   %head = insertelement <16 x i1> poison, i1 true, i32 0
406   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
407   %v = call <16 x double> @llvm.vp.maxnum.v16f64(<16 x double> %va, <16 x double> %vb, <16 x i1> %m, i32 %evl)
408   ret <16 x double> %v
411 declare <32 x double> @llvm.vp.maxnum.v32f64(<32 x double>, <32 x double>, <32 x i1>, i32)
413 define <32 x double> @vfmax_vv_v32f64(<32 x double> %va, <32 x double> %vb, <32 x i1> %m, i32 zeroext %evl) {
414 ; CHECK-LABEL: vfmax_vv_v32f64:
415 ; CHECK:       # %bb.0:
416 ; CHECK-NEXT:    addi sp, sp, -16
417 ; CHECK-NEXT:    .cfi_def_cfa_offset 16
418 ; CHECK-NEXT:    csrr a1, vlenb
419 ; CHECK-NEXT:    slli a1, a1, 3
420 ; CHECK-NEXT:    sub sp, sp, a1
421 ; CHECK-NEXT:    .cfi_escape 0x0f, 0x0d, 0x72, 0x00, 0x11, 0x10, 0x22, 0x11, 0x08, 0x92, 0xa2, 0x38, 0x00, 0x1e, 0x22 # sp + 16 + 8 * vlenb
422 ; CHECK-NEXT:    addi a1, a0, 128
423 ; CHECK-NEXT:    vsetivli zero, 16, e64, m8, ta, ma
424 ; CHECK-NEXT:    vle64.v v24, (a1)
425 ; CHECK-NEXT:    addi a1, sp, 16
426 ; CHECK-NEXT:    vs8r.v v24, (a1) # Unknown-size Folded Spill
427 ; CHECK-NEXT:    vsetivli zero, 2, e8, mf4, ta, ma
428 ; CHECK-NEXT:    vslidedown.vi v1, v0, 2
429 ; CHECK-NEXT:    vsetivli zero, 16, e64, m8, ta, ma
430 ; CHECK-NEXT:    vle64.v v24, (a0)
431 ; CHECK-NEXT:    li a1, 16
432 ; CHECK-NEXT:    mv a0, a2
433 ; CHECK-NEXT:    bltu a2, a1, .LBB26_2
434 ; CHECK-NEXT:  # %bb.1:
435 ; CHECK-NEXT:    li a0, 16
436 ; CHECK-NEXT:  .LBB26_2:
437 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
438 ; CHECK-NEXT:    vfmax.vv v8, v8, v24, v0.t
439 ; CHECK-NEXT:    addi a0, a2, -16
440 ; CHECK-NEXT:    sltu a1, a2, a0
441 ; CHECK-NEXT:    addi a1, a1, -1
442 ; CHECK-NEXT:    and a0, a1, a0
443 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
444 ; CHECK-NEXT:    vmv1r.v v0, v1
445 ; CHECK-NEXT:    addi a0, sp, 16
446 ; CHECK-NEXT:    vl8r.v v24, (a0) # Unknown-size Folded Reload
447 ; CHECK-NEXT:    vfmax.vv v16, v16, v24, v0.t
448 ; CHECK-NEXT:    csrr a0, vlenb
449 ; CHECK-NEXT:    slli a0, a0, 3
450 ; CHECK-NEXT:    add sp, sp, a0
451 ; CHECK-NEXT:    addi sp, sp, 16
452 ; CHECK-NEXT:    ret
453   %v = call <32 x double> @llvm.vp.maxnum.v32f64(<32 x double> %va, <32 x double> %vb, <32 x i1> %m, i32 %evl)
454   ret <32 x double> %v
457 define <32 x double> @vfmax_vv_v32f64_unmasked(<32 x double> %va, <32 x double> %vb, i32 zeroext %evl) {
458 ; CHECK-LABEL: vfmax_vv_v32f64_unmasked:
459 ; CHECK:       # %bb.0:
460 ; CHECK-NEXT:    addi a1, a0, 128
461 ; CHECK-NEXT:    vsetivli zero, 16, e64, m8, ta, ma
462 ; CHECK-NEXT:    vle64.v v24, (a1)
463 ; CHECK-NEXT:    vle64.v v0, (a0)
464 ; CHECK-NEXT:    li a1, 16
465 ; CHECK-NEXT:    mv a0, a2
466 ; CHECK-NEXT:    bltu a2, a1, .LBB27_2
467 ; CHECK-NEXT:  # %bb.1:
468 ; CHECK-NEXT:    li a0, 16
469 ; CHECK-NEXT:  .LBB27_2:
470 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
471 ; CHECK-NEXT:    vfmax.vv v8, v8, v0
472 ; CHECK-NEXT:    addi a0, a2, -16
473 ; CHECK-NEXT:    sltu a1, a2, a0
474 ; CHECK-NEXT:    addi a1, a1, -1
475 ; CHECK-NEXT:    and a0, a1, a0
476 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
477 ; CHECK-NEXT:    vfmax.vv v16, v16, v24
478 ; CHECK-NEXT:    ret
479   %head = insertelement <32 x i1> poison, i1 true, i32 0
480   %m = shufflevector <32 x i1> %head, <32 x i1> poison, <32 x i32> zeroinitializer
481   %v = call <32 x double> @llvm.vp.maxnum.v32f64(<32 x double> %va, <32 x double> %vb, <32 x i1> %m, i32 %evl)
482   ret <32 x double> %v