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

RISC-V VFWMUL.VV 指令详解

指令手册R-type

窄浮点操作数相乘,扩展后的 2*SEW 结果写入 vd。

指令语法

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

指令行为说明

VFWMUL.VV 是扩展浮点乘法,不是累加指令。vs1[i] 与 vs2[i] 相乘。结果以 2*SEW 宽度写入 vd。 向量 FP32/FP64 操作需要相应标量 F/D 支持;FP16 由相应向量半精度扩展控制,基础 V 扩展不自动包含半精度算术。

快速理解与检索要点

VFWMUL.VV 只做扩展乘法:窄输入相乘,宽结果写入 vd。

没有旧 vd 累加项;这是它与 VFWMACC/VFWMSAC 的主要区别。
只对 vl 范围内的活动元素执行;非活动元素和尾部元素受当前 vma/vta 策略影响。
vm=0 使用 v0 作为执行掩码,vm=1 表示不使用掩码。
浮点算术和转换遵循 RVV 浮点规则;普通浮点舍入来自 frm,定点 vxrm 不控制这些指令。
向量 FP32/FP64 操作需要相应标量 F/D 支持;FP16 由相应向量半精度扩展控制,基础 V 扩展不自动包含半精度算术。

常见使用场景

高精度矩阵运算

结合 «vsetvli t0, a0, e16, m1, ta, ma vfwmul.vv v2, v4, v6» 等实际代码理解该场景。

混合精度ML

结合 «vsetvli t0, a0, e16, m1, ta, ma vfwmul.vv v2, v4, v6» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

vd 是扩展宽度目的寄存器,不是累加器;需要累加时使用 VFWMACC/VFWMSAC 等指令。
向量 FP32/FP64 操作需要相应标量 F/D 支持;FP16 由相应向量半精度扩展控制,基础 V 扩展不自动包含半精度算术。

常见问题

这些指令使用 vxrm 吗?

不使用。浮点算术和转换使用 frm 或指令规定的固定舍入;vxrm 用于定点舍入指令。