aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/vfnmacc_vf.h
blob: 1b99302c6c9195f34f990baa5672a0f76e910e2b (plain)
1
2
3
4
5
6
7
8
9
10
11
// vfnmacc: vd[i] = -(f[rs1] * vs2[i]) - vd[i]
VI_VFP_VF_LOOP
({
  vd = f16_mulAdd(rs1, f16(vs2.v ^ F16_SIGN), f16(vd.v ^ F16_SIGN));
},
{
  vd = f32_mulAdd(rs1, f32(vs2.v ^ F32_SIGN), f32(vd.v ^ F32_SIGN));
},
{
  vd = f64_mulAdd(rs1, f64(vs2.v ^ F64_SIGN), f64(vd.v ^ F64_SIGN));
})