C.FLDSP

RISC-V C.FLDSP 指令详解

指令手册C-type

从栈指针+偏移加载双精度浮点。CI格式,RV32DC/RV64DC。

指令语法

c.fldsp fd, offset(sp)
操作数说明
压缩指令仅 16 位,寄存器选择通常限制在 x8–x15。
立即数字段较窄,查看特定压缩指令的完整编码。
CD压缩指令

指令行为说明

c.fldsp 从 sp + 零扩展的 8 字节缩放偏移加载 64 位双精度值到浮点 fd。

快速理解与检索要点

c.fldsp 从 sp + 零扩展的 8 字节缩放偏移加载 64 位双精度值到浮点 fd。

这是 C 扩展真实 16 位访存编码,语义对应 FLD/FLW/FSD/FSW 族的浮点访存。
基址固定为 x2/sp,目标可为浮点寄存器;需要 D 与 C。
偏移量是零扩展并按访问宽度缩放编码,不是任意字节立即数。

常见使用场景

寄存器操作

结合 «c.fldsp f0, 16(sp) # f0 = *(sp+16)» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

基址固定为 x2/sp,目标可为浮点寄存器;需要 D 与 C。
偏移量是零扩展并按访问宽度缩放编码,不是任意字节立即数。

常见问题

c.fldsp 的偏移单位是什么?

编码中的立即数按访问宽度缩放:双精度按 8 字节,单精度按 4 字节。

c.fldsp 是否需要浮点扩展?

需要相应浮点扩展:双精度形式需要 D,单精度形式需要 F,并且都需要 C。