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

RISC-V VMACC.VV 指令详解

指令手册R-type

将 vs1/标量 与 vs2 的整数乘积加到旧 vd。

指令语法

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

指令行为说明

VMACC.VV 是 RISC-V V 扩展的破坏性整数乘加指令。它计算 vd[i] = vd[i] + vs2[i] * 第二操作数。乘法和加法按 SEW 宽度产生低位结果,不设置整数异常标志。

快速理解与检索要点

VMACC.VV 只写活动元素;整数溢出保留低 SEW 位,不产生陷入。

向量-标量 `.vx` 形式使用 x[rs1],向量-向量 `.vv` 形式使用 vs1。
结果按 SEW 宽度写入;高半乘法显式返回 2*SEW 乘积的高 SEW 位。
vm=0 使用 v0 作为执行掩码,vm=1 表示不使用掩码;未活动元素和尾部元素按当前 vma/vta 策略处理。

常见使用场景

矩阵乘法

结合 «vsetvli t0, a0, e32, m1, ta, ma vmacc.vv v1, v2, v3 # v1[i] = v2[i]*v3[i] + v1[i]» 等实际代码理解该场景。

信号处理

结合 «vsetvli t0, a0, e32, m1, ta, ma vmacc.vv v1, v2, v3 # v1[i] = v2[i]*v3[i] + v1[i]» 等实际代码理解该场景。

卷积

结合 «vsetvli t0, a0, e32, m1, ta, ma vmacc.vv v1, v2, v3 # v1[i] = v2[i]*v3[i] + v1[i]» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

单宽度MAC——乘积高SEW位被丢弃(不同于扩展乘加vwmacc)。需要全精度时用vwmacc。
操作数顺序:vd = vs1*vs2 + vd。vd同时读写。SEW=8/16位时极易溢出。

常见问题

VMACC.VV 如何处理掩码?

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