首页/指令库/VNMSUB-VV
VNMSUB.VV

RISC-V VNMSUB.VV 指令详解

指令手册R-type

向量整数负乘减,目标寄存器同时作为乘法输入。

指令语法

vnmsub.vv vd, vs1, vs2, vm
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
V向量整数运算乘减

指令行为说明

VNMSUB.VV 对活动元素计算 vs2[i] - (vs1[i] * vd[i]),低 SEW 位写回 vd。

快速理解与检索要点

VNMSUB.VV 是破坏性整数乘加类指令;vd 既参与运算又接收结果。

VNMSUB 使用旧 vd 作为一个乘法输入,vs2 是被减数。
结果按 SEW 宽度截断,不产生整数溢出异常。
vm=0 使用 v0 执行掩码;vm=1 为不掩码执行。

常见使用场景

多项式求值

结合 «vnmsub.vv v8, v4, v12, v0.t» 等实际代码理解该场景。

信号处理

结合 «vnmsub.vv v8, v4, v12, v0.t» 等实际代码理解该场景。

使用前检查清单

语法检查
  • 确认当前指令格式为 R-type。
  • 确认操作数排列顺序与示例一致。
语义检查
  • 确认目标寄存器用途和调用约定兼容。
  • 确认该指令不是伪指令展开后的底层形式。

容易混淆 / 常见误区

vnmsub 使用旧 vd 作为一个乘法输入。
vs2 是加到负乘积上的第三操作数。
结果取低 SEW 位,不产生整数溢出异常。

常见问题

VNMSUB.VV 的 vd 是普通只写目标吗?

不是。该类指令是破坏性形式,旧 vd 会作为累加器或乘法输入参与计算。