; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -mtriple=riscv32 -mattr=+d,+zfh,+zvfh,+v,+m -target-abi=ilp32d \ ; RUN: -verify-machineinstrs < %s | FileCheck %s --check-prefixes=ZVFH ; RUN: llc -mtriple=riscv64 -mattr=+d,+zfh,+zvfh,+v,+m -target-abi=lp64d \ ; RUN: -verify-machineinstrs < %s | FileCheck %s --check-prefixes=ZVFH ; RUN: llc -mtriple=riscv32 -mattr=+d,+zfh,+zvfhmin,+v,+m -target-abi=ilp32d \ ; RUN: -verify-machineinstrs < %s | FileCheck %s --check-prefixes=ZVFHMIN ; RUN: llc -mtriple=riscv64 -mattr=+d,+zfh,+zvfhmin,+v,+m -target-abi=lp64d \ ; RUN: -verify-machineinstrs < %s | FileCheck %s --check-prefixes=ZVFHMIN declare @llvm.vp.fma.nxv1f32(, , , , i32) declare @llvm.vp.fneg.nxv1f32(, , i32) declare @llvm.vp.fpext.nxv1f32.nxv1f16(, , i32) declare @llvm.vp.merge.nxv1f32(, , , i32) define @vmfsac_vv_nxv1f32( %a, %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv1f32: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFH-NEXT: vfwmsac.vv v10, v8, v9, v0.t ; ZVFH-NEXT: vmv1r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv1f32: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v11, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v9, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, mf2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v11, v10, v0.t ; ZVFHMIN-NEXT: ret %aext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %a, %m, i32 %evl) %bext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %b, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv1f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv1f32( %aext, %bext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vv_nxv1f32_unmasked( %a, %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv1f32_unmasked: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFH-NEXT: vfwmsac.vv v10, v8, v9 ; ZVFH-NEXT: vmv1r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv1f32_unmasked: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v11, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v9 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, mf2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v11, v10 ; ZVFHMIN-NEXT: ret %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %a, %allones, i32 %evl) %bext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %b, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv1f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv1f32( %aext, %bext, %negc, %allones, i32 %evl) ret %v } define @vmfsac_vv_nxv1f32_tu( %a, %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv1f32_tu: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf4, tu, mu ; ZVFH-NEXT: vfwmsac.vv v10, v8, v9, v0.t ; ZVFH-NEXT: vmv1r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv1f32_tu: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v11, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v9 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, mf2, tu, mu ; ZVFHMIN-NEXT: vfmsac.vv v10, v11, v8, v0.t ; ZVFHMIN-NEXT: vmv1r.v v8, v10 ; ZVFHMIN-NEXT: ret %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %a, %allones, i32 %evl) %bext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %b, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv1f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv1f32( %aext, %bext, %negc, %allones, i32 %evl) %u = call @llvm.vp.merge.nxv1f32( %m, %v, %c, i32 %evl) ret %u } define @vmfsac_vv_nxv1f32_unmasked_tu( %a, %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv1f32_unmasked_tu: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf4, tu, ma ; ZVFH-NEXT: vfwmsac.vv v10, v8, v9 ; ZVFH-NEXT: vmv1r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv1f32_unmasked_tu: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v11, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v9 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, mf2, tu, ma ; ZVFHMIN-NEXT: vfmsac.vv v10, v11, v8 ; ZVFHMIN-NEXT: vmv1r.v v8, v10 ; ZVFHMIN-NEXT: ret %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %a, %allones, i32 %evl) %bext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %b, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv1f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv1f32( %aext, %bext, %negc, %allones, i32 %evl) %u = call @llvm.vp.merge.nxv1f32( %allones, %v, %c, i32 %evl) ret %u } define @vmfsac_vf_nxv1f32( %a, half %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv1f32: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFH-NEXT: vfwmsac.vf v9, fa0, v8, v0.t ; ZVFH-NEXT: vmv1r.v v8, v9 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv1f32: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, mf2, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v10, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v11, v10 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v10, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v11, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, mf2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v10, v9, v0.t ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %a, %m, i32 %evl) %vbext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %vb, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv1f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv1f32( %aext, %vbext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vf_nxv1f32_commute( %a, half %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv1f32_commute: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFH-NEXT: vfwmsac.vf v9, fa0, v8, v0.t ; ZVFH-NEXT: vmv1r.v v8, v9 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv1f32_commute: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, mf2, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v10, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v11, v10 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v10, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v11, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, mf2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v10, v8, v9, v0.t ; ZVFHMIN-NEXT: vmv1r.v v8, v10 ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %a, %m, i32 %evl) %vbext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %vb, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv1f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv1f32( %vbext, %aext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vf_nxv1f32_unmasked( %a, half %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv1f32_unmasked: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFH-NEXT: vfwmsac.vf v9, fa0, v8 ; ZVFH-NEXT: vmv1r.v v8, v9 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv1f32_unmasked: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, mf2, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v10, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v11, v10 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf4, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v10, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v11 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, mf2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v10, v9 ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %a, %allones, i32 %evl) %vbext = call @llvm.vp.fpext.nxv1f32.nxv1f16( %vb, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv1f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv1f32( %aext, %vbext, %negc, %allones, i32 %evl) ret %v } declare @llvm.vp.fma.nxv2f32(, , , , i32) declare @llvm.vp.fneg.nxv2f32(, , i32) declare @llvm.vp.fpext.nxv2f32.nxv2f16(, , i32) define @vmfsac_vv_nxv2f32( %a, %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv2f32: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFH-NEXT: vfwmsac.vv v10, v8, v9, v0.t ; ZVFH-NEXT: vmv1r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv2f32: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v11, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v9, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m1, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v11, v10, v0.t ; ZVFHMIN-NEXT: ret %aext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %a, %m, i32 %evl) %bext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %b, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv2f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv2f32( %aext, %bext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vv_nxv2f32_unmasked( %a, %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv2f32_unmasked: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFH-NEXT: vfwmsac.vv v10, v8, v9 ; ZVFH-NEXT: vmv1r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv2f32_unmasked: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v11, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v9 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m1, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v11, v10 ; ZVFHMIN-NEXT: ret %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %a, %allones, i32 %evl) %bext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %b, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv2f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv2f32( %aext, %bext, %negc, %allones, i32 %evl) ret %v } define @vmfsac_vf_nxv2f32( %a, half %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv2f32: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFH-NEXT: vfwmsac.vf v9, fa0, v8, v0.t ; ZVFH-NEXT: vmv1r.v v8, v9 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv2f32: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m1, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v10, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, mf2, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v11, v10 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v10, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v11, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m1, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v10, v9, v0.t ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %a, %m, i32 %evl) %vbext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %vb, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv2f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv2f32( %aext, %vbext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vf_nxv2f32_commute( %a, half %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv2f32_commute: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFH-NEXT: vfwmsac.vf v9, fa0, v8, v0.t ; ZVFH-NEXT: vmv1r.v v8, v9 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv2f32_commute: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m1, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v10, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, mf2, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v11, v10 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v10, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v11, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m1, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v10, v8, v9, v0.t ; ZVFHMIN-NEXT: vmv.v.v v8, v10 ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %a, %m, i32 %evl) %vbext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %vb, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv2f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv2f32( %vbext, %aext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vf_nxv2f32_unmasked( %a, half %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv2f32_unmasked: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFH-NEXT: vfwmsac.vf v9, fa0, v8 ; ZVFH-NEXT: vmv1r.v v8, v9 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv2f32_unmasked: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m1, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v10, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, mf2, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v11, v10 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, mf2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v10, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v11 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m1, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v10, v9 ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %a, %allones, i32 %evl) %vbext = call @llvm.vp.fpext.nxv2f32.nxv2f16( %vb, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv2f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv2f32( %aext, %vbext, %negc, %allones, i32 %evl) ret %v } declare @llvm.vp.fma.nxv4f32(, , , , i32) declare @llvm.vp.fneg.nxv4f32(, , i32) declare @llvm.vp.fpext.nxv4f32.nxv4f16(, , i32) define @vmfsac_vv_nxv4f32( %a, %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv4f32: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFH-NEXT: vfwmsac.vv v10, v8, v9, v0.t ; ZVFH-NEXT: vmv2r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv4f32: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v14, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v12, v9, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v12, v14, v10, v0.t ; ZVFHMIN-NEXT: vmv.v.v v8, v12 ; ZVFHMIN-NEXT: ret %aext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %a, %m, i32 %evl) %bext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %b, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv4f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv4f32( %aext, %bext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vv_nxv4f32_unmasked( %a, %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv4f32_unmasked: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFH-NEXT: vfwmsac.vv v10, v8, v9 ; ZVFH-NEXT: vmv2r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv4f32_unmasked: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v14, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v12, v9 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v12, v14, v10 ; ZVFHMIN-NEXT: vmv.v.v v8, v12 ; ZVFHMIN-NEXT: ret %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %a, %allones, i32 %evl) %bext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %b, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv4f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv4f32( %aext, %bext, %negc, %allones, i32 %evl) ret %v } define @vmfsac_vf_nxv4f32( %a, half %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv4f32: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFH-NEXT: vfwmsac.vf v10, fa0, v8, v0.t ; ZVFH-NEXT: vmv2r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv4f32: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m2, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v12, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, m1, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v14, v12 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v12, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v14, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v12, v10, v0.t ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %a, %m, i32 %evl) %vbext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %vb, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv4f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv4f32( %aext, %vbext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vf_nxv4f32_commute( %a, half %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv4f32_commute: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFH-NEXT: vfwmsac.vf v10, fa0, v8, v0.t ; ZVFH-NEXT: vmv2r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv4f32_commute: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m2, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v12, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, m1, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v9, v12 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v12, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v14, v9, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v12, v14, v10, v0.t ; ZVFHMIN-NEXT: vmv.v.v v8, v12 ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %a, %m, i32 %evl) %vbext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %vb, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv4f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv4f32( %vbext, %aext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vf_nxv4f32_unmasked( %a, half %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv4f32_unmasked: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFH-NEXT: vfwmsac.vf v10, fa0, v8 ; ZVFH-NEXT: vmv2r.v v8, v10 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv4f32_unmasked: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m2, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v12, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, m1, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v14, v12 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m1, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v12, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v14 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m2, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v12, v10 ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %a, %allones, i32 %evl) %vbext = call @llvm.vp.fpext.nxv4f32.nxv4f16( %vb, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv4f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv4f32( %aext, %vbext, %negc, %allones, i32 %evl) ret %v } declare @llvm.vp.fma.nxv8f32(, , , , i32) declare @llvm.vp.fneg.nxv8f32(, , i32) declare @llvm.vp.fpext.nxv8f32.nxv8f16(, , i32) define @vmfsac_vv_nxv8f32( %a, %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv8f32: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFH-NEXT: vfwmsac.vv v12, v8, v10, v0.t ; ZVFH-NEXT: vmv4r.v v8, v12 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv8f32: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v20, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v16, v10, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m4, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v16, v20, v12, v0.t ; ZVFHMIN-NEXT: vmv.v.v v8, v16 ; ZVFHMIN-NEXT: ret %aext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %a, %m, i32 %evl) %bext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %b, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv8f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv8f32( %aext, %bext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vv_nxv8f32_unmasked( %a, %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vv_nxv8f32_unmasked: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFH-NEXT: vfwmsac.vv v12, v8, v10 ; ZVFH-NEXT: vmv4r.v v8, v12 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vv_nxv8f32_unmasked: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v20, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v16, v10 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m4, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v16, v20, v12 ; ZVFHMIN-NEXT: vmv.v.v v8, v16 ; ZVFHMIN-NEXT: ret %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %a, %allones, i32 %evl) %bext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %b, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv8f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv8f32( %aext, %bext, %negc, %allones, i32 %evl) ret %v } define @vmfsac_vf_nxv8f32( %a, half %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv8f32: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFH-NEXT: vfwmsac.vf v12, fa0, v8, v0.t ; ZVFH-NEXT: vmv4r.v v8, v12 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv8f32: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m4, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v16, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, m2, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v20, v16 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v16, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v20, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m4, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v16, v12, v0.t ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %a, %m, i32 %evl) %vbext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %vb, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv8f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv8f32( %aext, %vbext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vf_nxv8f32_commute( %a, half %b, %c, %m, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv8f32_commute: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFH-NEXT: vfwmsac.vf v12, fa0, v8, v0.t ; ZVFH-NEXT: vmv4r.v v8, v12 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv8f32_commute: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m4, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v16, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, m2, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v10, v16 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v16, v8, v0.t ; ZVFHMIN-NEXT: vfwcvt.f.f.v v20, v10, v0.t ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m4, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v16, v20, v12, v0.t ; ZVFHMIN-NEXT: vmv.v.v v8, v16 ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %a, %m, i32 %evl) %vbext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %vb, %m, i32 %evl) %negc = call @llvm.vp.fneg.nxv8f32( %c, %m, i32 %evl) %v = call @llvm.vp.fma.nxv8f32( %vbext, %aext, %negc, %m, i32 %evl) ret %v } define @vmfsac_vf_nxv8f32_unmasked( %a, half %b, %c, i32 zeroext %evl) { ; ZVFH-LABEL: vmfsac_vf_nxv8f32_unmasked: ; ZVFH: # %bb.0: ; ZVFH-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFH-NEXT: vfwmsac.vf v12, fa0, v8 ; ZVFH-NEXT: vmv4r.v v8, v12 ; ZVFH-NEXT: ret ; ; ZVFHMIN-LABEL: vmfsac_vf_nxv8f32_unmasked: ; ZVFHMIN: # %bb.0: ; ZVFHMIN-NEXT: fcvt.s.h fa5, fa0 ; ZVFHMIN-NEXT: vsetvli a1, zero, e32, m4, ta, ma ; ZVFHMIN-NEXT: vfmv.v.f v16, fa5 ; ZVFHMIN-NEXT: vsetvli zero, zero, e16, m2, ta, ma ; ZVFHMIN-NEXT: vfncvt.f.f.w v20, v16 ; ZVFHMIN-NEXT: vsetvli zero, a0, e16, m2, ta, ma ; ZVFHMIN-NEXT: vfwcvt.f.f.v v16, v8 ; ZVFHMIN-NEXT: vfwcvt.f.f.v v8, v20 ; ZVFHMIN-NEXT: vsetvli zero, zero, e32, m4, ta, ma ; ZVFHMIN-NEXT: vfmsub.vv v8, v16, v12 ; ZVFHMIN-NEXT: ret %elt.head = insertelement poison, half %b, i32 0 %vb = shufflevector %elt.head, poison, zeroinitializer %splat = insertelement poison, i1 -1, i32 0 %allones = shufflevector %splat, poison, zeroinitializer %aext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %a, %allones, i32 %evl) %vbext = call @llvm.vp.fpext.nxv8f32.nxv8f16( %vb, %allones, i32 %evl) %negc = call @llvm.vp.fneg.nxv8f32( %c, %allones, i32 %evl) %v = call @llvm.vp.fma.nxv8f32( %aext, %vbext, %negc, %allones, i32 %evl) ret %v }