首页/指令库/FCVT-Q-WU
FCVT.Q.WU

RISC-V FCVT.Q.WU 指令详解

指令手册R-type

无符号32位整数转四精度。永不舍入。R型,fmt=Q(11),rs2编码源WU(01)。

指令语法

fcvt.q.wu rd, rs1, rm
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
Q浮点转换

指令行为说明

fcvt.q.wu 将无符号 32 位整数转换为四精度浮点结果。该转换是精确转换,因此编码的舍入模式不会改变数值结果。

快速理解与检索要点

fcvt.q.wu 将无符号 32 位整数转换为四精度浮点结果。该转换是精确转换,因此编码的舍入模式不会改变数值结果。

rs2/fmt 编码选择源和目标格式;汇编助记符中的后缀就是主要语义。
该整数到浮点转换是精确的;rm 被编码但不会改变数值结果。
W/WU 形式读取 32 位有符号或无符号整数源值。
整数源操作数来自 x[rs1],不是浮点寄存器,因此没有源 NaN-boxing 要求。
浮点结果在更宽 FLEN 寄存器中按目标格式 NaN-boxed。

常见使用场景

信号处理与DSP

结合 «fcvt.q.wu f0, x10 # f0 = (quad)(unsigned)x10» 等实际代码理解该场景。

浮点基本运算

结合 «fcvt.q.wu f0, x10 # f0 = (quad)(unsigned)x10» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

W/WU 形式读取 32 位有符号或无符号整数源值。
整数源操作数来自 x[rs1],不是浮点寄存器,因此没有源 NaN-boxing 要求。
浮点结果在更宽 FLEN 寄存器中按目标格式 NaN-boxed。

常见问题

fcvt.q.wu 的 rm 什么时候重要?

对该指令的数值结果不重要。源整数可以被目标浮点格式精确表示,因此不会因 rm 发生舍入。

fcvt.q.wu 和同族 FCVT 指令的区别是什么?

区别在源/目标格式、整数有符号性、RV64 限制以及是否可能舍入或触发无效转换。