首页/指令库/VFMV-F-S
VFMV.F.S

RISC-V VFMV.F.S 指令详解

指令手册R-type

将vs2的元素0(浮点)复制到标量f寄存器rd。

指令语法

vfmv.f.s rd, vs2
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
VZvfh向量运算寄存器移动

指令行为说明

VFMV.F.S 将向量源 vs2 的元素 0 复制到浮点标量寄存器 rd。它是标量搬移,不是逐元素浮点算术,也不执行 FMA。

快速理解与检索要点

VFMV.F.S 是向量元素 0 到浮点标量寄存器的搬移。

不要把它当作受普通执行掩码控制的逐元素向量算术。

常见使用场景

归约结果提取

结合 «vsetvli t0, a0, e32, m1, ta, ma vfmv.f.s ft0, v1 # ft0 = v1[0]» 等实际代码理解该场景。

标量-向量接口

结合 «vsetvli t0, a0, e32, m1, ta, ma vfmv.f.s ft0, v1 # ft0 = v1[0]» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

只复制元素 0,不复制整条向量。
目的寄存器是浮点标量寄存器;整数版本是 VMV.X.S。

常见问题

它会复制整条向量吗?

不会。它只读取 vs2 的元素 0 并写入浮点标量寄存器 rd。