Bootargs參數詳解
Bootargs參數詳解
U-boot的環境變量值得注意的有兩個: bootcmd 和bootargs。
一:bootcmd
bootcmd是自動啟動時默認執行的一些命令,因此你可以在當前環境中定義各種不同配置,不同環境的參數設置,然后設置bootcmd為你經常使用的那種參數,而且在bootcmd中可以使用調用的方式,方便修改。
eg:setenv bootcmd ‘setenv bootargs $(bootargs)root=$(rootfs) nfsroot=$(serverip):$(nsworkdir) ;nboot 0x80800000 0x4000000x200000;bootm 0x80800000’
二:bootargs
bootargs是環境變量中的重中之重,甚至可以說整個環境變量都是圍繞着bootargs來設置的。bootargs的種類非常非常的多,我們平常只是使用了幾種而已。bootargs非常的靈活,內核和文件系統的不同搭配就會有不同的設置方法,甚至你也可以不設置 bootargs,而直接將其寫到內核中去(在配置內核的選項中可以進行這樣的設置),正是這些原因導致了bootargs使用上的困難。
下面介紹一下bootargs常用參數,bootargs的種類非常的多,而且隨着kernel的發展會出現一些新的參數,使得設置會更加靈活多樣。
A. root
用來指定rootfs(文件系統)的位置, 常見的情況有:
1.
root=/dev/ram rw
root=/dev/ram0 rw
請注意上面的這兩種設置情況是通用的,我做過測試甚至root=/dev/ram1rw和root=/dev/ram2 rw也是可以的,網上有人說在某些情況下是不通用的,即必須設置成ram或者ram0,但是目前還沒有遇到,還需要進一步確認,遇到不行的時候可以逐一嘗試。此種方法用的也很少,因為大多數是用nandflash。2.
root=/dev/mtdx rw
root=/dev/mtdblockx rw
root=/dev/mtdblock/x rw
上面的這幾個在一定情況下是通用的,當然這要看你當前的系統是否支持,不過mtd是字符設備,而mtdblock是塊設備,有時候你的挨個的試到底當前的系統支持上面那種情況下,不過root=/dev/mtdblockxrw比較通用。此外,如果直接指定設備名可以的話,那么使用此設備的設備號也是可以的。這個地方要看你的系統啟動時MTD分區情況確認是哪個分區存放文件系統,如下圖。或者在內核源碼的arch/arm/mach-davinci/board-dm365.evm.或者arch/am/plat-s3c24xx/common-smdk.c中的smdk_default_nand_part結構數組中查看,注意是從mtdblock0開始的
這種配置是在nand中已經拷貝好文件系統時這樣配置(如果nand中沒有,此參數這樣配置會找不到文件系統的,出現的錯誤很多,可能會說unmount….或者panic –not syncing:VFS:unable timount root fs on unknown-block)
此時的解決方法最好是把板子nand全部擦出,重新燒寫。
3.
root=/dev/nfs
在文件系統為基於nfs的文件系統的時候使用,也就是說文件系統不在板子上,而是用NFS共享的服務器上的。當然指定root=/dev/nfs之后,還需要指定nfsroot=serverip:nfs_dir,serverip是服務器的IP,dir即指明文件系統存在那個主機的那個目錄下面。
注意:要確保在服務器中把此路徑下的文件添加到NFS共享,添加上共享的文件會有個小插頭的樣子。
用NFS共享服務器上的文件系統這種方法很好,這樣板子上的系統就可以起來了,可以再板子的終端里輸入命令了,在班子中將存放文件系統的分區掛載一下eg:mount /dev/mtdblock4 /mnt,這樣將服務器上做好的文件系統直接拷貝到/mnt文件下就好了eg:cp –rm * /mnt ,*代表當前路徑下的所有內容,無需再用maketools將文件系統制作成二進制文件的形式用tftp或者NFS燒寫到nand中了。
B. rootfstype
這個選項需要跟root一起配合使用,一般如果根文件系統是ext2的話,有沒有這個選項是無所謂的,但是如果是jffs2,squashfs等文件系統的話,就需要rootfstype指明文件系統的類型,不然會無法掛載根分區.(具體是怎樣無法掛載的這個還待測,是無法掛載nand中的還是虛擬機中的,待測)
eg:rootfstype=yaffs2
C. console
1.
console=tty 使用虛擬串口終端設備 .
console=ttyS[,options] 使用特定的串口,options可以是這樣的形式bbbbpnx,這里bbbb是指串口的波特率,p是奇偶位(從來沒有看過使用過),n是指的bits。
2.
console=ttySAC[,options] 同上面。
eg:DM365中:console=ttySAC0,115200n8
看你當前的環境,有時用ttyS,有時用ttySAC,網上有人說,這是跟內核的版本有關,2.4用ttyS,2.6用ttySAC,但實際情況是官方文檔中也是使用ttyS,所以應該是跟內核版本沒有關聯的。可以查看Documentation/serial-console.txt找到相關描述。
D. mem
mem=xxM 指定內存的大小,不是必須的
E. ramdisk_size (一般不用)
ramdisk=xxxxx 不推薦
ramdisk_size=xxxxx 推薦
上 面這兩個都可以告訴ramdisk 驅動,創建的ramdisk的size,默認情況下是4m(s390默認8M),你可以查看Documentation/ramdisk.txt找到相關的描述,不過ramdisk=xxxxx在新版的內核都已經沒有提了,不推薦使用。
F. initrd, noinitrd
當你沒有使用ramdisk啟動系統的時候,你需要使用noinitrd這個參數,但是如果使用了的話,就需要指定initrd=r_addr,size,r_addr表示initrd在內存中的位置,size表示initrd的大小。
G. init
init 指定的是內核啟起來后,進入系統中運行的第一個腳本,一般init=/linuxrc, 或者init=/etc/preinit,preinit的內容一般是創建console,null設備節點,運行init程序,掛載一些文件系統等等操作。請注意,很多初學者以為init=/linuxrc是固定寫法,其實不然,/linuxrc指的是/目錄下面的linuxrc腳本,一般是一個連接罷了。
此參數一般不需要設置,以為內核源碼中有一定的啟動項,內核如何啟動init進程在內核的init/main.c static init noinline init_post(void)
若出現No init found Try passing init=這種錯誤的時候可能原因是內核找不到文件系統或者無法掛載文件系統,不用考慮是init參數設置的錯誤。
Eg: kernelpanic-nosyncing :no init found.Tying init= option to know
此錯誤的原因是因為在root=/dev/mtdblock4但是nand中根本就沒有燒寫文件系統,而不是因為init參數設置不對
H. mtdparts mtdparts=fc000000.nor_flash:1920k(linux),128k(fdt),20M(ramdisk),4M(jffs2),38272k(user),256k(env),384k(uboot)
要 想這個參數起作用,內核中的mtd驅動必須要支持,即內核配置時需要選上Device Drivers ---> Memory Technology Device (MTD) support---> Command line partition table parsing
mtdparts的格式如下:
mtdparts=[;
:= :[,]
:= [@offset][][ro]
:= unique id used in mapping driver/device
:= standard linux memsize OR "-" to denote all remaining space
:= (NAME)
因此你在使用的時候需要按照下面的格式來設置:
mtdparts=mtd-id:@(),@()
這里面有幾個必須要注意的:
a. mtd-id 必須要跟你當前平台的flash的mtd-id一致,不然整個mtdparts會失效
b. size在設置的時候可以為實際的size(xxM,xxk,xx),也可以為'-'這表示剩余的所有空間。
舉例:
假設flash 的mtd-id是sa1100,那么你可以使用下面的方式來設置:
mtdparts=sa1100:- → 只有一個分區
mtdparts=sa1100:256k(ARMboot)ro,-(root) → 有兩個分區
可以查看drivers/mtd/cmdlinepart.c中的注釋找到相關描述。
I. ip
指定系統啟動之后網卡的ip地址,如果你使用基於nfs的文件系統,那么必須要有這個參數,其他的情況下就看你自己的喜好了。設置ip有兩種方法:
ip = ip addr
ip=ip addr:server ip addr:gateway:netmask::which netcard:off
這兩種方法可以用,不過很明顯第二種要詳細很多,請注意第二種中which netcard 是指開發板上的網卡,而不是主機上的網卡。
說明一下,如果用NFS或者為了ping通的話只需設置三個就可以了,ipaddr、serverip、eth就好了。
J.
總結:bootcmd可以使用調用的方式,方便以后的修改,bootargs我試着用同樣的方式的時候系統起不來。
下面附上DM365能夠用NFS掛載虛擬機中的文件系統時候參數設置
DM365能夠成功掛載nandflash中的文件系統時的設置只需要把root=dev/nfs 改為root=/dev/mtdblock4就好
H:常見的幾種形式
說完常見的幾種bootargs,那么我們來討論平常我經常使用的幾種組合:
1). 假設文件系統是ramdisk,且直接就在內存中,bootargs的設置應該如下:
setenv bootargs ‘initrd=0x32000000,0xa00000 root=/dev/ram0 console=ttySAC0mem=64M init=/linuxrc’
2). 假設文件系統是ramdisk,且在flash中,bootargs的設置應該如下:
setenv bootargs ‘mem=32M console=ttyS0,115200 root=/dev/ram rw init=/linuxrc’
注意這種情況下你應該要在bootm命令中指定ramdisk在flash中的地址,如bootm kernel_addr ramdisk_addr(fdt_addr)
3). 假設文件系統是jffs2類型的,且在flash中,bootargs的設置應該如下
setenv bootargs ‘mem=32M console=ttyS0,115200 noinitrd root=/dev/mtdblock2 rwrootfstype=jffs2 init=/linuxrc’
4). 假設文件系統是基於nfs的,bootargs的設置應該如下
setenv bootargs ‘noinitrd mem=64M console=ttySAC0 root=/dev/nfsnfsroot=192.168.0.3:/nfsip=192.168.0.5:192.168.0.3:192.168.0.3:255.255.255.0::eth0:off’
或者
setenv bootargs ‘noinitrd mem=64M console=ttySAC0 root=/dev/nfsnfsroot=192.168.0.3:/nfs ip=192.168.0.5’
上面就是我們經常使用的幾種bootargs的組合,老實說,bootargs非常非常的靈活,所以設置的方法有很多中形式,具體的還應該根據你的平台具體的情況來設置。
江南大學物聯網工程C426實驗室
2013.10.23
————————————————
版權聲明:本文為CSDN博主「zhangjikuan」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/zhangjikuan/article/details/22091335