mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 10:08:21 +01:00 
			
		
		
		
	Provides a tool to build boot Image for PBL(Pre boot loader) which is used on Freescale CoreNet SoCs, PBL can be used to load some instructions and/or data for pre-initialization. The default output image is u-boot.pbl, for more details please refer to doc/README.pblimage. Signed-off-by: Shaohui Xie <Shaohui.Xie@freescale.com> Signed-off-by: Andy Fleming <afleming@freescale.com>
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ------------------------------------------------------------------
 | |
| Freescale PBL(pre-boot loader) Boot Image generation using mkimage
 | |
| ------------------------------------------------------------------
 | |
| 
 | |
| The CoreNet SoC's can boot directly from eSPI FLASH, SD/MMC and
 | |
| NAND, etc. These SoCs use PBL to load RCW and/or pre-initialization
 | |
| instructions. For more details refer section 5 Pre-boot loader
 | |
| specifications of reference manual P3041RM/P4080RM/P5020RM at link:
 | |
| http://www.freescale.com/webapp/search/Serp.jsp?Reference+Manuals
 | |
| 
 | |
| Building PBL Boot Image and boot steps
 | |
| --------------------------------------
 | |
| 
 | |
| 1. Building PBL Boot Image.
 | |
|    The default Image is u-boot.pbl.
 | |
| 
 | |
|    For eSPI boot(available on P3041/P4080/P5020):
 | |
| 	To build the eSPI boot image:
 | |
| 	make <board_name>_SPIFLASH_config
 | |
| 	make u-boot.pbl
 | |
| 
 | |
|    For SD boot(available on P3041/P4080/P5020):
 | |
| 	To build the SD boot image:
 | |
| 	make <board_name>_SDCARD_config
 | |
| 	make u-boot.pbl
 | |
| 
 | |
|    For Nand boot(available on P3041/P5020):
 | |
| 	To build the NAND boot image:
 | |
| 	make <board_name>_NAND_config
 | |
| 	make u-boot.pbl
 | |
| 
 | |
| 
 | |
| 2. pblimage support available with mkimage utility will generate Freescale PBL
 | |
| boot image that can be flashed on the board eSPI flash, SD/MMC and NAND.
 | |
| Following steps describe it in detail.
 | |
| 
 | |
| 	1). Boot from eSPI flash
 | |
| 	Write u-boot.pbl to eSPI flash from offset 0x0.
 | |
| 	for ex in u-boot:
 | |
| 	=>tftp 100000 u-boot.pbl
 | |
| 	=>sf probe 0
 | |
| 	=>sf erase 0 100000
 | |
| 	=>sf write 100000 0 $filesize
 | |
| 	Change SW1[1:5] = off off on off on.
 | |
| 
 | |
| 	2). Boot from SD/MMC
 | |
| 	Write u-boot.pbl to SD/MMC from offset 0x1000.
 | |
| 	for ex in u-boot:
 | |
| 	=>tftp 100000 u-boot.pbl
 | |
| 	=>mmcinfo
 | |
| 	=>mmc write 100000 8 441
 | |
| 	Change SW1[1:5] = off off on on off.
 | |
| 
 | |
| 	3). Boot from Nand
 | |
| 	Write u-boot.pbl to Nand from offset 0x0.
 | |
| 	for ex in u-boot:
 | |
| 	=>tftp 100000 u-boot.pbl
 | |
| 	=>nand info
 | |
| 	=>nand erase 0 100000
 | |
| 	=>nand write 100000 0 $filesize
 | |
| 	Change SW1[1:5] = off on off off on
 | |
| 	Change SW7[1:4] = on off off on
 | |
| 
 | |
| Board specific configuration file specifications:
 | |
| ------------------------------------------------
 | |
| 1. Configuration files rcw.cfg and pbi.cfg must present in the
 | |
| board/freescale/corenet_ds/, rcw.cfg is for RCW, pbi.cfg is for
 | |
| PBI instructions. File name must not be changed since they are used
 | |
| in Makefile.
 | |
| 2. These files can have empty lines and lines starting with "#" as first
 | |
| character to put comments
 | |
| 
 | |
| Typical example of rcw.cfg file:
 | |
| -----------------------------------
 | |
| 
 | |
| #PBL preamble and RCW header
 | |
| aa55aa55 010e0100
 | |
| #64 bytes RCW data
 | |
| 4c580000 00000000 18185218 0000cccc
 | |
| 40464000 3c3c2000 58000000 61000000
 | |
| 00000000 00000000 00000000 008b6000
 | |
| 00000000 00000000 00000000 00000000
 | |
| 
 | |
| Typical example of pbi.cfg file:
 | |
| -----------------------------------
 | |
| 
 | |
| #PBI commands
 | |
| #Initialize CPC1
 | |
| 09010000 00200400
 | |
| 09138000 00000000
 | |
| 091380c0 00000100
 | |
| 09010100 00000000
 | |
| 09010104 fff0000b
 | |
| 09010f00 08000000
 | |
| 09010000 80000000
 | |
| #Configure LAW for CPC1
 | |
| 09000d00 00000000
 | |
| 09000d04 fff00000
 | |
| 09000d08 81000013
 | |
| 09000010 00000000
 | |
| 09000014 ff000000
 | |
| 09000018 81000000
 | |
| #Initialize eSPI controller
 | |
| 09110000 80000403
 | |
| 09110020 2d170008
 | |
| 09110024 00100008
 | |
| 09110028 00100008
 | |
| 0911002c 00100008
 | |
| #Flush PBL data
 | |
| 09138000 00000000
 | |
| 091380c0 00000000
 | |
| 
 | |
| ------------------------------------------------
 | |
| Author: Shaohui Xie<Shaohui.Xie@freescale.com>
 |