Add support for a built-in command line for x86 architectures. The Kconfig help gives the major rationale for this addition. Note that this option is available for many other arches, and its use is widespread in embedded projects. This patch addresses concerns that were raised with an earlier version, regarding precedence between the built-in command line and the command line provided by the boot loader. See the thread at http://lkml.org/lkml/2006/6/11/115 for details. The default behavior is to append the boot loader string to this one. However, there is a mechanism (leading '!') to force the built-in string to override the boot loader string. This implementation covers some important cases mentioned in the previous thread, namely: * boot loaders that can't pass args to the kernel * boot loaders that pass incorrect args to the kernel * automated testing of kernel command line options, without having to address lots of different bootloaders Signed-off-by: Tim Bird <tim.bird@xxxxxxxxxxx> --- Note: If you're copied on this, it's because you seemed interested in this the last time it was submitted. This particular implementation adds a space to the front of the command line, in the default case where the built-in string is empty. I don't think this is a problem, but comments are welcome. It would be trivial to remove the extra space, and require people who set the string to know what they are doing, and add their own space at the end of the string in the .config. arch/x86/Kconfig | 24 ++++++++++++++++++++++++ arch/x86/kernel/setup.c | 11 +++++++++++ 2 files changed, 35 insertions(+), 0 deletions(-) diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index 3d0f2b6..63c181e 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig @@ -1393,6 +1393,30 @@ config COMPAT_VDSO If unsure, say Y. +config CMDLINE + string "Initial kernel command string" + default "" + help + On some systems (e.g. embedded ones), there is no way for the + boot loader to pass arguments to the kernel. On some systems, + the arguments passed by the boot loader are incorrect. For these + platforms, you can supply command-line options at build + time by entering them here. These will be compiled into the kernel + image and used at boot time. + + If the boot loader provides a command line at boot time, it is + appended to this string. To have the kernel ignore the boot loader + command line, and use ONLY the string specified here, use an + exclamation point as the first character of the string. + Example: "!root=/dev/hda1 ro" + + In most cases, the command line (whether built-in or provided + by the boot loader) should specify the device for the root + file system. + + Systems with fully functional boot loaders (i.e. non-embedded) + should leave this string blank. + endmenu config ARCH_ENABLE_MEMORY_HOTPLUG diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c index 2d88858..298bcee 100644 --- a/arch/x86/kernel/setup.c +++ b/arch/x86/kernel/setup.c @@ -223,6 +223,7 @@ unsigned long saved_video_mode; #define RAMDISK_LOAD_FLAG 0x4000 static char __initdata command_line[COMMAND_LINE_SIZE]; +static char __initdata builtin_cmdline[COMMAND_LINE_SIZE] = CONFIG_CMDLINE; #if defined(CONFIG_EDD) || defined(CONFIG_EDD_MODULE) struct edd edd; @@ -665,6 +666,16 @@ void __init setup_arch(char **cmdline_p) bss_resource.start = virt_to_phys(&__bss_start); bss_resource.end = virt_to_phys(&__bss_stop)-1; + /* append boot loader cmdline to builtin, unless builtin overrides it */ + if (builtin_cmdline[0] != '!') { + strlcat(builtin_cmdline, " ", COMMAND_LINE_SIZE); + strlcat(builtin_cmdline, boot_command_line, COMMAND_LINE_SIZE); + strlcpy(boot_command_line, builtin_cmdline, COMMAND_LINE_SIZE); + } else { + strlcpy(boot_command_line, &builtin_cmdline[1], + COMMAND_LINE_SIZE); + } + strlcpy(command_line, boot_command_line, COMMAND_LINE_SIZE); *cmdline_p = command_line; -- 1.5.6 -- To unsubscribe from this list: send the line "unsubscribe linux-embedded" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html