首页/指令库/VMADC-VVM
VMADC.VVM

RISC-V VMADC.VVM 指令详解

指令手册R-type

计算逐元素加法进位,并把布尔结果写入目标掩码 vd。

指令语法

vmadc.vvm vd, vs2, vs1, v0.t
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
V向量整数运算进位/借位

指令行为说明

VMADC.VVM 是 RISC-V V 扩展的向量加法进位输出指令。它不写整数和,而是把每个元素的进位输出写成目标掩码位。带 m 后缀的形式使用 v0.mask[i] 作为进位/借位输入。目标寄存器是掩码寄存器,不能理解为普通 SEW 宽整数结果。

快速理解与检索要点

VMADC.VVM 生成进位掩码;v0 在带 m 形式中是输入进位/借位,不是普通执行掩码。

目标 vd 保存一位掩码结果,每个元素一位。
带 m 后缀形式的 v0.mask[i] 是算术输入;该指令不是用 v0 过滤执行元素。
与 VADC/VSBC 配合可实现多字精度加减。

常见使用场景

多精度加法

结合 «vmadc.vvm v1, v2, v3, v0.t» 等实际代码理解该场景。

大整数运算

结合 «vmadc.vvm v1, v2, v3, v0.t» 等实际代码理解该场景。

进位传递

结合 «vmadc.vvm v1, v2, v3, v0.t» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

编码带 m 后缀操作所有 body 元素,v0 是进位/借位输入——非正常掩码语义
进位入只能来自 v0;进位出写入目标掩码 vd
多精度模式:vmadc.vvm→vadc.vvm→vmmv.m循环传递进位

常见问题

VMADC.VVM 会写出加法/减法结果吗?

不会。它只写进位或借位的掩码位;整数结果由 VADC/VSBC 等数据指令产生。