1. 程式人生 > >uboot 啟動引數bootargs

uboot 啟動引數bootargs

    U-boot的環境變數值得注意的有兩個: bootcmd 和bootargs。
u-bootcmd
    前面有說過bootcmd是自動啟動時預設執行的一些命令,因此你可以在當前環境中定義各種不同配置,不同環境的引數設定,然後設定bootcmd為你經常使用的那種引數。
u-bootargs
    bootargs是環境變數中的重中之重,甚至可以說整個環境變數都是圍繞著bootargs來設定的。bootargs的種類非常非常的多,我們平常只是使用了幾種而已,感興趣的可以看看這篇文章說的很全:http://blog.chinaunix.net/u2/79570/showart_1675071.html。bootargs非常的靈活,核心和檔案系統的不同搭配就會有不同的設定方法,甚至你也可以不設定bootargs,而直接將其寫到核心中去(在配置核心的選項中可以進行這樣的設定),正是這些原因導致了bootargs使用上的困難。
    下面介紹一下bootargs常用引數,bootargs的種類非常的多,而且隨著kernel的發展會出現一些新的引數,使得設定會更加靈活多樣。

A. root 
用來指定rootfs的位置, 常見的情況有: 
    root=/dev/ram rw   
    root=/dev/ram0 rw
  請注意上面的這兩種設定情況是通用的,我做過測試甚至root=/dev/ram1 rw和root=/dev/ram2 rw也是可以的,網上有人說在某些情況下是不通用的,即必須設定成ram或者ram0,但是目前還沒有遇到,還需要進一步確認,遇到不行的時候可以逐一嘗試。

    root=/dev/mtdx rw
    root=/dev/mtdblockx rw
    root=/dev/mtdblock/x rw
    root=31:0x

上面的這幾個在一定情況下是通用的,當然這要看你當前的系統是否支援,不過mtd是字元裝置,而mtdblock是塊裝置,有時候你的挨個的試到底當前的系統支援上面那種情況下,不過root=/dev/mtdblockx rw比較通用。此外,如果直接指定裝置名可以的話,那麼使用此裝置的裝置號也是可以的。

    root=/dev/nfs
在檔案系統為基於nfs的檔案系統的時候使用。當然指定root=/dev/nfs之後,還需要指定nfsroot=serverip:nfs_dir,即指明檔案系統存在那個主機的那個目錄下面。

B. rootfstype 
    這個選項需要跟root一起配合使用,一般如果根檔案系統是ext2的話,有沒有這個選項是無所謂的,但是如果是jffs2,squashfs等檔案系統的話,就需要rootfstype指明檔案系統的型別,不然會無法掛載根分割槽.

C. console 
console=tty  使用虛擬串列埠終端裝置 .
console=ttyS[,options] 使用特定的串列埠,options可以是這樣的形式bbbbpnx,這裡bbbb是指串列埠的波特率,p是奇偶位(從來沒有看過使用過),n是指的bits。
console=ttySAC[,options] 同上面。

看你當前的環境,有時用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指令碼,一般是一個連線罷了。

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 是指開發板上的網絡卡,而不是主機上的網絡卡。

說完常見的幾種bootargs,那麼我們來討論平常我經常使用的幾種組合:
1). 假設檔案系統是ramdisk,且直接就在記憶體中,bootargs的設定應該如下:
setenv bootargs ‘initrd=0x32000000,0xa00000 root=/dev/ram0 console=ttySAC0 mem=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 rw rootfstype=jffs2 init=/linuxrc’

4). 假設檔案系統是基於nfs的,bootargs的設定應該如下
setenv bootargs ‘noinitrd mem=64M console=ttySAC0 root=/dev/nfs nfsroot=192.168.0.3:/nfs ip=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/nfs nfsroot=192.168.0.3:/nfs ip=192.168.0.5’


上面就是我們經常使用的幾種bootargs的組合,老實說,bootargs非常非常的靈活,所以設定的方法有很多中形式,具體的還應該根據你的平臺具體的情況來設定。

相關推薦

uboot 啟動引數bootargs

    U-boot的環境變數值得注意的有兩個: bootcmd 和bootargs。 u-bootcmd     前面有說過bootcmd是自動啟動時預設執行的一些命令,因此你可以在當前環境中定義各種不同配置,不同環境的引數設定,然後設定bootcmd為你經常使用的那

x210開發板uboot啟動引數設定與解析--朱友鵬嵌入式課程總結

x210開發板uboot啟動引數設定與解析 1.1 映象檔案已燒錄到開發板中 1.1.1 引數設定 setenv bootcmd "movi read kernel 30008000;bootm 30008000" setenv bootargs "console=ttyS

Zynq7020 uboot啟動引數修改

不知我的理解是否正確,因為我將uboot燒到qspi,預設是qspi啟動的,所以系統預設會在qspi裡尋找kernel,devicetree,filesystem,但我的需求是,我的uboot在qspi裡,這3個檔案放在SD卡或者emmc裡,也就是說我在qspi跑起來uboo

Uboot根據讀寫eeprom啟動標記,設定不同bootcmd和bootargs啟動引數

要實現此功能大體上分如下步驟: # 第一,uboot讀寫eeprom,根據讀到的值x (x = [ 0、1、2、3、... ...])組成(bootcmd<x>, bootargs<x>);然後獲取這組值,來設定bootcmd和bootargs。 #

uboot啟動uImage和rootfs(bootcmd和bootargs引數)

-boot的環境引數中有兩個和核心啟動相關的,它們是bootcmd和bootargs 1.u-boot中和環境引數有關的命令        printenv:列印當前環境引數        setenv param_name "value":設定環境引數     

飛思卡爾IMX6修改uboot預設啟動引數

硬體平臺:飛思卡爾IMX6 核心版本:kernel3.0.35 問題來源: 開發板的預設顯示方式是FPC介面800*480的屏,本專案中用到的屏是工業級的1024*768介面的LVDS屏,更換屏之後,除了移植相應的屏驅動和觸控驅動之外,就是uboot傳輸給核心的啟動引數b

uboot如何設定nfs的啟動引數

在uboot中設定環境變數: setenv nfsroot "/dev/nfs" setenv nfsip  "192.192.192.201" setenv nfsdir  "/home/xuewt/share/yocto/build/tmp/work/socfpga_c

移植u-boot-2015.07-rc3之uboot裁剪及啟動引數修改(九)

可以看到,現在make編譯出來的u-boot.bin有512kb大小,造成u-boot這麼巨大的原因是新版本的u-boot預設情況下支援非常多的命令,以至於很多不必要的.o檔案都被連結進u-boot.bin檔案中了。今天就來把u-boot中我用不到的命令都裁剪掉並設定預設的

uboot啟動linux核心小結(boot,bootd,boom,bootcmd,bootargs)

uboot在進行系統啟動和核心載入的時候被分為倆個階段, 第一階段主要是寫彙編程式碼,我沒有仔細研究,只是看了看移植好的針對mini2440的tekkman的uboot程式碼。 第二個階段為由C寫成

第1階段——uboot啟動函數bootm命令分析(9)

lean bank phy arm img 1.2 ota 缺省 過程 本節主要學習: 詳細分析UBOOT中"bootcmd=nand read.jffs2 0x30007FC0 kernel;bootm 0x30007FC0"中怎麽實現bootm命令啟動內核. 其中b

一,移植uboot,分析uboot啟動流程

寫到 位置 ESS fff setup boa soft bec 進入 文檔時間:2018-08-08 交叉編譯器:arm-linux-gcc-4.3.2 Ubuntu版本:16.04 uboot版本:2013.10 uboot啟動流程簡要如下:     a,設置CPU為管

MongoDB服務啟動和停止以及常用的啟動引數

一、Mongodb啟動命令引數說明    Mongodb的啟動命令可以使用  mongod –help檢視所有選項    mongod的主要引數有:   1.基本引數 --quiet #

[uboot] (第五章)uboot流程——uboot啟動流程

轉自https://blog.csdn.net/ooonebook/article/details/53070065   以下例子都以project X專案tiny210(s5pv210平臺,armv7架構)為例 [uboot] uboot流程系列: [project

[uboot] uboot啟動kernel篇(一)——Legacy-uImage & FIT-uImage

轉自https://blog.csdn.net/ooonebook/article/details/53495002 一、uImage 編譯kernel之後,會生成Image或者壓縮過的zImage。但是這兩種映象的格式並沒有辦法提供給uboot的足夠的資訊來進行load、jump或者驗證操

java中使用selenium設定chrome啟動引數和配置

1.給ChromeDriver配置禁止載入js,images ChromeOptions options = new ChromeOptions(); // 設定禁止載入項 Map<String, Object> prefs = new HashMap<String, Obje

MongoDB啟動引數說明

                                 MongoDB啟動引數說明 基本配置

通過ps -ef | grep java檢視到java程序相應jvm啟動引數

/opt/ln/java/bin/java -server -Xms4g -Xmx4g -XX:MetaspaceSize=512m -XX:MaxMetaspaceSize=512m -Xmn2g -XX:MaxDirectMemorySize=1g -XX:SurvivorRatio

Erlang---啟動引數學習/研究

分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow 也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!        

jvm 的啟動引數

java啟動引數共分為三類; 其一是標準引數(-),所有的JVM實現都必須實現這些引數的功能,而且向後相容; 其二是非標準引數(-X),預設jvm實現這些引數的功能,但是並不保證所有jvm實現都滿足,且不保證向後相容; 其三是非Stable引數(-XX),此類引數各個jvm實現會有所不同,將來可

JAVA啟動引數大全之三:非Stable引數

 前面我們提到用-XX作為字首的引數列表在jvm中可能是不健壯的,SUN也不推薦使用,後續可能會在沒有通知的情況下就直接取消了;但是由於這些引數中的確有很多是對我們很有用的,比如我們經常會見到的-XX:PermSize、-XX:MaxPermSize等等; 下面我們將就Java Hot