查看: 4291|回復: 2
打印 上一主題 下一主題

[提問(wèn)] 為啥剛剛enable MMU后系統立刻就掛了?

[復制鏈接]
跳轉到指定樓層
樓主
發(fā)表于 2013-10-7 01:33:36 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
嵌入式門(mén)外漢,手頭有個(gè)2410的老開(kāi)發(fā)板,自帶bootloader沒(méi)動(dòng),可通過(guò)usb下載zImage并啟動(dòng)成功。
我有個(gè)想法是做雙bootloader,也就是除了本身的bootloader外,另外安裝一個(gè)uboot在以前屬于linux kernel的nand分區上。但是出現了問(wèn)題:
1、從bootloader啟動(dòng)寫(xiě)在nand分區上的uboot,再通過(guò)uboot下載linux內核zImage,顯示解壓完成后就掛住了。
2、從bootloader通過(guò)USB下載和上面相同的uboot.bin,并在下載完成后運行該uboot,再通過(guò)uboot下載和上面相同的linux內核,內核可以成功啟動(dòng)。
這兩個(gè)方法唯一的區別就是,第一次是加載nand分區上的uboot運行,而第二次是下載uboot直接運行。


我寫(xiě)了一段閃燈的匯編,插入到內核啟動(dòng)代碼,發(fā)現,在head.S的__turn_mmu_on中,執行完mcr p15, 0, r0, c1, c0, 0(也就是開(kāi)啟mmu),系統就掛住了。通過(guò)實(shí)驗,我觀(guān)察到的r0值是0xc0007177。對了,kernel版本是2.6.14。不知道有沒(méi)有大俠可以幫我看看這是咋回事?





沙發(fā)
 樓主| 發(fā)表于 2013-10-10 20:41:27 | 只看該作者
搞定了,媽的,基礎知識不牢。。。原來(lái)是bootloader設置的啟動(dòng)參數區(0x30000100)作祟。
zImage解壓程序貌似會(huì )讀取這個(gè)區域,其內容是頁(yè)的大小和數量,bootloader設置分別為0x1000和0x4000,我在uboot啟動(dòng)zImage前將0x30000100和0x30000104兩個(gè)32位清零,kernel就能正常啟動(dòng)了。

大概就是這個(gè)意思,我還沒(méi)時(shí)間深究zImage的解壓過(guò)程,希望有懂的大俠澄清一下。
板凳
發(fā)表于 2013-10-14 20:22:38 | 只看該作者
多謝分享,樓主辛苦
您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復 返回頂部 返回列表
午夜高清国产拍精品福利|亚洲色精品88色婷婷七月丁香|91久久精品无码一区|99久久国语露脸精品|动漫卡通亚洲综合专区48页