EBOOT跳转到NK的过程
先做個(gè)說(shuō)明:我的平臺(tái)環(huán)境是:CE5.0(S3C2450)。
????? 我的config.bib定義的鏡像起始地址為0x8c20 0000(虛擬地址), EBoot將鏡像下載到以0x8c20 0000為起始地址的RAM中, 但實(shí)際上OS跳轉(zhuǎn)的地址卻是0x8c20 1000, 也就是說(shuō), 傳遞到Lauch函數(shù)的參數(shù)應(yīng)該是對(duì)應(yīng)的物理地址0x3020 1000, 也就是鏡像開(kāi)始后4K的位置.
????? 為什么跳到4K后的位置執(zhí)行呢? 如果直接在下載的其實(shí)地址(0x3020 0000)執(zhí)行會(huì)怎么樣呢? 答案是:程序同樣會(huì)跳轉(zhuǎn)到后4K的位置.?
我看了一下NK.nb0中的機(jī)器碼, 最前面4字節(jié)的內(nèi)容是FE 03 00 EA, 它對(duì)應(yīng)的指令是B跳轉(zhuǎn), 偏移地址是(0x3FE+2)*4正好就是4K, 也就是將跳轉(zhuǎn)到偏移地址為0x1000的地方, 這也就很好的解釋了上面的現(xiàn)象.
???? nk.bin是nk.nb0的壓縮形式.把nk.bin下載到ram里后就是nk.nb0了.你說(shuō)用燒錄器燒入nk.nb0應(yīng)該是燒到flash去了.如果你的平臺(tái)用的是nor flash可以XIP的話,就把flash里存放nk.nb0的首地址(物理地址)傳遞給launch函數(shù),就可以跳轉(zhuǎn)到os啟動(dòng)了.如果在內(nèi)存里運(yùn)行os,那么就要在eboot里把nk.nb0復(fù)制到內(nèi)存的某個(gè)位置,然后把這個(gè)位置的物理地址給launch就可以了.一般說(shuō)來(lái),這個(gè)位置就是bib里定義的imagestart。
總結(jié)
以上是生活随笔為你收集整理的EBOOT跳转到NK的过程的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 上海使用权房限购新政,什么叫使用权房子
- 下一篇: platform Builder导出SD