FMUL.D
RISC-V FMUL.D 指令详解
指令手册R-type双精度浮点乘法:rd = rs1*rs2。
指令语法
fmul.d rd, rs1, rs2, rm
操作数说明
rd:目标浮点寄存器,接收该格式的浮点结果。
rs1/rs2:源浮点寄存器;带 rm 的算术/舍入指令由 rm 或动态 frm 选择舍入模式。
D浮点运算
指令行为说明
FMUL.D 执行双精度浮点乘法:rd = rs1 × rs2。R 型指令,fmt=D(01)。舍入模式由 rm 指定。输入需合法 NaN-boxed。双精度约 15-17 位十进制有效数字。
常见使用场景
数值计算
结合 «fmul.d f0, f1, f2, rne # f0 = f1*f2 (round nearest even)» 等实际代码理解该场景。
科学计算
结合 «fmul.d f0, f1, f2, rne # f0 = f1*f2 (round nearest even)» 等实际代码理解该场景。
浮点基本运算
结合 «fmul.d f0, f1, f2, rne # f0 = f1*f2 (round nearest even)» 等实际代码理解该场景。
使用前检查清单
语法检查
- 确认当前指令格式为 R-type。
- 确认操作数排列顺序与示例一致。
语义检查
- 确认目标寄存器用途和调用约定兼容。
- 确认该指令不是伪指令展开后的底层形式。
容易混淆 / 常见误区
注意NaN-boxing约束