VID.V

RISC-V VID.V 指令详解

指令手册R-type

把每个活动元素的元素索引 i 写入目标整数向量 vd。

指令语法

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

指令行为说明

VID.V 是 RISC-V V 扩展的元素索引生成指令。对每个活动元素 i,它把无符号索引值 i 写入 vd 元素,索引从 0 开始并受当前 vl 限制。

快速理解与检索要点

VID.V 生成的是元素编号,不读取内存,也不读取普通源向量。

索引值按当前元素编号生成,结果写入 SEW 宽目标元素。
vm=0 使用 v0 作为执行掩码,vm=1 表示不使用掩码;未活动元素和尾部元素按当前 vma/vta 策略处理。
常与掩码比较、压缩或索引访问组合使用。

常见使用场景

序列生成

结合 «vsetvli t0, a0, e32, m1, ta, ma vid.v v1 # v1[i] = i» 等实际代码理解该场景。

循环计数器

结合 «vsetvli t0, a0, e32, m1, ta, ma vid.v v1 # v1[i] = i» 等实际代码理解该场景。

用作gather索引

结合 «vsetvli t0, a0, e32, m1, ta, ma vid.v v1 # v1[i] = i» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

vid.v输出0,1,2,...(基于元素位置)——不是基于寄存器字节偏移。
vs2操作数被忽略但必须指定。掩码为0的元素位置不写入(或被agnostic覆盖)。

常见问题

VID.V 如何处理掩码?

vm=0 时用 v0 选择活动元素,vm=1 时所有 body 元素都参与;非活动和尾部元素按当前策略处理。