Search code examples
floating-pointriscvriscv32

Concatenate values to float64 in RISC V


I have 0x40347ae1 in the 0(sp) and 0x4ccccccd in the 4(sp). How to concatenate these values in RiscV32 and store it in double register, such as fa0.

I expect the value to concatenate and become like this 0x40347ae14ccccccd and store it in fa0, so that I could display it as a float number.


Solution

  • If your environment has the "D" extension, then you have 64-bit floating point registers, and the "D" instruction set.

    You want the fld instruction, which will perform a 64-bit load (flw is for 32-bit load into a floating point register).


    However, if you want the result to be 0x40347ae14ccccccd, you'll need to swap the words, since as a little endian machine it will instead load 0x4ccccccd40347ae1 given your scenario of 0x40347ae1 at 0(sp) — the lower address — and 0x4ccccccd at 4(sp) — the next sequential address.


    If you're on a 64-bit RISC V machine, you can also move values from 64-bit integer registers into 64-bit floating point registers.  However, the designers have chosen to avoid partial register reads and writes, so some processor base & extension combinations have some limits.

    If you're on a 32-bit machine (with the "D" extension), the only way to access all of a 64-bit float register is via memory.  This is also the case with both 32- and 64-bit machines that implement the "Q" — quad precision extension.