mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 22:11:49 +01:00 
			
		
		
		
	For sama5d3xek we need to modify the SPL image for correct detection by ROM code. Signed-off-by: Andreas Bießmann <andreas.devel@googlemail.com> Tested-by: Bo Shen <voice.shen@atmel.com>
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2014 Andreas Bießmann <andreas.devel@googlemail.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * This is a host tool for generating an appropriate string out of board
 | |
|  * configuration. The string is required for correct generation of PMECC
 | |
|  * header which in turn is required for NAND flash booting of Atmel AT91 style
 | |
|  * hardware.
 | |
|  *
 | |
|  * See doc/README.atmel_pmecc for more information.
 | |
|  */
 | |
| 
 | |
| #include <config.h>
 | |
| #include <stdlib.h>
 | |
| 
 | |
| static int pmecc_get_ecc_bytes(int cap, int sector_size)
 | |
| {
 | |
| 	int m = 12 + sector_size / 512;
 | |
| 	return (m * cap + 7) / 8;
 | |
| }
 | |
| 
 | |
| int main(int argc, char *argv[])
 | |
| {
 | |
| 	unsigned int use_pmecc = 0;
 | |
| 	unsigned int sector_per_page;
 | |
| 	unsigned int sector_size = CONFIG_PMECC_SECTOR_SIZE;
 | |
| 	unsigned int oob_size = CONFIG_SYS_NAND_OOBSIZE;
 | |
| 	unsigned int ecc_bits = CONFIG_PMECC_CAP;
 | |
| 	unsigned int ecc_offset;
 | |
| 
 | |
| #ifdef CONFIG_ATMEL_NAND_HW_PMECC
 | |
| 	use_pmecc = 1;
 | |
| #endif
 | |
| 
 | |
| 	sector_per_page = CONFIG_SYS_NAND_PAGE_SIZE / CONFIG_PMECC_SECTOR_SIZE;
 | |
| 	ecc_offset = oob_size -
 | |
| 		pmecc_get_ecc_bytes(ecc_bits, sector_size) * sector_per_page;
 | |
| 
 | |
| 	printf("usePmecc=%d,", use_pmecc);
 | |
| 	printf("sectorPerPage=%d,", sector_per_page);
 | |
| 	printf("sectorSize=%d,", sector_size);
 | |
| 	printf("spareSize=%d,", oob_size);
 | |
| 	printf("eccBits=%d,", ecc_bits);
 | |
| 	printf("eccOffset=%d", ecc_offset);
 | |
| 	printf("\n");
 | |
| 
 | |
| 	exit(EXIT_SUCCESS);
 | |
| }
 |