首页/指令库/VCOMPRESS-VM
VCOMPRESS.VM

RISC-V VCOMPRESS.VM 指令详解

指令手册R-type

根据掩码vs1将vs2中被选中的元素连续压缩写入vd起始位置。

指令语法

vcompress.vm vd, vs2, vs1
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
V向量重排/索引置换

指令行为说明

VCOMPRESS.VM 按掩码 vs1 选择 vs2 中的活动元素,并把被选择的元素从 vd 起始处连续写入。它是未掩码指令,不能与执行掩码合用;源/目的寄存器组存在规范限制,避免覆盖尚未读取的源元素。

快速理解与检索要点

VCOMPRESS.VM 按 vs1 掩码保序压缩 vs2 中被选中的元素,并从 vd[0] 开始连续写入。

该指令编码为未掩码形式;vs1 是显式选择掩码,没有额外的 v0 执行掩码。
未被选中的源元素不写入结果;压缩结果之后的目标元素按尾部策略处理。

常见使用场景

稀疏数据压缩

结合 «vsetvli t0, a0, e32, m1, ta, ma vmsgt.vi v0, v8, 10 vcompress.vm v12, v8, v0» 等实际代码理解该场景。

流式压缩

结合 «vsetvli t0, a0, e32, m1, ta, ma vmsgt.vi v0, v8, 10 vcompress.vm v12, v8, v0» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

vs1 是选择掩码操作数,不是普通 v0 执行掩码。
选中元素之后的目标元素属于尾部元素,受 vta 策略影响;不要假定一定保留旧值。
源/目的寄存器组重叠受规范限制。

常见问题

VCOMPRESS.VM 使用 v0 作为执行掩码吗?

不使用。它是未掩码指令,显式的 vs1 操作数才是选择掩码。