From: Bernhard Walle Improve error handling in parse_crashkernel_mem() by comparing the return pointer of memparse() with the input pointer and also replaces all printk(KERN_WARNING msg) with pr_warning(msg). Signed-off-by: Bernhard Walle Reviewed-by: Oleg Verych Signed-off-by: Andrew Morton --- diff -puN kernel/kexec.c~extended-crashkernel-command-line-improve-error-handling-in-parse_crashkernel_mem kernel/kexec.c --- a/kernel/kexec.c~extended-crashkernel-command-line-improve-error-handling-in-parse_crashkernel_mem +++ a/kernel/kexec.c @@ -1166,44 +1166,59 @@ static int __init parse_crashkernel_mem( unsigned long long *crash_size, unsigned long long *crash_base) { - char *cur = cmdline; + char *cur = cmdline, *tmp; /* for each entry of the comma-separated list */ do { - unsigned long long start = 0, end = ULLONG_MAX; - unsigned long long size = -1; + unsigned long long start, end = ULLONG_MAX, size; /* get the start of the range */ - start = memparse(cur, &cur); + start = memparse(cur, &tmp); + if (cur == tmp) { + pr_warning("crashkernel: Memory value expected\n"); + return -EINVAL; + } + cur = tmp; if (*cur != '-') { - printk(KERN_WARNING "crashkernel: '-' expected\n"); + pr_warning("crashkernel: '-' expected\n"); return -EINVAL; } cur++; /* if no ':' is here, than we read the end */ if (*cur != ':') { - end = memparse(cur, &cur); + end = memparse(cur, &tmp); + if (cur == tmp) { + pr_warning("crashkernel: Memory " + "value expected\n"); + return -EINVAL; + } + cur = tmp; if (end <= start) { - printk(KERN_WARNING "crashkernel: end <= start\n"); + pr_warning("crashkernel: end <= start\n"); return -EINVAL; } } if (*cur != ':') { - printk(KERN_WARNING "crashkernel: ':' expected\n"); + pr_warning("crashkernel: ':' expected\n"); return -EINVAL; } cur++; - size = memparse(cur, &cur); - if (size < 0) { - printk(KERN_WARNING "crashkernel: invalid size\n"); + size = memparse(cur, &tmp); + if (cur == tmp) { + pr_warning("Memory value expected\n"); + return -EINVAL; + } + cur = tmp; + if (size >= system_ram) { + pr_warning("crashkernel: invalid size\n"); return -EINVAL; } /* match ? */ - if (system_ram >= start && system_ram <= end) { + if (system_ram >= start && system_ram <= end) { *crash_size = size; break; } @@ -1212,8 +1227,15 @@ static int __init parse_crashkernel_mem( if (*crash_size > 0) { while (*cur != ' ' && *cur != '@') cur++; - if (*cur == '@') - *crash_base = memparse(cur+1, &cur); + if (*cur == '@') { + cur++; + *crash_base = memparse(cur, &tmp); + if (cur == tmp) { + pr_warning("Memory value expected " + "after '@'\n"); + return -EINVAL; + } + } } return 0; @@ -1233,8 +1255,10 @@ static int __init parse_crashkernel_simp char *cur = cmdline; *crash_size = memparse(cmdline, &cur); - if (cmdline == cur) + if (cmdline == cur) { + pr_warning("crashkernel: memory value expected\n"); return -EINVAL; + } if (*cur == '@') *crash_base = memparse(cur+1, &cur); _