nuttx/boards/risc-v
Eero Nurkkala b4d2944df7 tools/mpfs: prepare OpenSBI image
Polarfire Icicle board has only (128K - 256) bytes for the bootloader
in the non-volatile eNVM. This space is barely enough for running NuttX.
If OpenSBI is selected, it will be placed in DDR. This all means the
nuttx.bin file grows into gigabyte size, filling the unused space (ddr -
envm) with zeroes.

The memory layout is as follows:

MEMORY
{
    ddr  (rx)          : ORIGIN = 0x80000000, LENGTH = 4M
    envm (rx)          : ORIGIN = 0x20220100, LENGTH = 128K - 256
    l2lim  (rwx)       : ORIGIN = 0x08000000, LENGTH = 1024k
    l2zerodevice (rwx) : ORIGIN = 0x0A000000, LENGTH = 512k
}

OpenSBI library is used as a separate binary, which is stored into
eMMC or SD-card. It is then loaded into its precise location in DDR.

Thus, we separate OpenSBI from NuttX and end up with two images
by utilizing the objcopy options:

  --only-section=sectionpattern (-j in short)
  --remove-section=sectionpattern (-R in short)

This is only valid when CONFIG_MPFS_OPENSBI is set.

Signed-off-by: Eero Nurkkala <eero.nurkkala@offcode.fi>
2022-01-04 19:45:14 +08:00
..
bl602/bl602evb arch/risc-v: Refine Toolchain.defs 2021-12-28 00:30:10 -06:00
c906/smartl-c906 arch/risc-v: Remove unneeded kconfigs 2021-12-28 05:02:42 -06:00
esp32c3/esp32c3-devkit esp32c3-devkit: Restrict FS options when Flash Encryption is enabled 2022-01-01 20:37:44 +08:00
fe310/hifive1-revb boards: hifive1-revb: Enable some nsh commands in nsh/defconfig 2022-01-01 20:35:27 +08:00
k210/maix-bit arch/risc-v: Refine Toolchain.defs 2021-12-28 00:30:10 -06:00
litex/arty_a7 arch/risc-v: Refine Toolchain.defs 2021-12-28 00:30:10 -06:00
mpfs tools/mpfs: prepare OpenSBI image 2022-01-04 19:45:14 +08:00
qemu-rv32/rv32-virt arch/risc-v: Remove unneeded kconfigs 2021-12-28 05:02:42 -06:00
rv32m1/rv32m1-vega arch/risc-v: Remove unneeded kconfigs 2021-12-28 05:02:42 -06:00