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
4 ; RUN: llc -mtriple=riscv64 -mattr=+d,+zfh,+zvfh,+v -target-abi=lp64d \
5 ; RUN: -verify-machineinstrs < %s | FileCheck %s
7 ; This tests a mix of vfmsac and vfmsub by using different operand orders to
8 ; trigger commuting in TwoAddressInstructionPass.
10 declare <vscale x 1 x half> @llvm.experimental.constrained.fma.nxv1f16(<vscale x 1 x half>, <vscale x 1 x half>, <vscale x 1 x half>, metadata, metadata)
12 define <vscale x 1 x half> @vfmsub_vv_nxv1f16(<vscale x 1 x half> %va, <vscale x 1 x half> %vb, <vscale x 1 x half> %vc) strictfp {
13 ; CHECK-LABEL: vfmsub_vv_nxv1f16:
15 ; CHECK-NEXT: vsetvli a0, zero, e16, mf4, ta, ma
16 ; CHECK-NEXT: vfmsub.vv v8, v9, v10
18 %neg = fneg <vscale x 1 x half> %vc
19 %vd = call <vscale x 1 x half> @llvm.experimental.constrained.fma.nxv1f16(<vscale x 1 x half> %va, <vscale x 1 x half> %vb, <vscale x 1 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
20 ret <vscale x 1 x half> %vd
23 define <vscale x 1 x half> @vfmsub_vf_nxv1f16(<vscale x 1 x half> %va, <vscale x 1 x half> %vb, half %c) strictfp {
24 ; CHECK-LABEL: vfmsub_vf_nxv1f16:
26 ; CHECK-NEXT: vsetvli a0, zero, e16, mf4, ta, ma
27 ; CHECK-NEXT: vfmsub.vf v8, fa0, v9
29 %head = insertelement <vscale x 1 x half> poison, half %c, i32 0
30 %splat = shufflevector <vscale x 1 x half> %head, <vscale x 1 x half> poison, <vscale x 1 x i32> zeroinitializer
31 %neg = fneg <vscale x 1 x half> %vb
32 %vd = call <vscale x 1 x half> @llvm.experimental.constrained.fma.nxv1f16(<vscale x 1 x half> %va, <vscale x 1 x half> %splat, <vscale x 1 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
33 ret <vscale x 1 x half> %vd
36 declare <vscale x 2 x half> @llvm.experimental.constrained.fma.nxv2f16(<vscale x 2 x half>, <vscale x 2 x half>, <vscale x 2 x half>, metadata, metadata)
38 define <vscale x 2 x half> @vfmsub_vv_nxv2f16(<vscale x 2 x half> %va, <vscale x 2 x half> %vb, <vscale x 2 x half> %vc) strictfp {
39 ; CHECK-LABEL: vfmsub_vv_nxv2f16:
41 ; CHECK-NEXT: vsetvli a0, zero, e16, mf2, ta, ma
42 ; CHECK-NEXT: vfmsub.vv v8, v10, v9
44 %neg = fneg <vscale x 2 x half> %vb
45 %vd = call <vscale x 2 x half> @llvm.experimental.constrained.fma.nxv2f16(<vscale x 2 x half> %va, <vscale x 2 x half> %vc, <vscale x 2 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
46 ret <vscale x 2 x half> %vd
49 define <vscale x 2 x half> @vfmsub_vf_nxv2f16(<vscale x 2 x half> %va, <vscale x 2 x half> %vb, half %c) strictfp {
50 ; CHECK-LABEL: vfmsub_vf_nxv2f16:
52 ; CHECK-NEXT: vsetvli a0, zero, e16, mf2, ta, ma
53 ; CHECK-NEXT: vfmsac.vf v8, fa0, v9
55 %head = insertelement <vscale x 2 x half> poison, half %c, i32 0
56 %splat = shufflevector <vscale x 2 x half> %head, <vscale x 2 x half> poison, <vscale x 2 x i32> zeroinitializer
57 %neg = fneg <vscale x 2 x half> %va
58 %vd = call <vscale x 2 x half> @llvm.experimental.constrained.fma.nxv2f16(<vscale x 2 x half> %vb, <vscale x 2 x half> %splat, <vscale x 2 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
59 ret <vscale x 2 x half> %vd
62 declare <vscale x 4 x half> @llvm.experimental.constrained.fma.nxv4f16(<vscale x 4 x half>, <vscale x 4 x half>, <vscale x 4 x half>, metadata, metadata)
64 define <vscale x 4 x half> @vfmsub_vv_nxv4f16(<vscale x 4 x half> %va, <vscale x 4 x half> %vb, <vscale x 4 x half> %vc) strictfp {
65 ; CHECK-LABEL: vfmsub_vv_nxv4f16:
67 ; CHECK-NEXT: vsetvli a0, zero, e16, m1, ta, ma
68 ; CHECK-NEXT: vfmsub.vv v8, v9, v10
70 %neg = fneg <vscale x 4 x half> %vc
71 %vd = call <vscale x 4 x half> @llvm.experimental.constrained.fma.nxv4f16(<vscale x 4 x half> %vb, <vscale x 4 x half> %va, <vscale x 4 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
72 ret <vscale x 4 x half> %vd
75 define <vscale x 4 x half> @vfmsub_vf_nxv4f16(<vscale x 4 x half> %va, <vscale x 4 x half> %vb, half %c) strictfp {
76 ; CHECK-LABEL: vfmsub_vf_nxv4f16:
78 ; CHECK-NEXT: vsetvli a0, zero, e16, m1, ta, ma
79 ; CHECK-NEXT: vfmsub.vf v8, fa0, v9
81 %head = insertelement <vscale x 4 x half> poison, half %c, i32 0
82 %splat = shufflevector <vscale x 4 x half> %head, <vscale x 4 x half> poison, <vscale x 4 x i32> zeroinitializer
83 %neg = fneg <vscale x 4 x half> %vb
84 %vd = call <vscale x 4 x half> @llvm.experimental.constrained.fma.nxv4f16(<vscale x 4 x half> %va, <vscale x 4 x half> %splat, <vscale x 4 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
85 ret <vscale x 4 x half> %vd
88 declare <vscale x 8 x half> @llvm.experimental.constrained.fma.nxv8f16(<vscale x 8 x half>, <vscale x 8 x half>, <vscale x 8 x half>, metadata, metadata)
90 define <vscale x 8 x half> @vfmsub_vv_nxv8f16(<vscale x 8 x half> %va, <vscale x 8 x half> %vb, <vscale x 8 x half> %vc) strictfp {
91 ; CHECK-LABEL: vfmsub_vv_nxv8f16:
93 ; CHECK-NEXT: vsetvli a0, zero, e16, m2, ta, ma
94 ; CHECK-NEXT: vfmsac.vv v8, v12, v10
96 %neg = fneg <vscale x 8 x half> %va
97 %vd = call <vscale x 8 x half> @llvm.experimental.constrained.fma.nxv8f16(<vscale x 8 x half> %vb, <vscale x 8 x half> %vc, <vscale x 8 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
98 ret <vscale x 8 x half> %vd
101 define <vscale x 8 x half> @vfmsub_vf_nxv8f16(<vscale x 8 x half> %va, <vscale x 8 x half> %vb, half %c) strictfp {
102 ; CHECK-LABEL: vfmsub_vf_nxv8f16:
104 ; CHECK-NEXT: vsetvli a0, zero, e16, m2, ta, ma
105 ; CHECK-NEXT: vfmsac.vf v8, fa0, v10
107 %head = insertelement <vscale x 8 x half> poison, half %c, i32 0
108 %splat = shufflevector <vscale x 8 x half> %head, <vscale x 8 x half> poison, <vscale x 8 x i32> zeroinitializer
109 %neg = fneg <vscale x 8 x half> %va
110 %vd = call <vscale x 8 x half> @llvm.experimental.constrained.fma.nxv8f16(<vscale x 8 x half> %vb, <vscale x 8 x half> %splat, <vscale x 8 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
111 ret <vscale x 8 x half> %vd
114 declare <vscale x 16 x half> @llvm.experimental.constrained.fma.nxv16f16(<vscale x 16 x half>, <vscale x 16 x half>, <vscale x 16 x half>, metadata, metadata)
116 define <vscale x 16 x half> @vfmsub_vv_nxv16f16(<vscale x 16 x half> %va, <vscale x 16 x half> %vb, <vscale x 16 x half> %vc) strictfp {
117 ; CHECK-LABEL: vfmsub_vv_nxv16f16:
119 ; CHECK-NEXT: vsetvli a0, zero, e16, m4, ta, ma
120 ; CHECK-NEXT: vfmsub.vv v8, v16, v12
122 %neg = fneg <vscale x 16 x half> %vb
123 %vd = call <vscale x 16 x half> @llvm.experimental.constrained.fma.nxv16f16(<vscale x 16 x half> %vc, <vscale x 16 x half> %va, <vscale x 16 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
124 ret <vscale x 16 x half> %vd
127 define <vscale x 16 x half> @vfmsub_vf_nxv16f16(<vscale x 16 x half> %va, <vscale x 16 x half> %vb, half %c) strictfp {
128 ; CHECK-LABEL: vfmsub_vf_nxv16f16:
130 ; CHECK-NEXT: vsetvli a0, zero, e16, m4, ta, ma
131 ; CHECK-NEXT: vfmsub.vf v8, fa0, v12
133 %head = insertelement <vscale x 16 x half> poison, half %c, i32 0
134 %splat = shufflevector <vscale x 16 x half> %head, <vscale x 16 x half> poison, <vscale x 16 x i32> zeroinitializer
135 %neg = fneg <vscale x 16 x half> %vb
136 %vd = call <vscale x 16 x half> @llvm.experimental.constrained.fma.nxv16f16(<vscale x 16 x half> %va, <vscale x 16 x half> %splat, <vscale x 16 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
137 ret <vscale x 16 x half> %vd
140 declare <vscale x 32 x half> @llvm.experimental.constrained.fma.nxv32f16(<vscale x 32 x half>, <vscale x 32 x half>, <vscale x 32 x half>, metadata, metadata)
142 define <vscale x 32 x half> @vfmsub_vv_nxv32f16(<vscale x 32 x half> %va, <vscale x 32 x half> %vb, <vscale x 32 x half> %vc) strictfp {
143 ; CHECK-LABEL: vfmsub_vv_nxv32f16:
145 ; CHECK-NEXT: vl8re16.v v24, (a0)
146 ; CHECK-NEXT: vsetvli a0, zero, e16, m8, ta, ma
147 ; CHECK-NEXT: vfmsac.vv v8, v16, v24
149 %neg = fneg <vscale x 32 x half> %va
150 %vd = call <vscale x 32 x half> @llvm.experimental.constrained.fma.nxv32f16(<vscale x 32 x half> %vc, <vscale x 32 x half> %vb, <vscale x 32 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
151 ret <vscale x 32 x half> %vd
154 define <vscale x 32 x half> @vfmsub_vf_nxv32f16(<vscale x 32 x half> %va, <vscale x 32 x half> %vb, half %c) strictfp {
155 ; CHECK-LABEL: vfmsub_vf_nxv32f16:
157 ; CHECK-NEXT: vsetvli a0, zero, e16, m8, ta, ma
158 ; CHECK-NEXT: vfmsac.vf v8, fa0, v16
160 %head = insertelement <vscale x 32 x half> poison, half %c, i32 0
161 %splat = shufflevector <vscale x 32 x half> %head, <vscale x 32 x half> poison, <vscale x 32 x i32> zeroinitializer
162 %neg = fneg <vscale x 32 x half> %va
163 %vd = call <vscale x 32 x half> @llvm.experimental.constrained.fma.nxv32f16(<vscale x 32 x half> %vb, <vscale x 32 x half> %splat, <vscale x 32 x half> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
164 ret <vscale x 32 x half> %vd
167 declare <vscale x 1 x float> @llvm.experimental.constrained.fma.nxv1f32(<vscale x 1 x float>, <vscale x 1 x float>, <vscale x 1 x float>, metadata, metadata)
169 define <vscale x 1 x float> @vfmsub_vv_nxv1f32(<vscale x 1 x float> %va, <vscale x 1 x float> %vb, <vscale x 1 x float> %vc) strictfp {
170 ; CHECK-LABEL: vfmsub_vv_nxv1f32:
172 ; CHECK-NEXT: vsetvli a0, zero, e32, mf2, ta, ma
173 ; CHECK-NEXT: vfmsub.vv v8, v9, v10
175 %neg = fneg <vscale x 1 x float> %vc
176 %vd = call <vscale x 1 x float> @llvm.experimental.constrained.fma.nxv1f32(<vscale x 1 x float> %va, <vscale x 1 x float> %vb, <vscale x 1 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
177 ret <vscale x 1 x float> %vd
180 define <vscale x 1 x float> @vfmsub_vf_nxv1f32(<vscale x 1 x float> %va, <vscale x 1 x float> %vb, float %c) strictfp {
181 ; CHECK-LABEL: vfmsub_vf_nxv1f32:
183 ; CHECK-NEXT: vsetvli a0, zero, e32, mf2, ta, ma
184 ; CHECK-NEXT: vfmsub.vf v8, fa0, v9
186 %head = insertelement <vscale x 1 x float> poison, float %c, i32 0
187 %splat = shufflevector <vscale x 1 x float> %head, <vscale x 1 x float> poison, <vscale x 1 x i32> zeroinitializer
188 %neg = fneg <vscale x 1 x float> %vb
189 %vd = call <vscale x 1 x float> @llvm.experimental.constrained.fma.nxv1f32(<vscale x 1 x float> %va, <vscale x 1 x float> %splat, <vscale x 1 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
190 ret <vscale x 1 x float> %vd
193 declare <vscale x 2 x float> @llvm.experimental.constrained.fma.nxv2f32(<vscale x 2 x float>, <vscale x 2 x float>, <vscale x 2 x float>, metadata, metadata)
195 define <vscale x 2 x float> @vfmsub_vv_nxv2f32(<vscale x 2 x float> %va, <vscale x 2 x float> %vb, <vscale x 2 x float> %vc) strictfp {
196 ; CHECK-LABEL: vfmsub_vv_nxv2f32:
198 ; CHECK-NEXT: vsetvli a0, zero, e32, m1, ta, ma
199 ; CHECK-NEXT: vfmsub.vv v8, v10, v9
201 %neg = fneg <vscale x 2 x float> %vb
202 %vd = call <vscale x 2 x float> @llvm.experimental.constrained.fma.nxv2f32(<vscale x 2 x float> %va, <vscale x 2 x float> %vc, <vscale x 2 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
203 ret <vscale x 2 x float> %vd
206 define <vscale x 2 x float> @vfmsub_vf_nxv2f32(<vscale x 2 x float> %va, <vscale x 2 x float> %vb, float %c) strictfp {
207 ; CHECK-LABEL: vfmsub_vf_nxv2f32:
209 ; CHECK-NEXT: vsetvli a0, zero, e32, m1, ta, ma
210 ; CHECK-NEXT: vfmsac.vf v8, fa0, v9
212 %head = insertelement <vscale x 2 x float> poison, float %c, i32 0
213 %splat = shufflevector <vscale x 2 x float> %head, <vscale x 2 x float> poison, <vscale x 2 x i32> zeroinitializer
214 %neg = fneg <vscale x 2 x float> %va
215 %vd = call <vscale x 2 x float> @llvm.experimental.constrained.fma.nxv2f32(<vscale x 2 x float> %vb, <vscale x 2 x float> %splat, <vscale x 2 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
216 ret <vscale x 2 x float> %vd
219 declare <vscale x 4 x float> @llvm.experimental.constrained.fma.nxv4f32(<vscale x 4 x float>, <vscale x 4 x float>, <vscale x 4 x float>, metadata, metadata)
221 define <vscale x 4 x float> @vfmsub_vv_nxv4f32(<vscale x 4 x float> %va, <vscale x 4 x float> %vb, <vscale x 4 x float> %vc) strictfp {
222 ; CHECK-LABEL: vfmsub_vv_nxv4f32:
224 ; CHECK-NEXT: vsetvli a0, zero, e32, m2, ta, ma
225 ; CHECK-NEXT: vfmsub.vv v8, v10, v12
227 %neg = fneg <vscale x 4 x float> %vc
228 %vd = call <vscale x 4 x float> @llvm.experimental.constrained.fma.nxv4f32(<vscale x 4 x float> %vb, <vscale x 4 x float> %va, <vscale x 4 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
229 ret <vscale x 4 x float> %vd
232 define <vscale x 4 x float> @vfmsub_vf_nxv4f32(<vscale x 4 x float> %va, <vscale x 4 x float> %vb, float %c) strictfp {
233 ; CHECK-LABEL: vfmsub_vf_nxv4f32:
235 ; CHECK-NEXT: vsetvli a0, zero, e32, m2, ta, ma
236 ; CHECK-NEXT: vfmsub.vf v8, fa0, v10
238 %head = insertelement <vscale x 4 x float> poison, float %c, i32 0
239 %splat = shufflevector <vscale x 4 x float> %head, <vscale x 4 x float> poison, <vscale x 4 x i32> zeroinitializer
240 %neg = fneg <vscale x 4 x float> %vb
241 %vd = call <vscale x 4 x float> @llvm.experimental.constrained.fma.nxv4f32(<vscale x 4 x float> %va, <vscale x 4 x float> %splat, <vscale x 4 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
242 ret <vscale x 4 x float> %vd
245 declare <vscale x 8 x float> @llvm.experimental.constrained.fma.nxv8f32(<vscale x 8 x float>, <vscale x 8 x float>, <vscale x 8 x float>, metadata, metadata)
247 define <vscale x 8 x float> @vfmsub_vv_nxv8f32(<vscale x 8 x float> %va, <vscale x 8 x float> %vb, <vscale x 8 x float> %vc) strictfp {
248 ; CHECK-LABEL: vfmsub_vv_nxv8f32:
250 ; CHECK-NEXT: vsetvli a0, zero, e32, m4, ta, ma
251 ; CHECK-NEXT: vfmsac.vv v8, v16, v12
253 %neg = fneg <vscale x 8 x float> %va
254 %vd = call <vscale x 8 x float> @llvm.experimental.constrained.fma.nxv8f32(<vscale x 8 x float> %vb, <vscale x 8 x float> %vc, <vscale x 8 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
255 ret <vscale x 8 x float> %vd
258 define <vscale x 8 x float> @vfmsub_vf_nxv8f32(<vscale x 8 x float> %va, <vscale x 8 x float> %vb, float %c) strictfp {
259 ; CHECK-LABEL: vfmsub_vf_nxv8f32:
261 ; CHECK-NEXT: vsetvli a0, zero, e32, m4, ta, ma
262 ; CHECK-NEXT: vfmsac.vf v8, fa0, v12
264 %head = insertelement <vscale x 8 x float> poison, float %c, i32 0
265 %splat = shufflevector <vscale x 8 x float> %head, <vscale x 8 x float> poison, <vscale x 8 x i32> zeroinitializer
266 %neg = fneg <vscale x 8 x float> %va
267 %vd = call <vscale x 8 x float> @llvm.experimental.constrained.fma.nxv8f32(<vscale x 8 x float> %vb, <vscale x 8 x float> %splat, <vscale x 8 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
268 ret <vscale x 8 x float> %vd
271 declare <vscale x 16 x float> @llvm.experimental.constrained.fma.nxv16f32(<vscale x 16 x float>, <vscale x 16 x float>, <vscale x 16 x float>, metadata, metadata)
273 define <vscale x 16 x float> @vfmsub_vv_nxv16f32(<vscale x 16 x float> %va, <vscale x 16 x float> %vb, <vscale x 16 x float> %vc) strictfp {
274 ; CHECK-LABEL: vfmsub_vv_nxv16f32:
276 ; CHECK-NEXT: vl8re32.v v24, (a0)
277 ; CHECK-NEXT: vsetvli a0, zero, e32, m8, ta, ma
278 ; CHECK-NEXT: vfmsub.vv v8, v24, v16
280 %neg = fneg <vscale x 16 x float> %vb
281 %vd = call <vscale x 16 x float> @llvm.experimental.constrained.fma.nxv16f32(<vscale x 16 x float> %vc, <vscale x 16 x float> %va, <vscale x 16 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
282 ret <vscale x 16 x float> %vd
285 define <vscale x 16 x float> @vfmsub_vf_nxv16f32(<vscale x 16 x float> %va, <vscale x 16 x float> %vb, float %c) strictfp {
286 ; CHECK-LABEL: vfmsub_vf_nxv16f32:
288 ; CHECK-NEXT: vsetvli a0, zero, e32, m8, ta, ma
289 ; CHECK-NEXT: vfmsub.vf v8, fa0, v16
291 %head = insertelement <vscale x 16 x float> poison, float %c, i32 0
292 %splat = shufflevector <vscale x 16 x float> %head, <vscale x 16 x float> poison, <vscale x 16 x i32> zeroinitializer
293 %neg = fneg <vscale x 16 x float> %vb
294 %vd = call <vscale x 16 x float> @llvm.experimental.constrained.fma.nxv16f32(<vscale x 16 x float> %va, <vscale x 16 x float> %splat, <vscale x 16 x float> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
295 ret <vscale x 16 x float> %vd
298 declare <vscale x 1 x double> @llvm.experimental.constrained.fma.nxv1f64(<vscale x 1 x double>, <vscale x 1 x double>, <vscale x 1 x double>, metadata, metadata)
300 define <vscale x 1 x double> @vfmsub_vv_nxv1f64(<vscale x 1 x double> %va, <vscale x 1 x double> %vb, <vscale x 1 x double> %vc) strictfp {
301 ; CHECK-LABEL: vfmsub_vv_nxv1f64:
303 ; CHECK-NEXT: vsetvli a0, zero, e64, m1, ta, ma
304 ; CHECK-NEXT: vfmsub.vv v8, v9, v10
306 %neg = fneg <vscale x 1 x double> %vc
307 %vd = call <vscale x 1 x double> @llvm.experimental.constrained.fma.nxv1f64(<vscale x 1 x double> %va, <vscale x 1 x double> %vb, <vscale x 1 x double> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
308 ret <vscale x 1 x double> %vd
311 define <vscale x 1 x double> @vfmsub_vf_nxv1f64(<vscale x 1 x double> %va, <vscale x 1 x double> %vb, double %c) strictfp {
312 ; CHECK-LABEL: vfmsub_vf_nxv1f64:
314 ; CHECK-NEXT: vsetvli a0, zero, e64, m1, ta, ma
315 ; CHECK-NEXT: vfmsub.vf v8, fa0, v9
317 %head = insertelement <vscale x 1 x double> poison, double %c, i32 0
318 %splat = shufflevector <vscale x 1 x double> %head, <vscale x 1 x double> poison, <vscale x 1 x i32> zeroinitializer
319 %neg = fneg <vscale x 1 x double> %vb
320 %vd = call <vscale x 1 x double> @llvm.experimental.constrained.fma.nxv1f64(<vscale x 1 x double> %va, <vscale x 1 x double> %splat, <vscale x 1 x double> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
321 ret <vscale x 1 x double> %vd
324 declare <vscale x 2 x double> @llvm.experimental.constrained.fma.nxv2f64(<vscale x 2 x double>, <vscale x 2 x double>, <vscale x 2 x double>, metadata, metadata)
326 define <vscale x 2 x double> @vfmsub_vv_nxv2f64(<vscale x 2 x double> %va, <vscale x 2 x double> %vb, <vscale x 2 x double> %vc) strictfp {
327 ; CHECK-LABEL: vfmsub_vv_nxv2f64:
329 ; CHECK-NEXT: vsetvli a0, zero, e64, m2, ta, ma
330 ; CHECK-NEXT: vfmsub.vv v8, v12, v10
332 %neg = fneg <vscale x 2 x double> %vb
333 %vd = call <vscale x 2 x double> @llvm.experimental.constrained.fma.nxv2f64(<vscale x 2 x double> %va, <vscale x 2 x double> %vc, <vscale x 2 x double> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
334 ret <vscale x 2 x double> %vd
337 define <vscale x 2 x double> @vfmsub_vf_nxv2f64(<vscale x 2 x double> %va, <vscale x 2 x double> %vb, double %c) strictfp {
338 ; CHECK-LABEL: vfmsub_vf_nxv2f64:
340 ; CHECK-NEXT: vsetvli a0, zero, e64, m2, ta, ma
341 ; CHECK-NEXT: vfmsac.vf v8, fa0, v10
343 %head = insertelement <vscale x 2 x double> poison, double %c, i32 0
344 %splat = shufflevector <vscale x 2 x double> %head, <vscale x 2 x double> poison, <vscale x 2 x i32> zeroinitializer
345 %neg = fneg <vscale x 2 x double> %va
346 %vd = call <vscale x 2 x double> @llvm.experimental.constrained.fma.nxv2f64(<vscale x 2 x double> %vb, <vscale x 2 x double> %splat, <vscale x 2 x double> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
347 ret <vscale x 2 x double> %vd
350 declare <vscale x 4 x double> @llvm.experimental.constrained.fma.nxv4f64(<vscale x 4 x double>, <vscale x 4 x double>, <vscale x 4 x double>, metadata, metadata)
352 define <vscale x 4 x double> @vfmsub_vv_nxv4f64(<vscale x 4 x double> %va, <vscale x 4 x double> %vb, <vscale x 4 x double> %vc) strictfp {
353 ; CHECK-LABEL: vfmsub_vv_nxv4f64:
355 ; CHECK-NEXT: vsetvli a0, zero, e64, m4, ta, ma
356 ; CHECK-NEXT: vfmsub.vv v8, v12, v16
358 %neg = fneg <vscale x 4 x double> %vc
359 %vd = call <vscale x 4 x double> @llvm.experimental.constrained.fma.nxv4f64(<vscale x 4 x double> %vb, <vscale x 4 x double> %va, <vscale x 4 x double> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
360 ret <vscale x 4 x double> %vd
363 define <vscale x 4 x double> @vfmsub_vf_nxv4f64(<vscale x 4 x double> %va, <vscale x 4 x double> %vb, double %c) strictfp {
364 ; CHECK-LABEL: vfmsub_vf_nxv4f64:
366 ; CHECK-NEXT: vsetvli a0, zero, e64, m4, ta, ma
367 ; CHECK-NEXT: vfmsub.vf v8, fa0, v12
369 %head = insertelement <vscale x 4 x double> poison, double %c, i32 0
370 %splat = shufflevector <vscale x 4 x double> %head, <vscale x 4 x double> poison, <vscale x 4 x i32> zeroinitializer
371 %neg = fneg <vscale x 4 x double> %vb
372 %vd = call <vscale x 4 x double> @llvm.experimental.constrained.fma.nxv4f64(<vscale x 4 x double> %va, <vscale x 4 x double> %splat, <vscale x 4 x double> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
373 ret <vscale x 4 x double> %vd
376 declare <vscale x 8 x double> @llvm.experimental.constrained.fma.nxv8f64(<vscale x 8 x double>, <vscale x 8 x double>, <vscale x 8 x double>, metadata, metadata)
378 define <vscale x 8 x double> @vfmsub_vv_nxv8f64(<vscale x 8 x double> %va, <vscale x 8 x double> %vb, <vscale x 8 x double> %vc) strictfp {
379 ; CHECK-LABEL: vfmsub_vv_nxv8f64:
381 ; CHECK-NEXT: vl8re64.v v24, (a0)
382 ; CHECK-NEXT: vsetvli a0, zero, e64, m8, ta, ma
383 ; CHECK-NEXT: vfmsac.vv v8, v16, v24
385 %neg = fneg <vscale x 8 x double> %va
386 %vd = call <vscale x 8 x double> @llvm.experimental.constrained.fma.nxv8f64(<vscale x 8 x double> %vb, <vscale x 8 x double> %vc, <vscale x 8 x double> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
387 ret <vscale x 8 x double> %vd
390 define <vscale x 8 x double> @vfmsub_vf_nxv8f64(<vscale x 8 x double> %va, <vscale x 8 x double> %vb, double %c) strictfp {
391 ; CHECK-LABEL: vfmsub_vf_nxv8f64:
393 ; CHECK-NEXT: vsetvli a0, zero, e64, m8, ta, ma
394 ; CHECK-NEXT: vfmsac.vf v8, fa0, v16
396 %head = insertelement <vscale x 8 x double> poison, double %c, i32 0
397 %splat = shufflevector <vscale x 8 x double> %head, <vscale x 8 x double> poison, <vscale x 8 x i32> zeroinitializer
398 %neg = fneg <vscale x 8 x double> %va
399 %vd = call <vscale x 8 x double> @llvm.experimental.constrained.fma.nxv8f64(<vscale x 8 x double> %vb, <vscale x 8 x double> %splat, <vscale x 8 x double> %neg, metadata !"round.dynamic", metadata !"fpexcept.strict")
400 ret <vscale x 8 x double> %vd