您的位置:

深入理解bootargs

一、bootargs参数

在嵌入式系统中,bootargs是非常重要的参数。它保存着Linux内核启动的相关信息,如启动参数和控制台信息等。而在ARM架构的系统中,bootargs参数则是在U-Boot引导时设置的。

bootargs参数通常包括以下几个方面:

1. 内核命令行参数

内核命令行参数是Linux内核启动时必要的参数,它们会告诉内核应该如何进行初始化和配置。常见的内核命令行参数包括rootfs、serial等。

root=/dev/mmcblk0p2 rootwait rw console=ttyS0,115200n8

2. 内存分配参数

内存分配参数通常由Linux内核自动处理,但在某些情况下需要手动设置。它们包括mem等。

mem=256MB

3. U-Boot环境变量

U-Boot环境变量是指在U-Boot引导时设置的全局变量。常见的U-Boot环境变量包括bootdelay、bootcmd等。

bootdelay=3
bootargs=root=/dev/mmcblk0p2 rootwait rw console=ttyS0,115200n8
bootcmd=run bootargs; bootm ${kernel_addr_r} - ${fdt_addr_r}

二、bootargs.bin有什么用

bootargs.bin是一个二进制文件,它包含由U-Boot引导时设置的bootargs参数。在一些嵌入式系统中,由于Flash空间有限,无法保留完整的bootargs参数,因此需要将其保存在一个二进制文件中。在系统启动时,内核会通过bootargs.bin文件读取bootargs参数。

U-Boot# mkimage -A arm -O linux -T script -C none -n "bootargs" -d "bootargs.txt" "bootargs.bin"

三、bootargs怎么读

在Linux内核启动时,内核会通过bootargs参数读取U-Boot设置的命令行参数。如果需要修改bootargs参数,可以通过以下方法进行:

1. 在启动时修改

在启动时按下系统启动键进入U-Boot控制台,然后通过setenv命令修改bootargs参数:

U-Boot# setenv bootargs "root=/dev/mmcblk0p2 rootwait rw console=ttyS0,115200n8"
U-Boot# saveenv
U-Boot# boot

2. 在U-Boot环境中修改

在U-Boot控制台中,通过setenv命令修改bootargs参数,并通过saveenv保存:

U-Boot# setenv bootargs "root=/dev/mmcblk0p2 rootwait rw console=ttyS0,115200n8"
U-Boot# saveenv
U-Boot# reset

四、机顶盒bootargs是什么意思

机顶盒bootargs参数和嵌入式系统中的bootargs参数基本相同,也是由U-Boot引导时设置的命令行参数。其主要作用是为Linux内核初始化和配置提供必要的信息。常见的机顶盒bootargs参数包括:

1. rootfs

rootfs参数指定Linux内核的根文件系统,即Linux内核启动后挂载的根文件系统。在机顶盒中,通常指定为NFS、TFTP或者SD卡等。

bootargs=root=/dev/nfs nfsroot=192.168.0.10:/nfs/rootfs ip=dhcp rw

2. serial

serial参数指定Linux内核使用的串口设备,用于调试和输出控制台信息。

bootargs=console=ttyS0,115200n8

五、黑苹果bootargs怎么设置

在黑苹果上,bootargs用于设置内核启动时的参数。如下是一个典型的黑苹果bootargs示例:

boot-args-v="-v debug=0x100 keepsyms=1"

其中,boot-args-v参数是用于控制启动时内核命令行参数的。在这个例子中,-v参数表示启用详细模式;debug参数用于控制调试模式;keepsyms参数保留系统符号表。

六、总结

在嵌入式系统和黑苹果上,bootargs参数非常重要。它包含了Linux内核启动的相关信息,用于初始化和配置内核。通过本文的介绍,我们可以更深入地了解bootargs参数的作用、设置和读取等方面的知识。