This patch adds a generic routine to the kernel, so that a map of settings can be entered on the kernel commandline. Signed-off-by: Remy Bohmer <linux@bohmer.net> --- --- include/linux/kernel.h | 1 lib/cmdline.c | 58 +++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 59 insertions(+) Index: linux-2.6.24-rc5-rt1/include/linux/kernel.h =================================================================== --- linux-2.6.24-rc5-rt1.orig/include/linux/kernel.h 2007-12-18 21:32:09.000000000 +0100 +++ linux-2.6.24-rc5-rt1/include/linux/kernel.h 2007-12-18 21:33:58.000000000 +0100 @@ -164,6 +164,7 @@ extern int vsscanf(const char *, const c extern int get_option(char **str, int *pint); extern char *get_options(const char *str, int nints, int *ints); +extern int get_map_option(const char *str, const char *key, int *pint); extern unsigned long long memparse(char *ptr, char **retptr); extern int core_kernel_text(unsigned long addr); Index: linux-2.6.24-rc5-rt1/lib/cmdline.c =================================================================== --- linux-2.6.24-rc5-rt1.orig/lib/cmdline.c 2007-10-09 22:31:38.000000000 +0200 +++ linux-2.6.24-rc5-rt1/lib/cmdline.c 2007-12-18 21:33:58.000000000 +0100 @@ -15,6 +15,7 @@ #include <linux/module.h> #include <linux/kernel.h> #include <linux/string.h> +#include <asm/setup.h> /* * If a hyphen was found in get_option, this will handle the @@ -114,6 +115,63 @@ char *get_options(const char *str, int n } /** + * get_map_option - Parse integer from an option map + * + * This function parses an integer from an option map like + * some_map=key1:99,key2:98,...,keyN:NN,NN + * Only the value of the first match is returned, or if no + * key option is given (key = NULL) the value of the first + * field without a ':' is returned. + * + * @str: option string + * @key: The key inside the map, can be NULL + * @pint: (output) integer value parsed from the map @str + * + * Return values: + * 0 - no int in string + * 1 - int found + */ +int get_map_option(const char *str, const char *key, int *pint) +{ + char buf[COMMAND_LINE_SIZE]; + char *p, *substr; + int found = 0; + + /* We must copy the string to the stack, because strsep() + changes it.*/ + strncpy(buf, str, COMMAND_LINE_SIZE); + buf[COMMAND_LINE_SIZE-1] = '\0'; + + p = buf; + substr = strsep(&p, ","); + while ((!found) && (substr != NULL)) { + if (strlen(substr) != 0) { + if (key == NULL) { + /* Check for the absence of any ':' */ + if (strchr(substr, ':') == NULL) { + sscanf(substr, "%d", pint); + found = 1; + } + } else { + /* check if the first part of the key matches */ + if (!strncmp(substr, key, strlen(key))) { + substr += strlen(key); + /* Now the next char must be a ':', + if not, search for the next match */ + if (*substr == ':') { + substr++; + sscanf(substr, "%d", pint); + found = 1; + } + } + } + } + substr = strsep(&p, ","); + } + return found; +} + +/** * memparse - parse a string with mem suffixes into a number * @ptr: Where parse begins * @retptr: (output) Pointer to next char after parse completes -- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/