嵌入式系統燒寫uboot/bootloader/kernel的一般方法


嵌入式系統燒寫uboot/bootloader/kernel的一般方法
 
本文介紹了在嵌入式系統中燒寫uboot/bootloader/kernel 的一般方法,以及如果uboot或者內核出現錯誤,  www.2cto.com  
引導失敗等情況時如何重新燒寫uboot/kernel.
 
燒寫uboot/kernel的方式一般有兩種,一種是在linux本身(shell中),直接將uboot/kernel的影像文件(二進制文件)使用操作燒寫flash的命令燒寫到flash特定分區上,
 
另一種是在uboot界面上,通過配置serverip,ipaddr,使用tftp命令 下載uboot/kernel到flash上
 
例子如下:
 
//一,在linux的shell中燒寫uboot/kernel
 
mtd write命令是自定義的燒寫flash命令。
 
//燒寫uboot ,/dev/mtd0 是bootloader 的特定分區
 mtd write u-boot.bin /dev/mtd0 
 
//燒寫kernel, mtd1 是kernel的特定分區
mtd write vmlinux.elf /dev/mtd1
 
//重啟
reboot 
 
//二,在uboot界面中燒寫uboot/kernel,以kernel為例子
 
//在bootloader 界面中
 
//本機uboot 的ip地址
setenv ipaddr 10.10.167.10
 
//服務器ip地址
setenv serverip 10.10.167.249
 
//下載linux內核vmlinux52
tftpboot 0 vmlinux52
 
// 燒寫到flash 上。
// 0x20000000 是vmlinux52的存貯位置。 
// 0x1dd00000 是 系統內核的起始位置(每個設備位置不同), 
// +0x600000是文件長度
upgrade 0x20000000 0x1dd00000 +0x600000
 
// 重啟linux
 
bootoctliux
 
*************************************** **
 
如果因為uboot或者內核有錯誤而導致啟動失敗,出現卡死狀態等,那么需要判斷問題是出在uboot階段還是linux階段,這可以通過觀察啟動過程中的debug信息來判斷,
 
如果uboot出現問題是比較麻煩的,因為這需要有一個裝有正確的uboot/bootloader的flash芯片作為引導,
 
將系統重新引導至uboot界面中,之后再重新燒寫uboot到系統本身的flash中,進而燒寫內核(如有必要)。 
 
一,重新燒寫uboot
 
首先需要一個特定的PCLL(flash芯片),這個PCLL上固化了一個正確的bootloader, 通過這個bootloader可以成功進入bootloader界面, 在此條件下重新燒寫uboot/bootloader。
 
使用此PLCC的步驟是:
 
在系統下電情況下, 使用跳線/撥碼開關等將此系統的啟動方式變從外部flash(即PLCC)引導,
 
之后將系統上電, 這時會從PLCC 啟動。
 
啟動成功后,進入uboot界面,  即命令行顯示Dream 5220# #(類似命令行提示符)
 
此時將版卡的啟動方式變為 從 nor flash 啟動。  之后重新燒寫uboot到此nor flash 上。  
 
再用 kermit  來操作。
 
Kermit是一個串口服務工具,類似與minicom ,功能比minicom 多。
 
//kermit/usb0.cfg  是kermit 的配置文件, 在其中可以配置 /dev/ttyUSB0 等路徑
kermit -y kermit/usb0.cfg
 
-y kermit/usb0.cfg   指定配置文件。
 
該文件內容如下:
/*
 
set line /dev/ttyUSB0                                                                                                                
set speed 115200
set carrier-watch off 
set hardshake none
set flow-control none
robust
set file type bin 
set file name lit 
set rec pack 1000
set send pack 1000
set window 5
 
*/
將此文件保存在主目錄下, 命名為:kermit/usb0.cfg(可自定義)
 
執行后進入kermit 界面, 按 c 
 
進入 串口界面(就是設備的界面)
 
切換回kermit 界面快捷鍵:Ctrl + \  , 之后再按 c  。
 
執行:
Dream 5220# # detect  
 
顯示:
Checking for NOR flash...
Flash detect 33554432Mb
 
這說明flash狀態良好。
 
//讓串口進入接受狀態。
Dream 5220# # loadb 
 
進入kermit 界面: ctrl + \  按 c
 
執行:
send  uboot.bin
 
就是將當前目錄下的uboot.bin 文件發送給串口。
 
完成后,進入串口界面。
 
執行:
Dream 5220# # upgrade 0x20000000 0x1dc00000 +0xe0000
 
0x20000000 是 kermit 執行 send  后 將文件send 到的默認地址。
再將文件寫到nor flash 的首地址:0x1dc00000  +0xe0000為寫的長度。
 
執行:reset。讓系統重啟。
 
/*
 
至此,新的uboot燒寫完成,reset后, 如果還是不成功的話,那么問題肯定出在linux的的啟動階段或者新的uboot還是有問題,這可以通過啟動過程中的debug信息看出來
 
一,如果內核有問題,導致linux沒有進入shell界面,要重新進入Uboot環境,就是在reset 之后,一直按 ctrl + c  ,這樣在uboot啟動完成后, 不會進入kernel的啟動階段,而是停留在uboot的命令行中,
 
在這個uboot 環境下,燒寫新內核, 配置ipaddr,serverip等,同最開始的例子中操作是一樣的。
 
//本機uboot 的ip地址
setenv ipaddr 10.10.167.10
 
//服務器ip地址
setenv serverip 10.10.167.249
 
//下載linux內核vmlinux52
// 在服務器的tftpboot目錄下存在相應文件,搭建到tftp服務環境
tftpboot 0 vmlinux52
 
// 燒寫到flash 上。
// 0x20000000 是vmlinux52的存貯位置。 
// 0x1dd00000 是系統內核的起始位置(每個設備位置不同), 
// +0x600000是文件長度
upgrade 0x20000000 0x1dd00000 +0x600000
 
在reset 之前,一般還要設置一下環境變量。
 
比如
 
setenv linux_args mtdparts=octeon_nor0:1m(BOOT),7m(LINUX),21m(CONFIG),3m(MD)
 
setenv bootcmd 'bootoctlinux 0x1dd00000 coremask=0x3 mem=700'
 
//保存
saveenv
 
bootoctliux
 
二 ,如果新燒寫的uboot本身有問題,那么修改uboot代碼,編譯通過后, 使用PLCC重復上述燒寫過程。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM