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 上 面的这几个在一定情况下是通用的,当然这要看你当前的系统是否支持,不过mtd是字符设备,而mtdblock是块设备,有时候你的挨个的试到底当前的系 统支持上面那种情况下,不过root=/dev/mtdblockx rw比较通用。此外,如果直接指定设备名可以的话,那么使用此设备的设备号也是可以的。 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=ttySAC0,115200 其参数中为什么要设置成ttySAC0,不知道是为什么? 在linux内核中 linux/drivers/serial/samsuing.c中定义了宏#define S3C24XX_SERIAL_NAME "ttySAC0" 我自己试图将它改为其他值
#define S3C24XX_SERIAL_NAME "ttySuiYuan0“,同时uboot的参数中也改为console=ttySuiYuan0,编译内核,下载,但是最后不行内核启动如下就没有了。
done Starting kernel ... Uncompressing Linux................................................................................................................................................... done, booting the kernel. 最后没办法,又该为了:#define S3C24XX_SERIAL_NAME "ttySAC0"
D. mem E. ramdisk_size F. initrd, noinitrd G. init 此参数在自己制作的文件系统中,可有可无,同时根文件系统目录中的/linuxrc文件也非必须。我试验过。
跟linuxrc相关的代码可有在uboot中找到。
if (execute_command) { panic("No init found. Try passing init= option to kernel."); H. mtdparts mtdparts的格式如下: I. ip 说完常见的几种bootargs,那么我们来讨论平常我经常使用的几种组合: 2). 假设文件系统是ramdisk,且在flash中,bootargs的设置应该如下: 3). 假设文件系统是jffs2类型的,且在flash中,bootargs的设置应该如下 4). 假设文件系统是基于nfs的,bootargs的设置应该如下 上面就是我们经常使用的几种bootargs的组合,老实说,bootargs非常非常的灵活,所以设置的方法有很多中形式,具体的还应该根据你的平台具体的情况来设置。 |
U-boot的环境变量: bootcmd 和bootargs
U-boot的环境变量: bootcmd 和bootargs