嵌入式Linux系統移植——uboot常用命令


flash的一般分區:

其它數據
環境變量
可執行程序。如bootloader

 

 

 

 

 

print(可縮寫為:pri):打印查看uboot這個軟件中集成的環境變量
setenv、saveenv:設置、保存環境變量

如:
設置環境變量:    setenv  abc 100
刪除環境變量:    setenv  abc
保存環境變量到存儲器:saveenv  abc 100
網絡層的設置:               setenv ipaddr 10.21.12.10

nand:
nand [動詞] [內存地址] [nandflash的內部地址] [搬移大小]

  • nand中5M空間的數據讀取到內存地址2100 0000

5M = 5* 1M ,1M = 2^20 = 0x100000

讀數據:nand read 21000000  500000 1024

  • nand把內存地址2100 0000的值寫到5M空間

初始化:nand erase 500000 1024
寫數據:nand write 21000000  500000 1024

tftp:
設置、保存本機IP:
setenv    ipaddr 192.168.9.120
saveenv ipaddr 192.168.9.120
設置服務器ip:
setenv serverip 192.168.9.3
利用tftp傳遞文件a.txt 到內存(s5pv210的dram中)地址 20008000上面:tftp   20008000  a.txt    

Ubuntu14.04環境下配置TFTP服務器

inux下安裝tftp服務端:
32bit sudo apt-get install tftpd-hpa
64bit sudo apt-get install tftpf openbsc-xinetd

bootm:
bootm傳遞r0,r1,r2還有bootargs

bootm 21000000

bootm 加載linux鏡像是加載uImage,uImage是由mkimage制作而來,和zImage的差異是uImage是zImage壓縮過的,bootm需要先對uImage解壓,解壓地址為內核入口地址。當解壓完成時uImage和zImage 幾乎是相同的,具體差異可以論述。uboot目前只能支持uImage啟動,不支持zImage啟動

zImage轉換為uImage

mkimage -A arm -O linux -T kernel -C none -a 20008000 -e 20008000 -n "linux-2.6.36" -d zImage uImage
go:
go命令本質就是改變當前pc值

 

內核啟動條件:內核、啟動參數、文件系統
啟動參數:(bootargs)
root=      啟動的根文件系統在哪個設備
init=       內核啟動后第一個可執行文件init進程從哪里來(指定內核啟動后,運行的第一個腳本)
console=    內核啟動時,使哪個設備作為控制台

initrd (boot loader initialized RAM disk),就是由uboot 初始化的內存盤。
在 linux內核啟動前,uboot會將存儲介質中的 initrd 文件加載到內存,內核啟動時會在訪問真正的根文件系統前先訪問該內存中的 initrd 文件系統

文件系統:內核與用戶交互的一個中介

文件系統的燒寫:NFS、Ramdisk

Ramdisk:內存磁盤

配置的內容:
root=/dev/ram
initrd= 0x22000000,8M    (設備信息(文件系統的基地址,大小))
init=/linuxrc
console=ttySAC0
NFS:網絡文件系統(TCP/IP協議  C/S架構)優勢:實際調試無需繁雜的復制運行程序

PC機服務端安裝:
1、搜索 apt-cache  search nfs-
2、安裝 sudo apt-get install nfs-kernel-server
PC中nfs配置文件:/etc/exports
(/home/rocky/work/rootfs)       *(rw,sysnc,no_substree_check))  
//第一列為開放權限的目錄        第二列中的*為IP地址,指出要輪詢哪些主機訪問,*代表任意主機   第二列括號內容為訪問服務開啟的權限 (可讀可寫,同步,安全機制)    
3、重啟服務:sudo /etc/init.d/nfs-kernel-server restart
開發板客戶端:
設置bootargs(客戶端根文件位置,NFS服務端共享目錄的IP和絕對路徑,客戶端系統的IP,init console)

內核啟動步驟(Ramdisk文件系統):
第一步:安裝並啟動uboot

第二步:通過tftp服務將內核文件及文件系統分別下載到指定位置
tftp  20008000 uImage
tftp 21000000 initrd.img.gz
第三步:設置啟動參數
setenv bootargs root=/dev/ram initrd=0x21000000,8M  init=/linuxrc console=ttySAC0,115200
第四步:bootm 20008000 
   至此內核啟動完成。

 內核啟動步驟(NFS文件系統)

優勢:由於將PC服務端的一個目錄鏈接作為開發板內核的文件系統,所以,可以在PC服務機上編輯調試代碼,調試生成的結果會自動更新至開發板客戶端系統中

PC服務端動作:

第一步:PC服務端安裝、配置NFS服務器

第二步:解壓服務端已存在的鏡像文件initrd.img.gz 

第三步:掛載鏡像文件到當前鏡像所在位置的swap目錄下  sudo mount -t ext2  initrd.img  ./swap/

第四步:進入開放權限的目錄將swap目錄下的所有內容復制進來。

sudo cp  -a  /home/rocky/tftpboot/swap/*    ./ 

目標開發板的動作

第一步:安裝uboot

第二步:在uboot下設置傳遞給內核的啟動參數bootargs
setenv bootargs root=/dev/nfs nfsroot=192.168.10.110:/home/rocky/work/rootfs ip=192.168.10.122 init=/linuxrc console=ttySAC0,115200

第三步:將內核文件加載至指定位置tftp 20008000 uImage

第四步:啟動bootm 20008000

 自動運行:

uboot環境變量中設置bootdelay、bootcmd
上電延時:bootdelay=10
Raddisk文件系統啟動內核時
設置運行時的動作命令:
bootcmd= nand read 20008000 100000 200000;nand read 21000000 56000000 400000;bootm 20008000

而NFS文件系統則無法做bootcmd這個指令


免責聲明!

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



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