精华内容
下载资源
问答
  • bootcmd 和bootargs

    2013-11-03 18:03:12
     U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。 u-bootcmd  前面有说过bootcmd是自动启动时默认执行的一些命令,因此你可以在当前环境中定义各种不同配置,不同环境的参数设置,然后设置bootcmd为你...

    转自 :http://linux.chinaunix.net/bbs/archiver/tid-1111568.html

        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  使用虚拟串口终端设备 .
    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=[;
      := :[,]
      := [@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非常非常的灵活,所以设置的方法有很多中形式,具体的还应该根据你的平台具体的情况来设置。

    展开全文
  • bootcmd和bootargs

    2020-12-07 20:59:56
    1. bootcmd uboot上电启动后会自动倒数bootdelay秒,如果没有人按下回车打断启动,则uboot会自动执行bootcmd启动命令来启动内核。 这个参数包含了一些命令,这些命令将在u-boot进入主循环后执行。 示例: ...

     

    1. bootcmd

    uboot上电启动后会自动倒数bootdelay秒,如果没有人按下回车打断启动,则uboot会自动执行bootcmd启动命令来启动内核。

     

    这个参数包含了一些命令,这些命令将在u-boot进入主循环后执行。

    示例:

           bootcmd=boot_logo;nand read 1000000 3c0000 300000;bootm 1000000

           意思是启动u-boot后,执行boot_logo显示logo信息,然后从nand flash中读内核映像到内存,然后启动内核。

     

     

    2. bootargs

    linux内核启动时可以接收uboot给他传递的启动参数,这些启动参数是uboot和内核约定好的形式、内容,linux内核在这些启动参数的指导下完成启动过程。这样的设计是为了灵活,为了内核在不重新编译的情况下可以用不同的方式启动。而我们要做的事情就是:在uboot的环境变量中设置bootargs,然后bootm命令启动内核时会自动将bootargs传给内核。

     

    举个例子:bootargs="console=ttySAC2,115200 root=/dev/mmcblk0p2 rw init=/linuxrc rootfstype=ext3"

    意义解释:

    console=ttySAC2,115200 控制台使用串口2,波特率115200.

    root=/dev/mmcblk0p2 rw 根文件系统在SD卡端口0设备(比如 iNand)第2分区,根文件系统是可读可写的

    init=/linuxrc linux的进程1(init进程)的路径

    rootfstype=ext3 根文件系统的类型是ext3

     

    Note,

    1. 如果uboot的bootargs设置了,kernel的Boot options中的Default kernel command string设置与否,都不启作用。

    2. 如果uboot的bootargs未设置的话,kernel就以Boot options中的Default kernel command string的设置进行启动。

     

     

    展开全文
  • U-boot的环境变量: bootcmd 和bootargs.pdf
  • bootcmd和bootargs参数

    2015-08-19 16:28:46
    u-boot的环境参数中有两个内核启动相关的,它们是bootcmd和bootargs 1.u-boot中和环境参数有关的命令  printenv:打印当前环境参数  setenv param_name "value":设置环境参数  saveenv:保存环境...

    u-boot的环境参数中有两个和内核启动相关的,它们是bootcmd和bootargs

    1.u-boot中和环境参数有关的命令

           printenv:打印当前环境参数

           setenv param_name "value":设置环境参数

           saveenv:保存环境参数到FLASH

    2.bootcmd:

    这个参数包含了一些命令,这些命令将在u-boot进入主循环后执行

    示例:

           bootcmd=boot_logo;nand read 10000003c0000 300000;bootm 1000000

           意思是启动u-boot后,执行boot_logo显示logo信息,然后从nand flash中读内核映像到内存,然后启动内核。

    3.bootargs

    这个参数设置要传递给内核的信息,主要用来告诉内核分区信息和根文件系统所在的分区。

    示例:

           root=/dev/mtdblock5 rootfstype=jffs2console=ttyS0,115200 mem=35M mtdparts=nand.0:3840k(u-boot),4096k(kernel),123136k(filesystem)

           其中:

           root=/dev/mtdblock5 表示根文件系统在第五分区

           rootfstype=jffs2 表示根文件系统的类型是jffs2

           console=ttyS0,115200 表示终端为ttyS0,串口波特率为115200

           mem=35M 表示内存大小为35M

           mtdparts告诉内核MTD分区情况,它在内核目录/drivers/mtd/cmdlinepart.c文件中有介绍:

    * The format for the command line is as follows:

     *

     * mtdparts=<mtddef>[;<mtddef]

     * <mtddef>  := <mtd-id>:<partdef>[,<partdef>]

     *              where <mtd-id> is the name from the "cat /proc/mtd" command

     * <partdef> := <size>[@offset][<name>][ro][lk]

     * <mtd-id>  := unique name used in mapping driver/device (mtd->name)

     * <size>    := standard linux memsize OR "-" to denote all remaining space

     * <name>    := '(' NAME ')'

     *

     * Examples:

     *

     * 1 NOR Flash, with 1 single writable partition:

     * edb7312-nor:-

     *

     * 1 NOR Flash with 2 partitions, 1 NAND with one

     * edb7312-nor:256k(ARMboot)ro,-(root);edb7312-nand:-(home)

     */

    关于mtd-id,每个FLASH都不一样,实际上我觉得和当前FLASH的驱动有关系,在内核启动后会打印相关的分区信息,里面会有相关FLASH的mtd-id。


    转载:http://blog.csdn.net/crazyman2010/article/details/6742687

    展开全文
  • U_boot 的 bootcmd 和bootargs参数详解 网址:http://www.cnblogs.com/cornflower/archive/2010/03/27/1698279.html  U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。 u-bootcmd ...
     
    

    网址:http://www.cnblogs.com/cornflower/archive/2010/03/27/1698279.html

        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  使用虚拟串口终端设备 .
    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=[;
      := :[,]
      := [@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’

    展开全文
  • uboot 中有两个非常重要的环境变量 bootcmd bootargs,接下来看一下这两个环境变量。bootcmd bootagrs 是采用类似 shell 脚本语言编写的,里面有很多的变量引用,这些变量其实都 是 环 境 变 量 , 有 很 多 ...
  • uboot 的 bootcmd 和bootargs参数详解

    千次阅读 2016-11-17 16:14:40
    U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。 u-bootcmd  前面有说过bootcmd是自动启动时默认执行的一些命令,因此你可以在当前环境中定义各种不同配置,不同环境的参数设置,然后设置bootcmd为你经常...
  • uboot中有很多环境变量,下面介绍其中两个bootcmd和bootargs。 这两个环境变量都是NXP自己定义的,放在.h文件中,路径在/include/configs下 上面的宏是条件编译语句,使用NAND使用EMMC是不同的。 1.bootcmd ...
  • uboot bootcmd 和bootargs参数详解

    千次阅读 2014-02-10 11:26:06
    U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。(http://www.cnblogs.com/cornflower/archive/2010/03/27/1698279.html) u-bootcmd  前面有说过bootcmd是自动启动时默认执行的一些命令,因此你可以在...
  • bootcmd 和bootargs【转】

    2013-02-26 17:42:52
    U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。 u-bootcmd  前面有说过bootcmd是自动启动时默认执行的一些命令,因此你可以在当前环境中定义各种不同配置,不同环境的参数设置,然后设置bootcmd为你...
  • U-boot bootcmd 和bootargs

    2012-12-23 00:12:00
    U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。u-bootcmd 前面有说过bootcmd是自动启动时默认执行的一些命令,因此你可以在当前环境中定义各种不同配置,不同环境的参数设置,然后设置bootcmd为你经常...
  • U-boot的环境变量值得注意的有两个: bootcmd 和bootargs。 u-bootcmd  前面有说过bootcmd是自动启动时默认执行的一些命令,因此你可以在当前环境中定义各种不同配置,不同环境的参数设置,然后设置bootcmd为你经常...
  • U-boot的环境变量:bootcmd 和bootargs u-bootcmdbootcmd是uboot自动启动时默认执行的一些命令,因此你可以在当前环境中定义各种不同配置,不同环境的参数设置,然后设置bootcmd为你经常使用的那种参数。 现在...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 4,741
精华内容 1,896
关键字:

bootcmd和bootargs