mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	On sunxi boards, SPL looks for U-Boot at a 32 KiB offset, unless SPL is
larger than 32 KiB, in which case U-Boot immediately follows SPL. See
the logic in spl_mmc_get_uboot_raw_sector() and spl_spi_load_image().
In two cases, the existing binman description mismatches the SPL code.
For 64-bit boards, binman would place U-Boot immediately following SPL,
even if SPL is smaller than 32 KiB. This can happen when SPL MMC support
is disabled (i.e. when booting from SPI flash).
In contrast, for 32-bit boards, binman would place U-Boot at 32 KiB,
even if SPL is larger than that. This happens because the 'offset'
property does not consider the size of previous entries.
Fix both issues by setting a minimum size for the SPL entry, which
exactly matches the logic in the SPL code. Unfortunately, this size must
be provided as a magic number, since none of the relevant config symbols
(SPL_PAD_TO, SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR, and SYS_SPI_U_BOOT_OFFS)
are guaranteed to be defined in all cases.
Fixes: cfa3db602caf ("sunxi: Convert 64-bit boards to use binman")
Signed-off-by: Samuel Holland <samuel@sholland.org>
Reviewed-by: Simon Glass <sjg@chromium.org>
Reviewed-by: Andre Przywara <andre.przywara@arm.com>
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
		
	
			
		
			
				
	
	
		
			117 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| #include <config.h>
 | |
| 
 | |
| #ifdef CONFIG_MACH_SUN50I_H6
 | |
| #define BL31_ADDR 0x104000
 | |
| #define  SCP_ADDR 0x114000
 | |
| #elif defined(CONFIG_MACH_SUN50I_H616)
 | |
| #define BL31_ADDR 0x40000000
 | |
| #else
 | |
| #define BL31_ADDR  0x44000
 | |
| #define  SCP_ADDR  0x50000
 | |
| #endif
 | |
| 
 | |
| / {
 | |
| 	aliases {
 | |
| 		mmc0 = &mmc0;
 | |
| #if CONFIG_MMC_SUNXI_SLOT_EXTRA == 2
 | |
| 		mmc1 = &mmc2;
 | |
| #endif
 | |
| 	};
 | |
| 
 | |
| 	binman: binman {
 | |
| 		multiple-images;
 | |
| 	};
 | |
| };
 | |
| 
 | |
| &binman {
 | |
| 	u-boot-sunxi-with-spl {
 | |
| 		filename = "u-boot-sunxi-with-spl.bin";
 | |
| 		pad-byte = <0xff>;
 | |
| 
 | |
| 		blob {
 | |
| 			/*
 | |
| 			 * This value matches SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR
 | |
| 			 * and SYS_SPI_U_BOOT_OFFS if those are defined.
 | |
| 			 */
 | |
| 			min-size = <0x8000>;
 | |
| 			filename = "spl/sunxi-spl.bin";
 | |
| 		};
 | |
| 
 | |
| #ifdef CONFIG_ARM64
 | |
| 		fit {
 | |
| 			description = "Configuration to load ATF before U-Boot";
 | |
| 			#address-cells = <1>;
 | |
| 			fit,fdt-list = "of-list";
 | |
| 
 | |
| 			images {
 | |
| 				uboot {
 | |
| 					description = "U-Boot (64-bit)";
 | |
| 					type = "standalone";
 | |
| 					os = "u-boot";
 | |
| 					arch = "arm64";
 | |
| 					compression = "none";
 | |
| 					load = <CONFIG_TEXT_BASE>;
 | |
| 
 | |
| 					u-boot-nodtb {
 | |
| 					};
 | |
| 				};
 | |
| 
 | |
| 				atf {
 | |
| 					description = "ARM Trusted Firmware";
 | |
| 					type = "firmware";
 | |
| 					os = "arm-trusted-firmware";
 | |
| 					arch = "arm64";
 | |
| 					compression = "none";
 | |
| 					load = <BL31_ADDR>;
 | |
| 					entry = <BL31_ADDR>;
 | |
| 
 | |
| 					atf-bl31 {
 | |
| 						filename = "bl31.bin";
 | |
| 						missing-msg = "atf-bl31-sunxi";
 | |
| 					};
 | |
| 				};
 | |
| 
 | |
| #ifdef SCP_ADDR
 | |
| 				scp {
 | |
| 					description = "SCP firmware";
 | |
| 					type = "firmware";
 | |
| 					arch = "or1k";
 | |
| 					compression = "none";
 | |
| 					load = <SCP_ADDR>;
 | |
| 
 | |
| 					scp {
 | |
| 						filename = "scp.bin";
 | |
| 						missing-msg = "scp-sunxi";
 | |
| 					};
 | |
| 				};
 | |
| #endif
 | |
| 
 | |
| 				@fdt-SEQ {
 | |
| 					description = "NAME";
 | |
| 					type = "flat_dt";
 | |
| 					compression = "none";
 | |
| 				};
 | |
| 			};
 | |
| 
 | |
| 			configurations {
 | |
| 				default = "@config-DEFAULT-SEQ";
 | |
| 
 | |
| 				@config-SEQ {
 | |
| 					description = "NAME";
 | |
| 					firmware = "atf";
 | |
| #ifndef SCP_ADDR
 | |
| 					loadables = "uboot";
 | |
| #else
 | |
| 					loadables = "scp", "uboot";
 | |
| #endif
 | |
| 					fdt = "fdt-SEQ";
 | |
| 				};
 | |
| 			};
 | |
| 		};
 | |
| #else
 | |
| 		u-boot-img {
 | |
| 		};
 | |
| #endif
 | |
| 	};
 | |
| };
 |