首页/指令库/VRSUB-VI
VRSUB.VI

RISC-V VRSUB.VI 指令详解

指令手册I-type

从立即数中减去向量元素。

指令语法

vrsub.vi vd, vs2, imm, vm
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数所在的寄存器。
立即数 imm:12 位有符号立即数,符号扩展后与 rs1 进行运算。
V向量整数运算算术

指令行为说明

VRSUB.VI 对活动元素计算 signext(imm) - vs2[i],低 SEW 位写入 vd。

快速理解与检索要点

VRSUB.VI 的操作数方向与 VSUB 相反,适合计算“标量/立即数减每个元素”。

结果按 SEW 宽度回绕,不产生整数溢出异常。
VI 形式使用 5 位有符号立即数并扩展到 SEW。
需要向量减标量时使用 VSUB.VX,而不是 VRSUB.VX。

常见使用场景

对称范围计算

结合 «vrsub.vi v8, v12, 7, v0.t» 等实际代码理解该场景。

补码运算

结合 «vrsub.vi v8, v12, 7, v0.t» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

减法顺序反转:立即数/标量-向量(非向量-立即数/标量)

常见问题

VRSUB.VI 和 VSUB 的区别是什么?

VRSUB 是反向减法,计算标量或立即数减 vs2;VSUB 计算 vs2 减另一个操作数。