如何基于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的启动程序的汇编代码:

[c-sharp] view plaincopy
  1. _start:  
  2. ;@ set up stack to end of MEMC  
  3. mov     sp, #-4  
  4. ;@ reloc params: destination=MEMC+0x1000 source=NFC_BUF, size=4KB  
  5. ldr     r0, =LDR_BASE  
  6. ldr     r1, =NFC_BUF  
  7. mov     r2, #0x1000  
  8. bl      burst8  
  9. adr     lr, l_main  
  10. mov     lr, lr, lsl #20  
  11. mov     lr, lr, lsr #20  
  12. ldr     r11, =LDR_BASE  
  13. add     lr, lr, r11  
  14. b       burst8  
  15. l_main:  
  16. bl      main  
  17. ;@ loop forever  
  18. l_end:  
  19. b       l_end  
  20.   
  21. burst8:   
  22. stmdb   sp!, {r4-r10}  
  23. l_burst8_next:  
  24. ldmia   r1!, {r3-r10}  
  25. stmia   r0!, {r3-r10}  
  26. subs    r2, r2, #32  
  27. bgt     l_burst8_next  
  28. ldmia   sp!, {r4-r10}  
  29. mov     pc, lr  

 转载:http://blog.csdn.net/moruite/article/details/6321918

原文地址:https://www.cnblogs.com/canphp/p/2770144.html