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

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

指令手册R-type

将双精度转无符号32位整数:rd = (uint32_t)f[rs1]。

指令语法

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

指令行为说明

fcvt.wu.d 将双精度浮点源操作数转换为无符号 32 位整数结果。浮点到整数转换按 rm 舍入,结果写入整数寄存器 rd。

快速理解与检索要点

fcvt.wu.d 将双精度浮点源操作数转换为无符号 32 位整数结果。浮点到整数转换按 rm 舍入,结果写入整数寄存器 rd。

rs2/fmt 编码选择源和目标格式;汇编助记符中的后缀就是主要语义。
W/WU 32 位整数结果在 RV64 上写入整数寄存器时按官方规则扩展到 XLEN。
超出整数目标范围或 NaN 输入按官方浮点到整数无效转换规则处理,并设置 NV。
源浮点操作数在更宽 FLEN 寄存器中必须满足 NaN-boxing 规则。

常见使用场景

类型转换

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

使用前检查清单

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

容易混淆 / 常见误区

W/WU 32 位整数结果在 RV64 上写入整数寄存器时按官方规则扩展到 XLEN。
超出整数目标范围或 NaN 输入按官方浮点到整数无效转换规则处理,并设置 NV。
源浮点操作数在更宽 FLEN 寄存器中必须满足 NaN-boxing 规则。

常见问题

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

当转换需要舍入时,rm 或动态 frm 决定舍入方向;越界或 NaN 输入走官方无效转换规则。

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

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