[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