mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-30 19:48:19 +00:00 
			
		
		
		
	This converts the nand load method to use spl_load. nand_page_size may not be valid until after nand_spl_load_image is called (see e.g. fsl_ifc_spl), so we set bl_len in spl_nand_read. Since spl_load reads the header for us, we can remove that argument from spl_nand_load_element. There are two possible regressions which could result from this commit. First, we ask for a negative address from spl_get_load_buffer. That is, instead of header = spl_get_load_buffer(0, sizeof(*header)); we do header = spl_get_load_buffer(-sizeof(*header), sizeof(*header)); this could cause a problem if spl_get_load_buffer does not return valid memory for negative offsets. Second, we now set bl_len for legacy images. This can cause memory up to a bl_len - 1 before the image load address to be written, which might not have been the case before. If this turns out to be a problem, we can add an option for a bounce buffer. We can't load FITs with external data with SPL_LOAD_FIT_FULL, so disable the test in that case. No boards enable SPL_NAND_SUPPORT and SPL_LOAD_FIT_FULL, so this is not a regression. Signed-off-by: Sean Anderson <seanga2@gmail.com> Reviewed-by: Simon Glass <sjg@chromium.org>
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0+
 | |
| /*
 | |
|  * Copyright (C) 2023 Sean Anderson <seanga2@gmail.com>
 | |
|  */
 | |
| 
 | |
| #include <nand.h>
 | |
| #include <spl.h>
 | |
| #include <test/spl.h>
 | |
| #include <test/ut.h>
 | |
| 
 | |
| uint32_t spl_nand_get_uboot_raw_page(void);
 | |
| 
 | |
| static int spl_test_nand_write_image(struct unit_test_state *uts, void *img,
 | |
| 				     size_t img_size)
 | |
| {
 | |
| 	uint32_t off = spl_nand_get_uboot_raw_page();
 | |
| 	struct mtd_info *mtd;
 | |
| 	struct erase_info erase = { };
 | |
| 	size_t length;
 | |
| 
 | |
| 	nand_reinit();
 | |
| 	mtd = get_nand_dev_by_index(0);
 | |
| 	ut_assertnonnull(mtd);
 | |
| 
 | |
| 	/* Mark the first block as bad to test that it gets skipped */
 | |
| 	ut_assertok(mtd_block_markbad(mtd, off & ~mtd->erasesize_mask));
 | |
| 	off += mtd->erasesize;
 | |
| 
 | |
| 	erase.mtd = mtd;
 | |
| 	erase.len = img_size + (off & mtd->erasesize_mask);
 | |
| 	erase.len += mtd->erasesize_mask;
 | |
| 	erase.len &= ~mtd->erasesize_mask;
 | |
| 	erase.addr = off & ~mtd->erasesize_mask;
 | |
| 	erase.scrub = 1;
 | |
| 	ut_assertok(mtd_erase(mtd, &erase));
 | |
| 
 | |
| 	ut_assertok(mtd_write(mtd, off, img_size, &length, img));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static int spl_test_nand(struct unit_test_state *uts, const char *test_name,
 | |
| 			 enum spl_test_image type)
 | |
| {
 | |
| 	return do_spl_test_load(uts, test_name, type,
 | |
| 				SPL_LOAD_IMAGE_GET(1, BOOT_DEVICE_NAND,
 | |
| 						   spl_nand_load_image),
 | |
| 				spl_test_nand_write_image);
 | |
| }
 | |
| SPL_IMG_TEST(spl_test_nand, LEGACY, DM_FLAGS);
 | |
| SPL_IMG_TEST(spl_test_nand, LEGACY_LZMA, DM_FLAGS);
 | |
| SPL_IMG_TEST(spl_test_nand, IMX8, DM_FLAGS);
 | |
| SPL_IMG_TEST(spl_test_nand, FIT_INTERNAL, DM_FLAGS);
 | |
| #if !IS_ENABLED(CONFIG_SPL_LOAD_FIT_FULL)
 | |
| SPL_IMG_TEST(spl_test_nand, FIT_EXTERNAL, DM_FLAGS);
 | |
| #endif
 |