Commit 79d84e19 authored by Jan Kiszka's avatar Jan Kiszka Committed by Greg Kroah-Hartman

fix param_sysfs_builtin name length check

patch 22800a28 in mainline.

Commit faf8c714 caused a regression:
parameter names longer than MAX_KBUILD_MODNAME will now be rejected,
although we just need to keep the module name part that short.  This patch
restores the old behaviour while still avoiding that memchr is called with
its length parameter larger than the total string length.
Signed-off-by: default avatarJan Kiszka <jan.kiszka@web.de>
Cc: Dave Young <hidave.darkstar@gmail.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Cc: Chuck Ebbert <cebbert@redhat.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent fed52120
...@@ -591,19 +591,16 @@ static void __init param_sysfs_builtin(void) ...@@ -591,19 +591,16 @@ static void __init param_sysfs_builtin(void)
for (i=0; i < __stop___param - __start___param; i++) { for (i=0; i < __stop___param - __start___param; i++) {
char *dot; char *dot;
size_t kplen; size_t max_name_len;
kp = &__start___param[i]; kp = &__start___param[i];
kplen = strlen(kp->name); max_name_len =
min_t(size_t, MAX_KBUILD_MODNAME, strlen(kp->name));
/* We do not handle args without periods. */ dot = memchr(kp->name, '.', max_name_len);
if (kplen > MAX_KBUILD_MODNAME) {
DEBUGP("kernel parameter name is too long: %s\n", kp->name);
continue;
}
dot = memchr(kp->name, '.', kplen);
if (!dot) { if (!dot) {
DEBUGP("couldn't find period in %s\n", kp->name); DEBUGP("couldn't find period in first %d characters "
"of %s\n", MAX_KBUILD_MODNAME, kp->name);
continue; continue;
} }
name_len = dot - kp->name; name_len = dot - kp->name;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment