------------------------------------------------------------------ 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>