UBOOT环境变量以及使用设置

看到这个标题,可能觉得这个并没有什么的,其实不然,编好了u-boot了,但是如何来使用确不是那么简单的,想当初我将uboot制作出来后以为全部都搞定了,屁颠屁颠的烧到板子上后可系统就是起不来,为什么了,折腾了很久以后才发现是u-boot的环境变量设置错误,在后来的工作中,我发现一些有一定经验的人在这方面也是模模糊糊的扯不清,所以这里要讨论一下。
 
    u-boot的环境变量是使用u-boot的关键,它可以由你自己定义的,但是其中有一些也是大家经常使用,约定熟成的,有一些是u-boot自己定义的,更改这些名字会出现错误,下面的表中我们列出了一些常用的环境变量:
 

环境变量
描述
bootdelay
  执行自动启动的等候秒数
baudrate
  串口控制台的波特率
netmask
  以太网接口的掩码
ethaddr
  以太网卡的网卡物理地址
bootfile
  缺省的下载文件
bootargs
  传递给内核的启动参数
bootcmd
  自动启动时执行的命令
serverip
  服务器端的ip地址
ipaddr
  本地ip 地址
stdin
  标准输入设备
stdout
  标准输出设备
stderr
  标准出错设备
 
上面只是一些最基本的环境变量,请注意,板子里原本是没有环境变量的,u-boot的缺省情况下会有一些基本的环境变量,在你执行了saveenv之后,环境变量会第一次保存到flash中,之后你对环境变量的修改,保存都是基于保存在flash中的环境变量的操作。
 
    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<n> 使用虚拟串口终端设备 <n>.
console=ttyS<n>[,options] 使用特定的串口<n>,options可以是这样的形式bbbbpnx,这里bbbb是指串口的波特率,p是奇偶校验位,n是指的bits。
console=ttySAC<n>[,options] 同上面。

 

 

 

看你当前的环境,有时用ttyS<n>,有时用ttySAC<n>,网上有人说,这是跟内核的版本有关,2.4用ttyS<n>,2.6用ttySAC<n>,但实际情况是官方文档中也是使用ttyS<n>,所以应该是跟内核版本没有关联的。可以查看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=<mtddef>[;<mtddef]
<mtddef> := <mtd-id>:<partdef>[,<partdef>]
 <partdef> := <size>[@offset][<name>][ro]
 <mtd-id> := unique id used in mapping driver/device
<size>    := standard linux memsize OR "-" to denote all remaining space
<name>    := (NAME)
因此你在使用的时候需要按照下面的格式来设置:
mtdparts=mtd-id:<size1>@<offset1>(<name1>),<size2>@<offset2>(<name2>)
这里面有几个必须要注意的:
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环境变量的配置和使用示例。首先,我需要回忆一下U-Boot的基本知识,环境变量在U-Boot中的作用,以及如何操作它们。根据用户提供的引用内容,环境变量存储在flash中,默认值来自源代码,用户可以通过命令进行设置和保存。 首先,我应该解释什么是U-Boot环境变量,它们的作用是什么。然后,详细说明如何查看、设置、保存环境变量,并提供一些常见的使用示例,比如设置网络参数或启动命令。需要确保步骤清晰,命令正确,并且符合用户的实际操作需求。 用户可能想知道具体的命令语法,比如printenv、setenv、saveenv使用方法。还要注意环境变量的优先级,当变量为空时使用默认值,否则使用用户设置的值。可能需要提到一些常见变量,如serverip、ipaddr、ethaddr、bootcmd和bootargs,这些在引用中都有涉及。 另外,用户可能需要示例来更好地理解,比如设置serverip的步骤,或者配置启动参数。需要确保示例准确,并且命令格式正确。同时,要注意用户可能的错误,比如忘记保存环境变量,导致重启后配置丢失,所以需要强调saveenv的重要性。 还要考虑用户可能遇到的问题,比如如何恢复默认设置,或者处理环境变量存储损坏的情况。可以简要提到这些情况,但主要焦点还是放在配置和使用示例上。 最后,根据用户的要求生成相关问题,这些问题应该与U-Boot环境变量的高级配置、存储位置、调试方法等相关,帮助用户进一步学习。</think>### U-Boot 环境变量的配置与使用详解 U-Boot 环境变量是嵌入式系统启动过程中用于存储配置参数的关键机制,其优先级规则为:若变量值为空则使用代码默认值,若已设置则优先使用用户定义值[^1]。以下从基础操作到典型场景逐步说明: #### 一、环境变量基础操作 1. **查看所有环境变量** ```bash => printenv baudrate=115200 bootcmd=run distro_bootcmd serverip=192.168.1.100 # 未设置使用默认值 ``` 通过该命令可验证当前生效的变量值[^3]。 2. **设置/修改变量** ```bash => setenv serverip 192.168.1.100 => setenv bootdelay 3 # 修改启动等待时间 ``` 变量修改后仅在内存中生效,需执行保存操作才能持久化[^1]。 3. **保存到存储设备** ```bash => saveenv Saving Environment to SPI Flash... OK ``` 该操作将当前环境变量写入NOR Flash或eMMC等存储介质。 #### 二、典型配置场景示例 1. **网络参数配置** ```bash => setenv ipaddr 192.168.1.50 # 设备IP => setenv serverip 192.168.1.100 # TFTP服务器IP => setenv netmask 255.255.255.0 => saveenv ``` 这些参数直接影响`tftp`命令下载内核镜像等网络操作[^2]。 2. **MAC地址设置** ```bash => setenv ethaddr 00:0a:35:12:34:56 => saveenv ``` 注意:MAC地址首次设置后不可修改,需清除环境变量分区才能重置[^2]。 3. **自定义启动流程** ```bash => setenv bootcmd 'tftp 0x82000000 zImage; bootm 0x82000000' => setenv bootargs console=ttyS0,115200 root=/dev/mmcblk0p2 => saveenv ``` `bootcmd`定义自动执行的启动命令,`bootargs`向内核传递参数[^2]。 #### 三、高级操作技巧 1. **多环境备份机制** 修改`envsize`和`envnumber`实现多份环境备份: ```bash => setenv envsize 0x20000 # 单个环境区大小 => setenv envnumber 2 # 双备份配置 => saveenv ``` 2. **环境变量恢复** ```bash => env default -f # 恢复所有默认值 => saveenv # 清除自定义设置 ``` 3. **脚本化配置** 通过`;`分隔多个命令实现批量配置: ```bash => setenv init_cmd 'setenv ipaddr 192.168.1.10; setenv serverip 192.168.1.100; saveenv' => run init_cmd ``` #### 四、调试与验证 1. **变量值有效性检查** ```bash => env info env_valid = valid env_ready = true env_use_default = false ``` 该命令显示环境变量存储状态[^3]。 2. **Android系统读取验证** 通过`envtool`工具验证变量是否传递到系统层: ```bash # envtool r factory_test ubootenv init successful.(0) on ``` 这确认了U-Boot环境变量与Android系统的集成效果[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值