61 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| -----------------------------
 | |
| NAND boot on PPC440 platforms
 | |
| -----------------------------
 | |
| 
 | |
| This document describes the U-Boot NAND boot feature as it
 | |
| is implemented for the AMCC Sequoia (PPC440EPx) board.
 | |
| 
 | |
| The PPC440EP(x)/GR(x) cpu's can boot directly from NAND FLASH,
 | |
| completely without NOR FLASH. This can be done by using the NAND
 | |
| boot feature of the 440 NAND flash controller (NDFC).
 | |
| 
 | |
| Here a short description of the different boot stages:
 | |
| 
 | |
| a) IPL (Initial Program Loader, integrated inside CPU)
 | |
| ------------------------------------------------------
 | |
| Will load first 4k from NAND (SPL) into cache and execute it from there.
 | |
| 
 | |
| b) SPL (Secondary Program Loader)
 | |
| ---------------------------------
 | |
| Will load special U-Boot version (NUB) from NAND and execute it. This SPL
 | |
| has to fit into 4kByte. It sets up the CPU and configures the SDRAM
 | |
| controller and the NAND controller so that the special U-Boot image can be
 | |
| loaded from NAND to SDRAM.
 | |
| This special image is build in the directory "nand_spl".
 | |
| 
 | |
| c) NUB (NAND U-Boot)
 | |
| --------------------
 | |
| This NAND U-Boot (NUB) is a special U-Boot version which can be started
 | |
| from RAM. Therefore it mustn't (re-)configure the SDRAM controller.
 | |
| 
 | |
| On 440EPx the SPL is copied to internal SRAM before the NAND controller
 | |
| is set up. While still running from cache, I experienced problems accessing
 | |
| the NAND controller.
 | |
| 
 | |
| 
 | |
| Example: Build and install NAND boot image for Sequoia (440EPx):
 | |
| 
 | |
| a) Configure for sequoia with NAND boot support:
 | |
| # make sequoia_nand_config
 | |
| 
 | |
| b) Build image(s)
 | |
| # make
 | |
| 
 | |
| This will generate the SPL image in the "nand_spl" directory:
 | |
| nand_spl/u-boot-spl.bin
 | |
| Also another image is created spanning a whole NAND block (16kBytes):
 | |
| nand_spl/u-boot-spl-16k.bin
 | |
| The main NAND U-Boot image is generated in the toplevel directory:
 | |
| u-boot.bin
 | |
| A combined image of u-boot-spl-16k.bin and u-boot.bin is also created:
 | |
| u-boot-nand.bin
 | |
| 
 | |
| This image should be programmed at offset 0 in the NAND flash:
 | |
| 
 | |
| # tftp 100000 /tftpboot/sequoia/u-boot-nand.bin
 | |
| # nand erase 0 60000
 | |
| # nand write 100000 0 60000
 | |
| 
 | |
| 
 | |
| September 07 2006, Stefan Roese <sr@denx.de>
 |