S3C2410X的NAND flash啟動
這里,筆者參考了引導裝入程序(Bootloader)的方式,把代碼分成兩部分,第一部分作為引導代碼,包括ARM所要求的連續8個字的中斷向量表。它主要負責把NAND flash中的程序代碼復制到SDRAM中,其代碼遠小于4KB。第二部分是應用程序。調試時可分別單獨調試,互不影響。調試完成后,分別燒寫,引導代碼的RO_Base設置為0x0,燒寫到NANDflash的第0塊。第二部分應用程序的RO_Base設置為0x3000,0000,燒寫到NAND flash第一塊開始的地址空間。上電復位時,引導代碼由硬件邏輯復制到片內SRAM中,于是,ARM所要求的連續8個字的中斷向量表就位于0x0地址開始的連續空間內。接著從第一條指令開始執行,除了一些必要的初始化以及設置中斷向量表,它把NAND flash中第一塊開始的程序代碼復制到起始地址為0x3000,0000的SDRAM中。地址0x3000,0000既是RO_Base的地址,也是SDRAM在整個地址空間的起始地址。復制完成后,引導代碼也該結束退出了,退出之前需調整PC指針,為了簡單起見,把PC指針直接調整到地址0x3000,0000,即從應用程序的啟動代碼開始執行。需要注意的是,引導代碼把中斷向量表復制到SDRAM中_ISR_StartAddress處即地址0x30ffffff,而應用程序的啟動代碼也把中斷向量表復制到SDRAM中同一地址_ISR_StartAddress處。這樣,當異常發生時,PC指針首先跳到地址0x0開始8個字的異常向量
表,這是在片內SRAM的引導代碼里。接著,跳到SDRAM中的中斷向量表,這是在應用程序里,然后轉到中斷處理程序,PC指針的跳轉跨越了兩部分程序。引導代碼和應用程序在存儲空間和NAND flash的分布情況如圖所示。實現復制和PC指針調整的代碼如下 :
IMPORT nand_read_ll ;引入外部C函數
ldr r0, =SDRAM_Base_Address ;r0指向SDRAM的基地址,即地址0x3000,0000
mov r1, =APP_Start_ Address ;r1指向NAND_flash中應用程序的開始地址;即第1塊的開始地址
mov r2, =APP_End_ Address ;r2指向NAND_flash中應用程序的結束地址
bl nand_read_ll ;調用復制函數開始復制
ldr r12, =SDRAM_Base_Address
mov pc, r12 ;pc指向SDRAM的基地址;引導代碼到此結束,接著從應用程序啟動代碼的第一條語句開始執行。
同樣道理,NOR flash啟動也可以采用這種方式,不同的是,引導代碼在NOR flash中,它把NOR flash中的程序代碼復制到SDRAM中,然后,也是跳到SDRAM中開始執行。
評論