一、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参数的作用、设置和读取等方面的知识。