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

RISC-V VMERGE.VVM 指令详解

指令手册R-type

按 v0 掩码在 vs2 与向量源之间逐元素选择,写入 vd。

指令语法

vmerge.vvm vd, vs2, vs1, v0.t
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
V向量数据移动合并/选择

指令行为说明

VMERGE.VVM 是 RISC-V V 扩展的向量合并指令。它是显式使用 v0.t 的形式:v0.mask[i]=0 选择 vs2[i],v0.mask[i]=1 选择第二源(向量)。该指令不是普通 vm 执行掩码形式。

快速理解与检索要点

VMERGE 使用 v0.t 作为选择数据:0 取 vs2,1 取第二源。不要把它当作普通 vm=0 执行掩码。

v0 是合并选择掩码,语法中固定写作 v0.t。
移动指令保留源位模式在目标元素中的解释,具体扩展规则由源类型决定。
相关的 masked 选择应使用 vmerge 形式,而不是给 vmv 添加普通执行掩码。

常见使用场景

掩码扩展

结合 «vmerge.vvm v8, v4, v6, v0.t» 等实际代码理解该场景。

条件赋值

结合 «vmerge.vvm v8, v4, v6, v0.t» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

vmerge 使用 v0 作为选择数据;所有 body 元素都会更新,而不是被普通执行掩码关掉
掩码源固定为v0
vm=1+vs2=v0时编码为vmv.v形式,语义完全不同

常见问题

VMERGE.VVM 如何处理掩码?

它没有普通 v0 执行掩码;若语法中出现 mask 操作数,该操作数是数据输入而不是额外执行掩码。