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