FLT.H 的 rd 是浮点寄存器吗?
不是。rd 是整数寄存器,保存布尔结果 0 或 1。
半精度浮点小于比较,条件成立时 x[rd]=1,否则 x[rd]=0。
FLT.H 比较 f[rs1] 与 f[rs2] 的半精度浮点值,并把布尔结果写入整数寄存器 rd。这是 signaling 比较:任一 NaN(包括 quiet NaN)都会设置 NV,结果为 0。结果不是浮点值,不受 rm 舍入模式影响。
FLT.H 把浮点比较结果写到整数寄存器 x[rd]。它属于 signaling 比较语义,quiet NaN 也会触发 NV。
结合 «flt.h x10, f0, f1 # x10 = (f0<f1)» 等实际代码理解该场景。
结合 «flt.h x10, f0, f1 # x10 = (f0<f1)» 等实际代码理解该场景。
不是。rd 是整数寄存器,保存布尔结果 0 或 1。
任一 NaN 结果为 0,并设置 NV。