VADD.VV

RISC-V VADD.VV 指令详解

指令手册R-type

逐元素执行整数加法:vd[i] = vs2[i] + vs1[i]。

指令语法

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

指令行为说明

VADD.VV 执行 RVV 单宽整数加法。结果按当前 SEW 宽度保留低位,整数溢出不会产生异常;需要饱和语义时应使用饱和加法类指令。

快速理解与检索要点

VADD.VV 是普通向量整数加法,不使用定点舍入 CSR。每个活动元素按 SEW 宽度求和并写入 vd。

溢出按二进制补码低 SEW 位回绕,不设置异常标志。
只对 vl 范围内的活动元素执行;非活动元素和尾部元素受当前 vma/vta 策略影响。
除专用掩码指令外,vm=0 使用 v0 作为执行掩码,vm=1 表示不使用掩码。

常见使用场景

向量化循环

结合 «vsetvli t0, a0, e32, m1, ta, ma vadd.vv v1, v2, v3» 等实际代码理解该场景。

数组运算

结合 «vsetvli t0, a0, e32, m1, ta, ma vadd.vv v1, v2, v3» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

所有操作数EEW=SEW,EMUL=LMUL。溢出静默忽略(仅保留低SEW位)。需要饱和加法用vsadd。

常见问题

它会使用 vxrm 舍入吗?

不会。VADD 是普通整数加法;vxrm 用于定点舍入指令。