mx51 uboot启动感悟
http://blog.csdn.net/evilcode/article/details/6079767
arm內部有rom,該rom有代碼,上面駐留著系統真正啟動的代碼,和uboot沒有關系。
通過該段代碼根據不同的啟動模式進行不同的啟動方式:
如果是nand會自動讀取uboot前4k的代碼到片內sdram執行,該代碼要完成cpu的初始化和ram初始化(初始化ram為外圍的)等。
——————————————————————————
i.mx51沒有nand但有SD卡,但都是作為存儲設備!
——————————————————————————
一直困惑自己的是,一直以為uboot的前4k是拷貝到外圍ram執行的,但片外的ram需要前4k去初始化這樣造成了死鎖
拿Freescale的imx51為例 片內ROM 36k 片內RAM128k
iMX51啟動機制如下(在實際開發中不會涉及到該內容寫下這些只是讓你更好的了解系統的啟動過程,系統的啟動過程不單單只有uboot這一塊在uboot之前還做了很多的工作):
imx51在系統重啟時,會采樣啟動模式的GPIO管腳(BOOT_MODE[1:0]),采樣所得到的值存儲在SBMR寄存器中(System Reset Controller Boot Mode Register)。imx51支持的啟動模式包括:內部啟動模式(通過啟動模式的GPIO管腳判斷啟動外設)、測試模式、下載模式(通過USB/UART下載代碼)、內部啟動模式(通過啟動模式fuse位判斷啟動外設)。
| BOOT_MODE[1:0] | 啟動模式類型 | 啟動模式細節 |
| 00 | 內部啟動模式 ? (通過啟動模式GPIO管腳判斷啟動外設) | iMX51執行芯片內部的啟動代碼,可以從以下設備啟動 ?
|
| 01 | 測試模式 | ? |
| 10 | 內部啟動模式 ? (通過啟動模式fuse位判斷啟動外設) | 與00模式相同,只是不通過啟動模式GPIO管腳來判斷啟動外設,而是通過iMX51的內部fuse位,這些fuse位可以一次性寫入。 |
| 00 | USB/UART下載啟動模式 | 下載并執行代碼,可以通過以下接口 ? l?????????? USB(全速) l?????????? UART |
imx51在系統重啟時,會讀取GPIO_BT_SEL的內部fuse位:
a)如果GPIO_BT_SEL=1(被燒寫過),在芯片內部啟動代碼會通過讀取內部fuse位來判斷外設相關性。
b)如果GPIO_BT_SEL=0,imx51會在啟動時采樣外設相關特性的GPIO管腳,并存儲在SBMR寄存器中。芯片內部啟動代碼會通過讀取該寄存器判斷外設相關性。所以,芯片內部fuse位與啟動相關GPIO管腳是一一對應的。
IMX51內部啟動代碼
imx51內部有一段ROMcode,在內部啟動模式下,系統啟動時,會執行這段代碼,這段代碼會初始化最基本的硬件,然后判斷系統的外部存儲設備信息(通過讀取SBMR寄存器)。然后系統會初始化相應的外設,并將外設中的第一部分代碼拷貝到芯片內部RAM中,并跳轉到其頭地址并執行。
通過這種方式,imx51可以支持從多種外設啟動,從而增加啟動靈活性,imx51 ROMcode流程如下
我們是按照從SD卡
1) ? 通過采樣SBMR寄存器讀取fuse位或者采用啟動模式的管腳 <——Reset
2)通過BOOT_MODE[1:0]來判斷是否是那種啟動模式
為了保持穩定性BOOT_MODE[1:0]=10,內部啟動模式(通過啟動模式fuse位判斷啟動外設),將外部信息燒寫到芯片內部fuse中,這樣系統將從內部fuse中讀取相關外設信息。
3)因為是從SD卡啟動所以 boot memo ctrol SD/MMC/MoviNAND?
BT_MEM_CTL = 外設接口擴展存儲設備
‘00’=SD/MMC HDD
4)配置SD/MMC的控制器 eSDHC1 Controller
5)basic config and obtain base addr of boot device
基本的配置和獲取啟動硬件的基地址
6)執行鏡像
講這些的作用:imx51的Romcode固化在芯片內部,不能修改,以上分析Romcode主要可以幫助大家理解以下幾點:
1)imx51最初是如何啟動的
2)在bootloader開始執行前,系統處于何種狀態,由以上分析可見
a)imx51已經初始化了硬件部分,包括部分時鐘,內部總線以及外部存儲設備的控制器,以及外部存儲設備本身
b)bootloader的頭2k已經被拷貝到imx51內部的RAM了,除開1k的MBR頭,以及flash文件頭,剩下的部分就是可執行代碼。由此可知剩下部分已經不能放下整個bootloader了,所以必須把bootloader分成兩個部分:XLDR和Eboot本身。
c)可以利用DCD段來初始化某些寄存器,例如AndroidBSP利用它來初始化系統DDR2控制器。
總結
以上是生活随笔為你收集整理的mx51 uboot启动感悟的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Wi-Fi速度慢的十个原因以及解决办法
- 下一篇: 读取SD卡里面的BMP文件 显示到TFT