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

RISC-V VWMACCSU.VV 指令详解

指令手册R-type

有符号乘无符号的宽化整数乘加。

指令语法

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

指令行为说明

VWMACCSU.VV 将有符号 vs1 元素与无符号 vs2 元素相乘,2*SEW 乘积加到宽目标 vd。

快速理解与检索要点

VWMACCSU.VV 是宽化乘加,旧 vd 是 2*SEW 宽累加器。

官方操作数顺序是 vd、乘数源、vs2、vm;VX 形式的标量在 rs1。
乘积宽度为 2*SEW,并加到旧 vd。
VWMACCSU.VV 使用有符号 vs1 与无符号 vs2;不要把符号性写反。

常见使用场景

位操作与掩码

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

向量运算

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

循环与迭代

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

使用前检查清单

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

容易混淆 / 常见误区

旧 vd 是 2*SEW 宽累加器,指令会覆盖它。
符号性是 signed(vs1) * unsigned(vs2),不要写反。
目的寄存器组宽度为 2*SEW,LMUL/EMUL 约束必须合法。

常见问题

VWMACCSU.VV 的目标 vd 是单宽吗?

不是。vd 是 2*SEW 宽累加器,旧 vd 值参与加法。