u-boot 环境变量参数设置

今天原本是烧写内核,结果一不当心把uboot也整不能用了,无奈之下只好从新烧个uboot,等都弄好之后,发现系统仍是启动不了,原来是启动参数设置不对,因而找到了这篇文章,//是我添加的内容。html

 

原文地址:http://blog.chinaunix.net/u3/94312/showart_1923637.htmllinux

原文:服务器

     看到这个标题,可能以为这个并无什么的,其实否则,编好了u-boot了,可是如何来使用确不是那么简单的,想当初我将uboot制做出来后觉得所有都搞定了,屁颠屁颠的烧到板子上后可系统就是起不来,为何了,折腾了好久之后才发现是u-boot的环境变量设置错误,在后来的工做中,我发现一些有必定经验的人在这方面也是模模糊糊的扯不清,因此这里要讨论一下。app

 

    的环境变量是使用u-boot的关键,它能够由你本身定义的,可是其中有一些也是你们常用,约定熟成的,有一些是u-boot本身定义的,更改这些名字会出现错误,下面的表中咱们列出了一些经常使用的环境变量:测试

 

环境变量spa

描述.net

bootdelayunix

执行自动启动的等候秒数server

baudratehtm

串口控制台的波特率

netmask

以太网接口的掩码

ethaddr

以太网卡的网卡物理地址

bootfile

缺省的下载文件

bootargs

传递给内核的启动参数

bootcmd

自动启动时执行的命令

serverip

服务器端的ip地址

ipaddr

本地ip地址

stdin

标准输入设备

stdout

标准输出设备

stderr

标准出错设备

 

上面只是一些最基本的环境变量,请注意,板子里本来是没有环境变量的,u-boot的缺省状况下会有一些基本的环境变量,在你执行了saveenv以后,环境变量会第一次保存到flash中,以后你对环境变量的修改,保存都是基于保存在flash中的环境变量的操做。


    U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。

       bootcmd

    前面有说过bootcmd是自动启动时默认执行的一些命令,所以你能够在当前环境中定义各类不一样配置,不一样环境的参数设置,而后设置bootcmd为你常用的那种参数。//若是要输入分号,记得是这样:‘\;’,zImage用的是go addr,uImage用的是bootm addr,我是这样理解的。


      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=[;<mtddef]< p="">

:= :[,]

:= [@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很是很是的灵活,因此设置的方法有不少中形式,具体的还应该根据你的平台具体的状况来设置。

 

//mini2400运行OpenWrt:setenv bootargs noinitrd root=/dev/mtdblock3 rootfstype=jffs2 console=ttySAC0,115200 师兄给我解释mtdblock3:0是uboot,1是uboot环境变量,2是内核,3是文件系统。至于为何是ttySAC0而不是ttyS0,我也不自到。