首页/指令库/FSGNJX-H
FSGNJX.H

RISC-V FSGNJX.H 指令详解

指令手册R-type

结果的数值位来自 rs1,符号位来自rs1 与 rs2 符号异或。

指令语法

fsgnjx.h rd, rs1, rs2
操作数说明
rd:目标浮点寄存器,接收该格式的浮点结果。
rs1/rs2:源浮点寄存器;带 rm 的算术/舍入指令由 rm 或动态 frm 选择舍入模式。
Zfh浮点运算

指令行为说明

FSGNJX.H 只重组半精度浮点编码的符号位:指数和尾数字段来自 rs1,符号位按 rs1 与 rs2 符号异或 产生。它不执行浮点算术、不舍入、不设置浮点异常标志,也不规范化 NaN。

快速理解与检索要点

FSGNJX.H 适合搜索“浮点取负/绝对值/拷贝为什么不触发异常”。它只搬动符号位相关信息,不改变 rs1 的指数和尾数。

rs2=rs1 时,FSGNJ/FSGNJN/FSGNJX 分别对应常见的 FMV/FNEG/FABS 伪指令语义。
该类指令没有 rm 字段,也不会设置 fflags。

常见使用场景

符号操作

结合 «fsgnjx.h f0, f1, f2 # f0 = f1 XOR sign of f2» 等实际代码理解该场景。

浮点位操作

结合 «fsgnjx.h f0, f1, f2 # f0 = f1 XOR sign of f2» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

这是位级符号操作,不是算术加减或数值转换。
不会设置异常标志,也不会把 NaN 规范化。
rs2=rs1 常用于 FABS 伪指令。

常见问题

FSGNJX.H 会改变 NaN payload 吗?

不会规范化 NaN;除符号位按规则变化外,rs1 的其余位保持。

FSGNJX.H 是数值转换吗?

不是。它是浮点寄存器中的位级符号操作。