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

RISC-V VMSBC.VV 指令详解

指令手册R-type

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

指令语法

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

指令行为说明

VMSBC.VV 是 RISC-V V 扩展的向量减法借位输出指令。它不写整数和,而是把每个元素的借位输出写成目标掩码位。不带 m 后缀的形式没有借位输入,且没有普通执行掩码操作数。目标寄存器是掩码寄存器,不能理解为普通 SEW 宽整数结果。

快速理解与检索要点

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

目标 vd 保存一位掩码结果,每个元素一位。
不带 m 后缀形式不读取 v0 作为进位/借位输入。
与 VADC/VSBC 配合可实现多字精度加减。

常见使用场景

多精度减法

结合 «vmsbc.vv v1, v2, v3» 等实际代码理解该场景。

大整数运算

结合 «vmsbc.vv v1, v2, v3» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

借位定义:截断前差值为负则借位=1
不带 m 后缀时无借位入

常见问题

VMSBC.VV 会写出加法/减法结果吗?

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