fmv.h.x
Half-precision floating-point move from integer
This instruction is defined by:
-
F, version >= 0
This instruction is included in the following profiles:
-
RVA20S64 (Mandatory)
-
RVA20U64 (Mandatory)
-
RVA22S64 (Mandatory)
-
RVA22U64 (Mandatory)
Synopsis
Moves the half-precision value encoded in IEEE 754-2008 standard encoding
from the lower 16 bits of integer register rs1
to the floating-point
register fd
. The bits are not modified in the transfer, and in particular,
the payloads of non-canonical NaNs are preserved.
Execution
-
IDL
-
Sail
check_f_ok($encoding);
Bits<16> hp_value = X[rs1][15:0];
f[fd] = nan_box<16, FLEN>(hp_value);
mark_f_state_dirty();
{
let rs1_val_X = X(rs1);
let rd_val_H = rs1_val_X [15..0];
F(rd) = nan_box (rd_val_H);
RETIRE_SUCCESS
}