80 likes | 284 Views
NAND boot over I2C example A simple Hello World example demonstrating NAND boot over I2C. Steps to build the example: Import the i2cnandboot CCS project from tools boot_loader examplesi2c nand evmc66xxl directory. (in CCSv5, Project->Import Existing CCS/CCE Eclipse Projects)
E N D
NAND boot over I2C example A simple Hello World example demonstrating NAND boot over I2C. Steps to build the example: Import the i2cnandboot CCS project from tools\boot_loader\examples\i2c\nand\evmc66xxl directory. (in CCSv5, Project->Import Existing CCS/CCE Eclipse Projects) 2. Clean the i2cnandboot project and re-build the project, after build is completed, i2cnandboot_evm66xxl.out and i2cnandboot_evm66xxl.map will be generated under tools\boot_loader\examples\i2c\nand\evmc66xxl\bin directory.
Steps to run i2cnandboot in CCSv5: Be sure to set the boot mode dip switch to no boot/EMIF16 boot mode on the EVM. Load the program tools\boot_loader\examples\i2c\nand\evmc66xxl\bin\i2cnandboot_evm66xxl.out to CCS. Connect the 3-pin RS-232 cable from the EVM to the serial port of the PC, and start Hyper Terminal. 4. Create a new connection with the Baud rate set to 115200 bps, Data bits 8, Parity none, Stop bits 1 and Flow control none. Be sure the COM port # is set correctly. 5. Run the program in CCS, i2cnandboot will send the hello world booting info to both the CCS console and the Hyper Terminal
Steps to program i2cnandboot to NAND: • Be sure IBL is programmed to I2C EEPROM bus address 0x51, if IBL is not programmed, refer to tools\boot_loader\ibl\doc\README.txt on how to program the IBL to EEPROM. • 2. By default, IBL will boot a BBLOB image (Linux kernel) from NAND, to run this example, we need to change the NAND boot image format to ELF: • In setConfig_c66xx_main() of tools\boot_loader\ibl\src\make\bin\i2cConfig.gel, replace ibl.bootModes[1].u.nandBoot.bootFormat = ibl_BOOT_FORMAT_BBLOB; with ibl.bootModes[1].u.nandBoot.bootFormat = ibl_BOOT_FORMAT_ELF; • Re-program the boot configuration table, refer to tools\boot_loader\ibl\doc\README.txt on how to program the boot configuration table to EEPROM.
3. Copy tools\boot_loader\examples\i2c\nand\evmc66xxl\bin\i2cnandboot_evm66xxl.out to tools\writer\nand\evmc66xxl\bin, rename it to app.bin and refer to tools\writer\nand\docs\README.txt on how to program the app.bin to NAND flash. 4. Once the programming is completed successfully, set the boot dip switches to I2C master mode, bus address 0x51 and boot parameter index to be 2. 5. After POR, IBL will boot the hello world image from NAND.
NOR NAND NOR or NAND addressing ‘Word’ = control gate; ‘bit’ = drain less contacts → more compact
NAND versus NOR 10x better endurance Fast read (~100 ns) Slow write (~10 μs) Used for Code Smaller cell size Slow read (~1 μs) Faster write (~1 μs) Used for Data
NAND versus NOR 10x better endurance Fast read (~100 ns) Slow write (~10 μs) Used for Code Smaller cell size Slow read (~1 μs) Faster write (~1 μs) Used for Data