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