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