FLTQ.D 的 rd 是浮点寄存器吗?
不是。rd 是整数寄存器,保存布尔结果 0 或 1。
双精度浮点静默小于比较,条件成立时 x[rd]=1,否则 x[rd]=0。
FLTQ.D 比较 f[rs1] 与 f[rs2] 的双精度浮点值,并把布尔结果写入整数寄存器 rd。这是 quiet 比较:静默 NaN 不设置 NV,信号 NaN 设置 NV;任一 NaN 时结果为 0。结果不是浮点值,不受 rm 舍入模式影响。
FLTQ.D 把浮点比较结果写到整数寄存器 x[rd]。它属于 quiet 比较语义,适合不希望 quiet NaN 触发 NV 的比较场景。
结合 «fltq.d x10, f11, f12 ; x10 = (f11 < f12) ? 1 : 0 (double quiet)» 等实际代码理解该场景。
结合 «fltq.d x10, f11, f12 ; x10 = (f11 < f12) ? 1 : 0 (double quiet)» 等实际代码理解该场景。
不是。rd 是整数寄存器,保存布尔结果 0 或 1。
任一 NaN 结果为 0;只有信号 NaN 设置 NV。