U-boot的环境变量: bootcmd 和bootargs

 
U-boot的环境变量: bootcmd 和bootargs
u-bootcmd
bootcmd是uboot自动启动时默认执行的一些命令,因此你可以在当前环境中定义各种不同配置,不同环境的参数设置,然后设置bootcmd为你经常使用的那种参数。
 
现在我的bootcmd的参数设置为:bootcmd=nfs 0x30008000 192.168.1.149:/opt/FriendlyARM/uImage;bootm
表示uboot以nfs的方式加载位置在于192.168.1.149:/opt/FriendlyARM/这个目录下面的uImage文件,加载之后再执行bootm。

bootm 指令是专门用于启动在SDRAM中的用U-boot的mkimage工具处理过的内核映像。因此在执行bootm命令的时候必须确保image文件已经在内存中。


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/mtdblockx rw 表示你的根文件系统所在目录,其中x的取值需要根据自己的flash分区来进行确定。
Creating 5 MTD partitions on "NAND 128MiB 3,3V 8-bit":
0x000000000000-0x000000040000 : "supervivi"
0x000000040000-0x000000060000 : "param"
0x000000060000-0x000000560000 : "Kernel"
0x000000560000-0x000040560000 : "root"
mtd: partition "root" extends beyond the end of device "NAND 128MiB 3,3V 8-bit" -- size truncated to 0x7aa0000
0x000000000000-0x000040000000 : "nand"
mtd: partition "nand" extends beyond the end of device "NAND 128MiB 3,3V 8-bit" -- size truncated to 0x8000000
在上面的flash分区中第四个分区用来存放根文件系统,因此mtdblaockx中的x的值应该是3.(从0始编号)
rooot=/dev/nfs
在文件系统为 基于nfs的文件系统的时候使用。当然指定root=/dev/nfs之后,还需要指定 nfsroot=serverip:nfs_dir,即指明文件系统存在那个 主机的那个目录下面
我的bootargs参数设置为:
bootargs=noinitrd root=/dev/nfs proto=tcp,nolock,nfsvers=3, rw nfsroot=192.168.1.149:/mini2440/rootfs ip=192.168.1.146:192.168.1.149::255.255.255.0 console=ttySAC0,115200 init=/linuxrc mem=64M
就是以nfs文件系统的方式来加载linux文件系统的

B. rootfstype
这个选项需要跟root一起配合使用,一般如果根文件系统是ext2的话,有没有这个选项是无所谓的,但是如果是jffs2,squashfs等文件系统的话,就需要rootfstype指明文件系统的类型,不然会无法挂载根分区.

C. console
console=tty 使用 虚拟串口终端设备 .
console=ttyS[,options] 使用 特定的串口,options可以是这样的形式bbbbpnx,这里bbbb是指 串口的波特率,p是奇偶位(从来没有看过使用过),n是指的bits。
console=ttySAC[,options] 同上面。

console=ttySAC0,115200 其参数中为什么要设置成ttySAC0,不知道是为什么?
在linux内核中 linux/drivers/serial/samsuing.c中定义了宏#define S3C24XX_SERIAL_NAME "ttySAC0" 我自己试图将它改为其他值
#define S3C24XX_SERIAL_NAME "ttySuiYuan0“,同时uboot的参数中 也改为console=ttySuiYuan0,编译内核,下载,但是最后不行内核启动如下就没有了。

done
Bytes transferred = 2268932 (229f04 hex)
## Booting kernel from Legacy Image at 30008000 ...
   Image Name:   linux_kernel_2012-02-06 14:54:15
   Created:      2012-02-06   6:54:15 UTC
   Image Type:   ARM Linux Kernel Image (uncompressed)
   Data Size:    2268868 Bytes =  2.2 MB
   Load Address: 30008000
   Entry Point:  30008040
   Verifying Checksum ... OK
   XIP Kernel Image ... OK
OK

Starting kernel ...

Uncompressing Linux................................................................................................................................................... done, booting the kernel.

最后没办法,又该为了:#define S3C24XX_SERIAL_NAME "ttySAC0"

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脚本,一般是一个连接罢 了。
此参数在自己制作的文件系统中,可有可无,同时根文件系统目录中的/linuxrc文件也非必须。我试验过。
跟linuxrc相关的代码可有在uboot中找到。

if (execute_command) {
run_init_process(execute_command);
printk(KERN_WARNING "Failed to execute %s. Attempting "
"defaults...\n", execute_command);
}
run_init_process("/sbin/init");
run_init_process("/etc/init");
run_init_process("/bin/init");
run_init_process("/bin/sh");

panic("No init found. Try passing init= option to kernel.");
看看这个代码就知道了,如果没有找到linuxrc,则只要下面的
run_init_process("/sbin/init");
run_init_process("/etc/init");
run_init_process("/bin/init");
run_init_process("/bin/sh");

中任意一条能执行也是OK的,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非常非常的灵活,所以设置的方法有很多中形式,具体的还应该根据你的平台具体的情况来设置。

原文地址 http://m.cnblogs.com/65491/1698279.html
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 以下是一个基本的 U-Boot 脚本,用于配置 SPI Flash。该脚本使用 `sf probe` 命令探测 SPI Flash 设备,然后设置 U-Boot 环境变量来存储 Flash 设备的参数。请注意,此示例中的参数值需要根据您的 Flash 设备进行更改。 ``` # 定义 Flash 设备参数 setenv spi_flash_addr 0x0 # Flash 设备地址 setenv spi_flash_size 0x800000 # Flash 设备大小 # 探测 Flash 设备 sf probe # 将 Flash 设备参数存储到环境变量中 setenv bootargs root=/dev/mtdblock0 rootfstype=jffs2 rw setenv bootcmd 'sf read ${loadaddr} ${spi_flash_addr} ${spi_flash_size}; bootm' saveenv ``` 在这个例子中,`spi_flash_addr` 表示 Flash 设备的起始地址,`spi_flash_size` 表示 Flash 设备的大小。`sf probe` 命令用于探测 SPI Flash 设备,并且将 Flash 设备参数存储到 U-Boot 环境变量中。最后,`bootcmd` 环境变量定义了如何从 Flash 设备启动系统。 ### 回答2: 以下是一个使用u-boot脚本配置SPI闪存的示例: ``` # 使用U-Boot脚本配置SPI闪存示例 # 首先,我们需要加载SPI闪存驱动 # 根据硬件版本和芯片型号进行适配 # 这里我们以Spansion SPI闪存为例 sf probe # 然后,我们需要设置闪存的相关参数 # 首先是闪存器件的名称 setenv spi_flash_name "spansion" # 接下来是闪存器件的页大小 # 这里以256字节为例 setenv spi_flash_page_size 256 # 然后是扇区大小 # 这里以4KB为例 setenv spi_flash_sector_size 4096 # 最后是闪存总大小 # 这里以32MB为例 setenv spi_flash_total_size 32M # 配置完成后,可以将相关参数保存到环境变量中 saveenv # 如果需要擦除整个闪存,可以使用以下命令 sf erase 0 ${spi_flash_total_size} # 如果需要读取闪存中的数据,可以使用以下命令 sf read ${loadaddr} 0 ${filesize} # 如果需要将数据写入闪存,可以使用以下命令 sf write ${loadaddr} 0 ${filesize} # 使用以上命令和参数,我们可以在U-Boot环境中配置和操作SPI闪存。 ``` 请注意,实际的配置和操作可能因硬件和芯片型号不同而有所不同。以上示例仅供参考,具体操作步骤和参数应根据实际情况进行适配。 ### 回答3: 下面是一个示例的u-boot脚本配置SPI Flash的例子: ``` # 定义相关环境变量 setenv spi_flash_addr 0x1000000 # SPI Flash起始地址 setenv kernel_image_addr 0x200000 # 内核镜像在内存中的加载地址 setenv dtb_addr 0x400000 # 设备树在内存中的加载地址 # 配置SPI Flash sf probe 0:0 # 扫描并初始化第0个SPI Flash设备 sf erase ${spi_flash_addr} 0x100000 # 擦除SPI Flash的前1MB空间 # 将内核镜像和设备树加载到内存中 tftp ${kernel_image_addr} kernel.img # 从TFTP服务器下载内核镜像 tftp ${dtb_addr} device_tree.dtb # 从TFTP服务器下载设备树 # 将内核镜像和设备树写入SPI Flash sf write ${kernel_image_addr} ${spi_flash_addr} 0x100000 # 将内核镜像写入SPI Flash的第1MB位置 sf write ${dtb_addr} ${spi_flash_addr} 0x200000 # 将设备树写入SPI Flash的第2MB位置 # 设定内核启动参数 setenv bootargs 'console=ttyS0,115200 root=/dev/mtdblock2 rootfstype=jffs2' # 启动内核 bootm ${kernel_image_addr} - ${dtb_addr} ``` 这个例子展示了如何使用u-boot脚本配置SPI Flash。首先定义了SPI Flash的起始地址,并擦除了前1MB的空间。然后从TFTP服务器下载内核镜像和设备树,并将它们写入SPI Flash的相应位置。接着设置内核启动参数,并最后启动内核

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值