首页/指令库/VFIRST-M
VFIRST.M

RISC-V VFIRST.M 指令详解

指令手册R-type

在vs2掩码中查找最低位被置1的位置,结果写入标量rd(-1表示全零)。

指令语法

vfirst.m rd, vs2, vm
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
V向量运算掩码操作

指令行为说明

VFIRST.M 在掩码源 vs2 中查找最低编号的置 1 活动元素,将元素索引写入整数寄存器 rd;没有找到时写 -1。

快速理解与检索要点

VFIRST.M 是掩码到标量的 RVV 指令,结果写入整数寄存器 rd,而不是向量寄存器。

源操作数是掩码寄存器视图;元素是否参与还受 vl 和可选执行掩码影响。
只对 vl 范围内的活动元素执行;非活动元素和尾部元素受当前 vma/vta 策略影响。
除专用掩码指令外,vm=0 使用 v0 作为执行掩码,vm=1 表示不使用掩码。
浮点运算遵循向量浮点章节:普通浮点运算使用 frm 舍入并设置浮点异常标志;定点 vxrm 不控制这些指令。

常见使用场景

条件循环控制

结合 «vsetvli t0, a0, e32, m1, ta, ma vmseq.vv v0, v8, v9 vfirst.m a0, v0» 等实际代码理解该场景。

掩码遍历

结合 «vsetvli t0, a0, e32, m1, ta, ma vmseq.vv v0, v8, v9 vfirst.m a0, v0» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

结果写入rd(x寄存器),非向量寄存器。vs2为掩码源(不限v0)。无匹配返回-1。

常见问题

结果写到哪里?

写入标量整数寄存器 rd。VCPOP.M 写计数,VFIRST.M 写第一个置位元素的索引或 -1。