[PATCH] amd: versal2: Add support for saving env based on bootmode
Michal Simek
michal.simek at amd.com
Wed Apr 16 13:50:06 CEST 2025
On 4/11/25 17:46, Venkatesh Yadav Abbarapu wrote:
> Enable saving variables to MMC(FAT) and SPI based on primary
> bootmode. If bootmode is JTAG, dont save env anywhere(NOWHERE).
>
> Enable ENV_FAT_DEVICE_AND_PART="0:auto" for Versal Gen2 platform.
>
> Signed-off-by: Venkatesh Yadav Abbarapu <venkatesh.abbarapu at amd.com>
> ---
> board/amd/versal2/board.c | 32 ++++++++++++++++++++++++++++++
> configs/amd_versal2_virt_defconfig | 3 +++
> env/Kconfig | 2 +-
> 3 files changed, 36 insertions(+), 1 deletion(-)
>
> diff --git a/board/amd/versal2/board.c b/board/amd/versal2/board.c
> index 5651d516a9e..23c76238f01 100644
> --- a/board/amd/versal2/board.c
> +++ b/board/amd/versal2/board.c
> @@ -341,3 +341,35 @@ int dram_init(void)
> void reset_cpu(void)
> {
> }
> +
> +#if defined(CONFIG_ENV_IS_NOWHERE)
> +enum env_location env_get_location(enum env_operation op, int prio)
> +{
> + u32 bootmode = versal_net_get_bootmode();
> +
> + if (prio)
> + return ENVL_UNKNOWN;
> +
> + switch (bootmode) {
> + case EMMC_MODE:
> + case SD_MODE:
> + case SD1_LSHFT_MODE:
> + case SD_MODE1:
> + if (IS_ENABLED(CONFIG_ENV_IS_IN_FAT))
> + return ENVL_FAT;
> + if (IS_ENABLED(CONFIG_ENV_IS_IN_EXT4))
> + return ENVL_EXT4;
> + return ENVL_NOWHERE;
> + case OSPI_MODE:
> + case QSPI_MODE_24BIT:
> + case QSPI_MODE_32BIT:
> + if (IS_ENABLED(CONFIG_ENV_IS_IN_SPI_FLASH))
> + return ENVL_SPI_FLASH;
> + return ENVL_NOWHERE;
> + case JTAG_MODE:
> + case SELECTMAP_MODE:
> + default:
> + return ENVL_NOWHERE;
> + }
> +}
> +#endif
> diff --git a/configs/amd_versal2_virt_defconfig b/configs/amd_versal2_virt_defconfig
> index 9911caa0e46..a8d9f5cc777 100644
> --- a/configs/amd_versal2_virt_defconfig
> +++ b/configs/amd_versal2_virt_defconfig
> @@ -66,6 +66,9 @@ CONFIG_PARTITION_TYPE_GUID=y
> CONFIG_OF_BOARD=y
> CONFIG_DTB_RESELECT=y
> CONFIG_MULTI_DTB_FIT=y
> +CONFIG_ENV_IS_NOWHERE=y
> +CONFIG_ENV_IS_IN_FAT=y
> +CONFIG_ENV_IS_IN_SPI_FLASH=y
> CONFIG_SYS_REDUNDAND_ENVIRONMENT=y
> CONFIG_SYS_RELOC_GD_ENV_ADDR=y
> CONFIG_NET_LWIP=y
> diff --git a/env/Kconfig b/env/Kconfig
> index 4438f0b392c..9507aeed12a 100644
> --- a/env/Kconfig
> +++ b/env/Kconfig
> @@ -485,7 +485,7 @@ config ENV_FAT_DEVICE_AND_PART
> string "Device and partition for where to store the environemt in FAT"
> depends on ENV_IS_IN_FAT
> default "0:1" if TI_COMMON_CMD_OPTIONS
> - default "0:auto" if ARCH_ZYNQ || ARCH_ZYNQMP || ARCH_VERSAL || ARCH_VERSAL_NET
> + default "0:auto" if ARCH_ZYNQ || ARCH_ZYNQMP || ARCH_VERSAL || ARCH_VERSAL_NET || ARCH_VERSAL2
> default ":auto" if ARCH_SUNXI
> default "0" if ARCH_AT91
> help
Applied.
M
More information about the U-Boot
mailing list