From 1b343e2603e46baca914a5adb49144f47fb5d39d Mon Sep 17 00:00:00 2001 From: Patrice Chotard Date: Tue, 1 Apr 2025 18:08:44 +0200 Subject: board: st: stm32mp2: add env_get_location() In case of several environment location support, env_get_location is needed to select the correct location depending of the boot device . Signed-off-by: Patrice Chotard --- board/st/stm32mp2/stm32mp2.c | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) (limited to 'board/st/stm32mp2/stm32mp2.c') diff --git a/board/st/stm32mp2/stm32mp2.c b/board/st/stm32mp2/stm32mp2.c index aa7dd31996e..c70ffaf5dbd 100644 --- a/board/st/stm32mp2/stm32mp2.c +++ b/board/st/stm32mp2/stm32mp2.c @@ -6,7 +6,7 @@ #define LOG_CATEGORY LOGC_BOARD #include -#include +#include #include #include #include @@ -59,6 +59,25 @@ int board_init(void) return 0; } +enum env_location env_get_location(enum env_operation op, int prio) +{ + u32 bootmode = get_bootmode(); + + if (prio) + return ENVL_UNKNOWN; + + switch (bootmode & TAMP_BOOT_DEVICE_MASK) { + case BOOT_FLASH_SD: + case BOOT_FLASH_EMMC: + if (CONFIG_IS_ENABLED(ENV_IS_IN_MMC)) + return ENVL_MMC; + else + return ENVL_NOWHERE; + default: + return ENVL_NOWHERE; + } +} + int board_late_init(void) { const void *fdt_compat; -- cgit v1.2.3