flash的一般分區: print(可縮寫為:pri):列印查看uboot這個軟體中集成的環境變數setenv、saveenv:設置、保存環境變數 如:設置環境變數: setenv abc 100刪除環境變數: setenv abc保存環境變數到存儲器:saveenv abc 100網路層的設置: ...
flash的一般分區:
其它數據 |
環境變數 |
可執行程式。如bootloader |
print(可縮寫為:pri):列印查看uboot這個軟體中集成的環境變數
setenv、saveenv:設置、保存環境變數
如:
設置環境變數: setenv abc 100
刪除環境變數: setenv abc
保存環境變數到存儲器:saveenv abc 100
網路層的設置:
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 到記憶體地址 20008000上面:tftp 20008000 a.txt
linux下安裝tftp服務端:
32bit sudo apt-get install tftpd-hpa
64bit sudo apt-get install tftpf openbsc-xinetd
bootm:
bootm傳遞r0,r1,r2還有bootargs
bootm 載入linux鏡像是載入uIamge,uIamge是由mkimage製作而來,和zIamge的差異是uIamge是zIamge壓縮過的,bootm需要先對uIamge解壓,解壓地址為內核入口地址。當解壓完成時uIamge和zIamge 幾乎是相同的,具體差異可以論述。uboot目前只能支持uImage啟動,不支持zImage啟動
go:
go命令本質就是改變當前pc值
內核啟動條件:內核、啟動參數、文件系統
啟動參數:(bootargs)
root= 啟動的根文件系統在哪個設備
init= 內核啟動後第一個可執行文件init進程從哪裡來
console= 內核啟動時,使哪個設備作為控制台
文件系統:內核與用戶交互的一個中介
文件系統的燒寫:NFS、Ramdisk
Ramdisk:記憶體磁碟
配置的內容:
root=/dev/ram
initrd= 0x21000000,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)
測試:
記憶體:20008000 uImage
21000000 initrd.img.gz
內核啟動步驟(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下設置啟動參數
setenv bootargs root=/dev/nfs nfsroot=192.168.10.110:/home/rocky/work/rootfs ip=192.168.10.122 init=/linuxrc console=ttySAC,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這個指令