uboot bootcmd 和bootargs参数详解

本文深入解析U-Boot环境变量bootcmd与bootargs的用法,包括常用参数设置及常见场景应用,帮助开发者更好地理解和配置U-Boot启动参数。
 U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。(http://www.cnblogs.com/cornflower/archive/2010/03/27/1698279.html)
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非常非常的灵活,所以设置的方法有很多中形式,具体的还应该根据你的平台具体的情况来设置。
<think>我收到用户的查询是关于在U-Boot中添加新的bootargs成员变量。用户引用了几个站内引用,这些引用提供了关于U-Boot的背景信息,包括它的功能、环境变量如bootcmdbootargs的重要性,以及如何查看环境变量。用户的直接问题是询问方法或实现步骤来新增bootargs成员变量。首先,我需要回顾bootargs环境变量的作用。从引用中得知,bootargs用于向Linux内核传递参数,比如指定根文件系统、控制台设置等。这是启动过程的关键部分。用户提到的引用提供了基础:引用[2]提到bootcmdbootargs环境变量在U-Boot中的作用,并指出修改它们是在启动Linux内核前的重要步骤。引用[3]展示了如何使用printenv命令查看环境变量,这是调试的基础。我的目标是引导用户完成添加新成员变量的过程。核心步骤包括:理解当前bootargs内容、编辑bootargs字符串、保存修改、并测试验证。我应该确保这些步骤清晰,避免技术术语过多,以适合嵌入式开发者的水平。回顾用户的历史对话,用户可能是在移植或定制U-Boot到特定硬件,如基于i.MX6ULL的开发板。引用中提到LCD网络驱动的问题,暗示用户有实际开发经验,所以我的回答应注重实用操作,而不是理论。关键步骤分解:-第一步:查看当前bootargs设置。用printenv命令,从引用[3]的示例中确认命令格式。-第二步:编辑bootargs字符串。添加新参数,如"mem=1G"或"my_param=value",需确保格式正确,用空格分隔参数。-第三步:保存修改。用saveenv命令将更改写入存储介质,如SPIFlash或eMMC。-第四步:验证。重启后重新查看bootargs,并启动内核观察是否生效。还需要提醒注意事项:参数的正确性、冲突避免、持久性保存问题。用户可能忘记saveenv导致丢失设置,这一点重要强调。最后,生成相关问题以深化理解:如何设置永久值、在内核中使用新参数、重置环境变量等。这有助于用户探索更多。</think> 要在U-Boot中添加新的bootargs成员变量,需通过修改或扩展环境变量`bootargs`实现。以下是具体步骤注意事项: --- ### **步骤详解** #### 1. **查看当前环境变量** 在U-Boot命令行使用`printenv bootargs`查看现有参数: ```bash => printenv bootargs bootargs=console=ttymxc0,115200 root=/dev/mmcblk1p2 rootwait rw ``` 此命令基于引用[3][^3]中`printenv`的用法,用于确认当前配置。 #### 2. **修改`bootargs`变量** - **直接追加新参数** 使用`setenv`命令添加新参数(以空格分隔),例如添加静默启动参数: ```bash => setenv bootargs ${bootargs} quiet my_param=value ``` - `${bootargs}`:保留原参数 - `quiet my_param=value`:新增的成员变量 - **完全覆写参数** 若需重构整个字符串: ```bash => setenv bootargs console=ttymxc0,115200 root=/dev/mmcblk1 rootwait my_param=value ``` #### 3. **保存环境变量** 使用`saveenv`将修改写入存储介质(如SPI Flash、eMMC): ```bash => saveenv ``` **关键提示**:未执行此命令时,修改仅在当前会话有效(重启后丢失)。 #### 4. **验证配置** - 重启后再次运行`printenv bootargs`确认新参数存在: ```bash => printenv bootargs bootargs=console=ttymxc0,115200 root=/dev/mmcblk1 rootwait rw quiet my_param=value ``` - 启动Linux内核后,在`/proc/cmdline`中检查参数是否生效: ```bash cat /proc/cmdline ``` --- ### **注意事项** 1. **参数冲突检查** - 避免重复定义同名参数(如两个`console=`),后定义的参数会覆盖前者。 - 验证新参数是否与内核兼容(例如`my_param`需内核驱动支持)。 2. **永久生效方式** - **编译时固化**:修改U-Boot源码中的默认环境变量(如`include/env_default.h`或板级配置文件),参考引用[2][^4]中修改`mx6ull_alientek_emmc.h`的方法。 - **运行时修改**:通过`setenv`+`saveenv`动态更新。 3. **常见问题** - 若修改后系统无法启动,尝试进入U-Boot恢复默认环境: ```bash => env default -f # 重置环境变量 => saveenv # 保存默认值 ``` --- ### **示例流程** ```bash # 查看原参数 => printenv bootargs bootargs=console=ttymxc0,115200 root=/dev/mmcblk1p2 rootwait rw # 追加新参数 => setenv bootargs ${bootargs} init=/sbin/init debug # 保存并重启 => saveenv => reset # 验证新参数 => printenv bootargs bootargs=console=ttymxc0,115200 root=/dev/mmcblk1p2 rootwait rw init=/sbin/init debug ``` --- ### **相关问题** 1. **如何让新参数在U-Boot编译时自动生效?** > 需修改板级配置文件中的`CONFIG_BOOTARGS`定义,或编辑默认环境变量表[^2][^4]。 2. **Linux内核如何解析`bootargs`中的自定义参数?** > 内核通过`__setup()`宏或设备树绑定机制解析参数,需在内核驱动中注册新参数的处理函数。 3. **U-Boot环境变量损坏后如何恢复?** > 使用`env default -a`重置为默认值,或通过USB/TFTP重新烧写U-Boot。 4. **`bootargs`与`bootcmd`有何区别?** > `bootcmd`定义启动命令序列(如加载内核、设备树),`bootargs`专用于向内核传递参数[^1][^2]。 通过以上操作,可安全添加自定义参数以满足特定硬件或调试需求。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值