如何基于nand flash启动Linux内核(分享一段实用、简单、类似bootloader功能的代码)

基于OS的电子类产品通常会把kernel烧到norfash里,因为可以按字节进行读写,但是norflash的价格要比nand flash的价格贵,而且nand flash是基于块读写的,如一次性读写512字节(block).如果是MLC的nand flash是按页读取的,一页差不多有4K byte, 那如何基于nand flash启动内容呢? 这里的实现步骤如下:

1. 目前部分nand flash controller芯片会默认把nand flash的第0块中的第0页内容读到controller的buffer里,也就可以在第0块第0页放一段小程序(简称IPL) 用来把Linux内核代码读到内存。

2. Linux内核一般在2M左右,一次性读到内存后就启动kernel函数开始启动操作系统,操作系统启动后就可以挂在根文件系统

 

下面具体看下基于ARM9的启动程序的汇编代码:

 

_start: ;@ set up stack to end of MEMC mov sp, #-4 ;@ reloc params: destination=MEMC+0x1000 source=NFC_BUF, size=4KB ldr r0, =LDR_BASE ldr r1, =NFC_BUF mov r2, #0x1000 bl burst8 adr lr, l_main mov lr, lr, lsl #20 mov lr, lr, lsr #20 ldr r11, =LDR_BASE add lr, lr, r11 b burst8 l_main: bl main ;@ loop forever l_end: b l_end burst8: stmdb sp!, {r4-r10} l_burst8_next: ldmia r1!, {r3-r10} stmia r0!, {r3-r10} subs r2, r2, #32 bgt l_burst8_next ldmia sp!, {r4-r10} mov pc, lr 

 

你可能感兴趣的:(汇编,Flash,buffer,byte,产品,linux内核)