向linux kernel中添加cmdline的四种方式

在linux启动时候,串口log中会打印cmdline

[    0.000000] c0 0 (swapper) Kernel command line: earlycon androidboot.selinux=permissive uart_dma keep_dbgclk_on clk_ignore_unused initrd=0xd0000000,38711808 rw crash_page=0x8f040000 initrd=/recoveryrc boot_reason=0x2000 ota_status=0x1001

1

在linux启动完成后,通过 cat /proc/cmdline也是可以看到cmdline. 那么cmdline是如何添加的呢?

1、 在dts中的bootargs中添加

/ {

    model = "xxx yyyyyyy FPGA";

    compatible = "xxx ,yyyyy-fpga", "xxx ,yyyyyy";



    chosen {

        /*

         * initrd parameters not set in dts file since the ramdisk.img size

         * need to check in uboot, and the initrd load address and size will

         * set in uboot stage.

         */

        bootargs = "earlycon androidboot.selinux=permissive uart_dma keep_dbgclk_on clk_ignore_unused";

        stdout-path = "serial0:115200";

    };

......

}

2、在BoardConfig中添加

vim device/xxx/xxx_evb/BoardConfigCommon.mk



BOARD_KERNEL_CMDLINE += androidboot.selinux=enforcing androidboot.hardware=xxxxx_phone androidboot.dtbo_idx=0

1

3、在uboot中添加

vim u-boot/common/cmd_bootm.c

append_bootargs("recovery=1");

sprintf(dm_buf,"init=/init skip_initramfs rootwait root=/dev/dm-0 dm=\"system none ro,0 1 android-verity /dev/mmcblk0p%d\"",ret);

append_bootargs((const char *)dm_buf);

4、在android的Makefile中添加

vim build/core/Makefile



INTERNAL_KERNEL_CMDLINE := $(strip $(BOARD_KERNEL_CMDLINE) buildvariant=$(TARGET_BUILD_VARIANT) $(VERITY_KEYID))

ifdef INTERNAL_KERNEL_CMDLINE

INTERNAL_BOOTIMAGE_ARGS += --cmdline "$(INTERNAL_KERNEL_CMDLINE)"

endif

Linux 内核中,**宏控制**(Macro Control)主要通过 **预处理器宏定义**(`#define`)和 **编译选项** 来实现。这些宏控制可以影响内核的编译流程、启用或禁用某些功能、优化代码路径,甚至控制调试信息的输出。 --- ### 📌 宏控制的传递方式 Linux 内核中宏控制的传递主要通过以下几种方式实现: --- ### 1. **通过 `Kconfig` 配置选项控制宏定义** Linux 内核使用 `Kconfig` 文件系统来管理配置选项,这些配置最终会被转换为宏定义。 - 每个 `CONFIG_XXX` 选项在编译时会自动转换为宏定义,例如: ```c #ifdef CONFIG_MODULES // 模块支持代码 #endif ``` - `Kconfig` 中的配置项会被保存在 `.config` 文件中。 - 编译过程中,`include/generated/autoconf.h` 文件会根据 `.config` 自动生成这些宏定义。 --- ### 2. **通过 Makefile 传递宏定义** 在内核的 `Makefile` 中,可以通过 `ccflags-y`、`CFLAGS` 等变量传递宏定义给编译器。 例如: ```makefile ccflags-y += -DDEBUG_PRINT ``` 这会在编译该模块时定义宏 `DEBUG_PRINT`,从而启用调试输出。 --- ### 3. **通过编译命令行参数传递宏定义** 在调用 `gcc` 编译源文件时,也可以通过 `-D` 参数直接定义宏: ```bash gcc -DENABLE_FEATURE_X -c mymodule.c ``` 在内核构建系统中,这种参数通常由 `Makefile` 自动生成。 --- ### 4. **通过头文件定义宏** 有些宏定义直接写在头文件中,例如: ```c #define MY_DRIVER_VERSION 2 ``` 这种方式适合固定不变的配置,但不便于动态控制。 --- ### 5. **通过运行时参数控制(非宏)** 虽然不是宏,但有些控制可以通过运行时参数(如 `bootargs`)或 `sysfs`、`procfs` 接口进行调整。例如: ```bash kernel.printk = 7 4 1 7 ``` 这类参数通常在启动时通过 `cmdline` 传递给内核。 --- ### 🔧 示例:如何启用一个调试宏 #### 步骤 1:在 Makefile 中添加宏定义 ```makefile obj-$(CONFIG_MYDRIVER) += mydriver.o ccflags-$(CONFIG_MYDRIVER_DEBUG) += -DMYDRIVER_DEBUG ``` #### 步骤 2:在源码中使用宏控制 ```c #ifdef MYDRIVER_DEBUG printk(KERN_DEBUG "Debug: entering function\n"); #endif ``` #### 步骤 3:在 `Kconfig` 中添加配置项 ```kconfig config MYDRIVER_DEBUG bool "Enable MyDriver Debug Messages" depends on MYDRIVER help Say Y here to enable debug messages in MyDriver. ``` --- ### ✅ 总结 | 方式 | 说明 | |------|------| | `Kconfig` + `.config` | 最常见,通过 `CONFIG_XXX` 控制宏定义 | | `Makefile` 中的 `ccflags-y` | 用于模块级宏控制 | | 编译命令行 `-D` 参数 | 直接定义宏 | | 头文件中的 `#define` | 用于固定配置 | | 运行时参数(如 `cmdline`) | 控制行为,非宏定义 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值