U-boot中惯用参数设定及常用宏的解释和说明

U-boot中常用参数设定及常用宏的解释和说明

uboot功能很强,支持各种各样的启动方式,如:U盘启动,NFS启动,NAND Flash启动,NOR Flash启动……

1、环境变量的存储设置 
如u-boot中的savenv命令,它用来保存系统的环境变量到Flash中,当我们在开发板的配置文件中,使用的宏定义为:

执行savenv命令后环境变量会被保存到NOR Flash中去,而当我们使用的宏定义为:

这是,执行savenv后,环境变量会被存储到NAND Flash中去。
2、USB的支持
当你想利用uboot的USB进行U盘启动或者是USB传输时,需要添加宏:

3、内核启动相关宏
需要修改:

还有比较常用的命令有:

两个比较重要的宏定义有CONFIG_BOOTARGS和CONFIG_BOOTCOMMAND,CONFIG_BOOTARGS是u-boot向Linux内核传递的参数实际上这个宏值就是环境变量中的bootargs的值,CONFIG_BOOTCOMMAND是系统在上电自动执行时所执行的命令对应环境变量中bootcmd的值。
CONFIG_BOOTARGS和CONFIG_BOOTCOMMAND定义的是这两个环境变量的初始值,以后我们在u-boot烧写到Flash中后,再需要修改这两个变量,需要利用命令:
setenv bootargs 值……和 setenv bootcmd 值……来改变,如果想要断电后更新过的环境变量还能使用,需要执行savenv保存到flash中去,setenv只是修改环境变量在内存中的值。

下面我具几个具体的例子来说明bootcmd的使用方法: 

(1)利用NFS传输内核并完成启动,当Linux的内核在主机,我们想要把内核传输到开发板上启动时可以使用:

这样系统在启动会就会执行这个命令去将主机IP为"192.168.1.2"的目录"/home/yanghao/nfs/"下的内核复制到内存0x30008000,然后再跳转到该地址去执行。

(2)如果内核在NAND Flash中

u-boot先从NAND Flash中读取内核到内存,然后去执行内核

下面我具几个具体的例子来说明bootargs的使用方法: 

(1)当系统的文件系统在主机端时,可以使用nfs文件系统,这种方式很常用,便于文件系统的修改:

需要设置好主机的IP地址和DNS服务器地址,还有开发板的地址。文件系统在主机IP为"192.168.1.2"的目录"/home/yanghao/nfs/"下
(2)如果是其它的文件系统,如YAFFS文件系统则可以使用

内核会根据定义的分区表信息去读取yaffs文件系统在/dev/mtdblock2中