首页/指令库/VFWSUB-VF
VFWSUB.VF

RISC-V VFWSUB.VF 指令详解

指令手册R-type

窄向量 vs2 减去浮点标量 f[rs1],结果以 2*SEW 宽度写入 vd。

指令语法

vfwsub.vf vd, vs2, rs1, vm
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
VZvfh向量运算浮点

指令行为说明

VFWSUB.VF 是 RISC-V V 扩展的拓宽浮点减法指令。两个输入先扩展到 2*SEW 宽度后相减。结果写入 2*SEW 宽度的 vd 元素,浮点舍入、异常标志和 NaN 处理遵循 RVV 浮点规则。

快速理解与检索要点

VFWSUB.VF 的方向是 vs2 减去 f[rs1];不要把它理解成反向减法。

.VV/.VF 形式先把窄输入拓宽,vd 元素宽度为 2*SEW。
浮点运算使用 frm 或指令规定的浮点舍入规则;vxrm 只用于定点舍入指令。
向量 FP32/FP64 操作需要相应标量 F/D 支持;半精度由对应向量半精度扩展控制。
vm=0 使用 v0 作为执行掩码,vm=1 表示不使用掩码;未活动元素和尾部元素按当前 vma/vta 策略处理。

常见使用场景

高精度差分

结合 «vsetvli t0, a0, e32, m1, ta, ma vfwsub.vf v2, v4, ft0» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

目标EMUL=2*LMUL需双倍寄存器。掩码由v0控制。注意操作数顺序vs2-(scalar/vector)。
向量 FP32/FP64 操作需要对应的标量 F/D 支持;仅有 V 并不意味着支持 FP16。

常见问题

VFWSUB.VF 的目标寄存器宽度是多少?

它写入 2*SEW 宽度的浮点结果,因此目标寄存器组占用按拓宽结果计算。

VFWSUB.VF 如何处理掩码?

vm=0 时用 v0 选择活动元素,vm=1 时所有 body 元素都参与;非活动和尾部元素按当前策略处理。