[PATCH v5 08/11] spl: Convert nor to spl_load
Sean Anderson
sean.anderson at seco.com
Thu Aug 3 17:46:05 CEST 2023
On 8/3/23 04:33, Xavier Drudis Ferran wrote:
> El Mon, Jul 31, 2023 at 06:43:00PM -0400, Sean Anderson deia:
>> This converts the nor load method to use spl_load. As a result it also
>> adds support for LOAD_FIT_FULL.
>>
>> Signed-off-by: Sean Anderson <sean.anderson at seco.com>
>> ---
>>
>> Changes in v5:
>> - Rework to load header in spl_load
>>
>> common/spl/spl_nor.c | 41 +++++++----------------------------------
>> 1 file changed, 7 insertions(+), 34 deletions(-)
>>
>> diff --git a/common/spl/spl_nor.c b/common/spl/spl_nor.c
>> index 5b65b96a77..7328a87024 100644
>> --- a/common/spl/spl_nor.c
>> +++ b/common/spl/spl_nor.c
>> @@ -26,8 +26,10 @@ unsigned long __weak spl_nor_get_uboot_base(void)
>> static int spl_nor_load_image(struct spl_image_info *spl_image,
>> struct spl_boot_device *bootdev)
>> {
>> - __maybe_unused const struct legacy_img_hdr *header;
>> - __maybe_unused struct spl_load_info load;
>> + struct spl_load_info load = {
>> + .bl_len = 1,
>> + .read = spl_nor_load_read,
>> + };
>>
>> /*
>> * Loading of the payload to SDRAM is done with skipping of
>> @@ -41,7 +43,8 @@ static int spl_nor_load_image(struct spl_image_info *spl_image,
>> * Load Linux from its location in NOR flash to its defined
>> * location in SDRAM
>> */
>> - header = (const struct legacy_img_hdr *)CONFIG_SYS_OS_BASE;
>> + const struct legacy_img_hdr *header =
>> + (const struct legacy_img_hdr *)CONFIG_SYS_OS_BASE;
>> #ifdef CONFIG_SPL_LOAD_FIT
>> if (image_get_magic(header) == FDT_MAGIC) {
>> int ret;
>> @@ -91,36 +94,6 @@ static int spl_nor_load_image(struct spl_image_info *spl_image,
>> * Load real U-Boot from its location in NOR flash to its
>> * defined location in SDRAM
>> */
>> -#ifdef CONFIG_SPL_LOAD_FIT
>> - header = (const struct legacy_img_hdr *)spl_nor_get_uboot_base();
>> - if (image_get_magic(header) == FDT_MAGIC) {
>> - debug("Found FIT format U-Boot\n");
>> - load.bl_len = 1;
>> - load.read = spl_nor_load_read;
>> - return spl_load_simple_fit(spl_image, &load,
>> - spl_nor_get_uboot_base(),
>> - (void *)header);
>
> this loaded the simple fit from sector=CFG_SYS_UBOOT_BASE and now we'll
> call spl_load with sector=0 ?
>
> But spl_nor_get_uboot_base() is overriden by calculations of
> concatenated images in
>
> arch/arm/mach-imx/image-container.c
> arch/mips/mach-mtmips/mt7621/spl/spl.c
> arch/mips/mach-mtmips/spl.c
>
>> - }
>> -#endif
>> - if (IS_ENABLED(CONFIG_SPL_LOAD_IMX_CONTAINER)) {
>> - load.bl_len = 1;
>> - load.read = spl_nor_load_read;
>> - return spl_load_imx_container(spl_image, &load,
>> - spl_nor_get_uboot_base());
>
> this loaded the imx image from sector=CFG_SYS_UBOOT_BASE or whatever
> spl_nor_get_uboot_base() gave and now we'll call spl_load with
> sector=0 ?
>
>> - }
>> -
>> - /* Legacy image handling */
>> - if (IS_ENABLED(CONFIG_SPL_LEGACY_IMAGE_FORMAT)) {
>> - struct legacy_img_hdr hdr;
>> -
>> - load.bl_len = 1;
>> - load.read = spl_nor_load_read;
>> - spl_nor_load_read(&load, spl_nor_get_uboot_base(), sizeof(hdr), &hdr);
>> - return spl_load_legacy_img(spl_image, bootdev, &load,
>> - spl_nor_get_uboot_base(),
>> - &hdr);
>
> This loaded legacy image with potential lzma decompression and now
> compressed images are no longer supported ?
>
>> - }
>> -
>> - return -EINVAL;
>> + return spl_load(spl_image, bootdev, &load, 0, 0);
>
> maybe better
>
> + return spl_load(spl_image, bootdev, &load, 0, spl_nor_get_uboot_base());
>
>
> and consider calling spl_load_legacy_img(spl_image, bootdev, &info, offset, header)
> from spl_load()?
Yeah, I noticed both of these issues when Tom sent the size difference.
I'm going to address these in v6. Ideally, I will incorporate the LZMA
code into spl_load.
--Sean
>> }
>> SPL_LOAD_IMAGE_METHOD("NOR", 0, BOOT_DEVICE_NOR, spl_nor_load_image);
>> --
>> 2.40.1
>>
More information about the U-Boot
mailing list