mirror of
https://source.denx.de/u-boot/u-boot.git
synced 2026-06-02 09:46:37 +03:00
board: st: factorize STM32MP FWU multi-bank support
Factorize FWU multi-bank support code common to STM32MP1 and STM32MP2 platforms into a dedicated shared source file. No functional change intended. Signed-off-by: Dario Binacchi <dario.binacchi@amarulasolutions.com> Reviewed-by: Patrice Chotard <patrice.chotard@foss.st.com>
This commit is contained in:
committed by
Patrice Chotard
parent
560d8f3270
commit
4369c6a050
@@ -9,6 +9,7 @@ obj-$(CONFIG_PMIC_STPMIC1) += stpmic1.o
|
|||||||
ifeq ($(CONFIG_ARCH_STM32MP),y)
|
ifeq ($(CONFIG_ARCH_STM32MP),y)
|
||||||
obj-$(CONFIG_SET_DFU_ALT_INFO) += stm32mp_dfu.o
|
obj-$(CONFIG_SET_DFU_ALT_INFO) += stm32mp_dfu.o
|
||||||
obj-$(CONFIG_$(PHASE_)DFU_VIRT) += stm32mp_dfu_virt.o
|
obj-$(CONFIG_$(PHASE_)DFU_VIRT) += stm32mp_dfu_virt.o
|
||||||
|
obj-$(CONFIG_FWU_MULTI_BANK_UPDATE) += stm32mp_fwu.o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
obj-$(CONFIG_TYPEC_STUSB160X) += stusb160x.o
|
obj-$(CONFIG_TYPEC_STUSB160X) += stusb160x.o
|
||||||
|
|||||||
55
board/st/common/stm32mp_fwu.c
Normal file
55
board/st/common/stm32mp_fwu.c
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2026 Amarula Solutions, Dario Binacchi <dario.binacchi@amarulasolutions.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <fwu.h>
|
||||||
|
#include <part_efi.h>
|
||||||
|
#include <asm/io.h>
|
||||||
|
/**
|
||||||
|
* fwu_plat_get_bootidx() - Get the value of the boot index
|
||||||
|
* @boot_idx: Boot index value
|
||||||
|
*
|
||||||
|
* Get the value of the bank(partition) from which the platform
|
||||||
|
* has booted. This value is passed to U-Boot from the earlier
|
||||||
|
* stage bootloader which loads and boots all the relevant
|
||||||
|
* firmware images
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void fwu_plat_get_bootidx(uint *boot_idx)
|
||||||
|
{
|
||||||
|
*boot_idx = (readl(TAMP_FWU_BOOT_INFO_REG) >>
|
||||||
|
TAMP_FWU_BOOT_IDX_OFFSET) & TAMP_FWU_BOOT_IDX_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
int fwu_platform_hook(struct udevice *dev, struct fwu_data *data)
|
||||||
|
{
|
||||||
|
uint boot_idx;
|
||||||
|
efi_guid_t boot_uuid, root_uuid;
|
||||||
|
const efi_guid_t boot_type_guid = PARTITION_XBOOTLDR;
|
||||||
|
const efi_guid_t root_type_guid =
|
||||||
|
PARTITION_LINUX_FILE_SYSTEM_DATA_GUID;
|
||||||
|
char uuidbuf[UUID_STR_LEN + 1];
|
||||||
|
int retb, retr;
|
||||||
|
|
||||||
|
fwu_plat_get_bootidx(&boot_idx);
|
||||||
|
|
||||||
|
retb = fwu_mdata_get_image_guid(&boot_uuid, &boot_type_guid, boot_idx);
|
||||||
|
retr = fwu_mdata_get_image_guid(&root_uuid, &root_type_guid, boot_idx);
|
||||||
|
|
||||||
|
if (!retb && !retr) {
|
||||||
|
uuid_bin_to_str(boot_uuid.b, uuidbuf, UUID_STR_FORMAT_GUID);
|
||||||
|
env_set("boot_partuuid", uuidbuf);
|
||||||
|
|
||||||
|
uuid_bin_to_str(root_uuid.b, uuidbuf, UUID_STR_FORMAT_GUID);
|
||||||
|
env_set("root_partuuid", uuidbuf);
|
||||||
|
} else if (!retb && retr) {
|
||||||
|
log_warning("%s: found boot GUID but missing root GUID (%d)\n",
|
||||||
|
__func__, retr);
|
||||||
|
} else if (!retr && retb) {
|
||||||
|
log_warning("%s: found root GUID but missing boot GUID (%d)\n",
|
||||||
|
__func__, retb);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
@@ -837,57 +837,3 @@ static void board_copro_image_process(ulong fw_image, size_t fw_size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
U_BOOT_FIT_LOADABLE_HANDLER(IH_TYPE_COPRO, board_copro_image_process);
|
U_BOOT_FIT_LOADABLE_HANDLER(IH_TYPE_COPRO, board_copro_image_process);
|
||||||
|
|
||||||
#if defined(CONFIG_FWU_MULTI_BANK_UPDATE)
|
|
||||||
|
|
||||||
#include <fwu.h>
|
|
||||||
|
|
||||||
/**
|
|
||||||
* fwu_plat_get_bootidx() - Get the value of the boot index
|
|
||||||
* @boot_idx: Boot index value
|
|
||||||
*
|
|
||||||
* Get the value of the bank(partition) from which the platform
|
|
||||||
* has booted. This value is passed to U-Boot from the earlier
|
|
||||||
* stage bootloader which loads and boots all the relevant
|
|
||||||
* firmware images
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
void fwu_plat_get_bootidx(uint *boot_idx)
|
|
||||||
{
|
|
||||||
*boot_idx = (readl(TAMP_FWU_BOOT_INFO_REG) >>
|
|
||||||
TAMP_FWU_BOOT_IDX_OFFSET) & TAMP_FWU_BOOT_IDX_MASK;
|
|
||||||
}
|
|
||||||
|
|
||||||
int fwu_platform_hook(struct udevice *dev, struct fwu_data *data)
|
|
||||||
{
|
|
||||||
uint boot_idx;
|
|
||||||
efi_guid_t boot_uuid, root_uuid;
|
|
||||||
const efi_guid_t boot_type_guid = PARTITION_XBOOTLDR;
|
|
||||||
const efi_guid_t root_type_guid =
|
|
||||||
PARTITION_LINUX_FILE_SYSTEM_DATA_GUID;
|
|
||||||
char uuidbuf[UUID_STR_LEN + 1];
|
|
||||||
int retb, retr;
|
|
||||||
|
|
||||||
fwu_plat_get_bootidx(&boot_idx);
|
|
||||||
|
|
||||||
retb = fwu_mdata_get_image_guid(&boot_uuid, &boot_type_guid, boot_idx);
|
|
||||||
retr = fwu_mdata_get_image_guid(&root_uuid, &root_type_guid, boot_idx);
|
|
||||||
|
|
||||||
if (!retb && !retr) {
|
|
||||||
uuid_bin_to_str(boot_uuid.b, uuidbuf, UUID_STR_FORMAT_GUID);
|
|
||||||
env_set("boot_partuuid", uuidbuf);
|
|
||||||
|
|
||||||
uuid_bin_to_str(root_uuid.b, uuidbuf, UUID_STR_FORMAT_GUID);
|
|
||||||
env_set("root_partuuid", uuidbuf);
|
|
||||||
} else if (!retb && retr) {
|
|
||||||
log_warning("%s: found boot GUID but missing root GUID (%d)\n",
|
|
||||||
__func__, retr);
|
|
||||||
} else if (!retr && retb) {
|
|
||||||
log_warning("%s: found root GUID but missing boot GUID (%d)\n",
|
|
||||||
__func__, retb);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_FWU_MULTI_BANK_UPDATE */
|
|
||||||
|
|
||||||
|
|||||||
@@ -188,56 +188,3 @@ void board_quiesce_devices(void)
|
|||||||
{
|
{
|
||||||
led_boot_off();
|
led_boot_off();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(CONFIG_FWU_MULTI_BANK_UPDATE)
|
|
||||||
|
|
||||||
#include <fwu.h>
|
|
||||||
|
|
||||||
/**
|
|
||||||
* fwu_plat_get_bootidx() - Get the value of the boot index
|
|
||||||
* @boot_idx: Boot index value
|
|
||||||
*
|
|
||||||
* Get the value of the bank(partition) from which the platform
|
|
||||||
* has booted. This value is passed to U-Boot from the earlier
|
|
||||||
* stage bootloader which loads and boots all the relevant
|
|
||||||
* firmware images
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
void fwu_plat_get_bootidx(uint *boot_idx)
|
|
||||||
{
|
|
||||||
*boot_idx = (readl(TAMP_FWU_BOOT_INFO_REG) >>
|
|
||||||
TAMP_FWU_BOOT_IDX_OFFSET) & TAMP_FWU_BOOT_IDX_MASK;
|
|
||||||
}
|
|
||||||
|
|
||||||
int fwu_platform_hook(struct udevice *dev, struct fwu_data *data)
|
|
||||||
{
|
|
||||||
uint boot_idx;
|
|
||||||
efi_guid_t boot_uuid, root_uuid;
|
|
||||||
const efi_guid_t boot_type_guid = PARTITION_XBOOTLDR;
|
|
||||||
const efi_guid_t root_type_guid =
|
|
||||||
PARTITION_LINUX_FILE_SYSTEM_DATA_GUID;
|
|
||||||
char uuidbuf[UUID_STR_LEN + 1];
|
|
||||||
int retb, retr;
|
|
||||||
|
|
||||||
fwu_plat_get_bootidx(&boot_idx);
|
|
||||||
|
|
||||||
retb = fwu_mdata_get_image_guid(&boot_uuid, &boot_type_guid, boot_idx);
|
|
||||||
retr = fwu_mdata_get_image_guid(&root_uuid, &root_type_guid, boot_idx);
|
|
||||||
|
|
||||||
if (!retb && !retr) {
|
|
||||||
uuid_bin_to_str(boot_uuid.b, uuidbuf, UUID_STR_FORMAT_GUID);
|
|
||||||
env_set("boot_partuuid", uuidbuf);
|
|
||||||
|
|
||||||
uuid_bin_to_str(root_uuid.b, uuidbuf, UUID_STR_FORMAT_GUID);
|
|
||||||
env_set("root_partuuid", uuidbuf);
|
|
||||||
} else if (!retb && retr) {
|
|
||||||
log_warning("%s: found boot GUID but missing root GUID (%d)\n",
|
|
||||||
__func__, retr);
|
|
||||||
} else if (!retr && retb) {
|
|
||||||
log_warning("%s: found root GUID but missing boot GUID (%d)\n",
|
|
||||||
__func__, retb);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_FWU_MULTI_BANK_UPDATE */
|
|
||||||
|
|||||||
Reference in New Issue
Block a user