aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichal Schmidt <mschmidt@redhat.com>2011-10-09 18:03:37 -0400
committerRusty Russell <rusty@rustcorp.com.au>2011-10-25 22:40:39 -0400
commitb1e4d20cbf2ef8e27515da032b95fdcbb5b06bf1 (patch)
treef080e839635fa36f55d22d147baa12ae64d4c181
parent37252db6aa576c34fd794a5a54fb32d7a8b3a07a (diff)
params: make dashes and underscores in parameter names truly equal
The user may use "foo-bar" for a kernel parameter defined as "foo_bar". Make sure it works the other way around too. Apply the equality of dashes and underscores on early_params and __setup params as well. The example given in Documentation/kernel-parameters.txt indicates that this is the intended behaviour. With the patch the kernel accepts "log-buf-len=1M" as expected. https://bugzilla.redhat.com/show_bug.cgi?id=744545 Signed-off-by: Michal Schmidt <mschmidt@redhat.com> Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> (neatened implementations)
-rw-r--r--include/linux/moduleparam.h20
-rw-r--r--init/main.c4
-rw-r--r--kernel/params.c21
3 files changed, 36 insertions, 9 deletions
diff --git a/include/linux/moduleparam.h b/include/linux/moduleparam.h
index ddaae98c53f9..fffb10bd5514 100644
--- a/include/linux/moduleparam.h
+++ b/include/linux/moduleparam.h
@@ -262,6 +262,26 @@ static inline void __kernel_param_unlock(void)
262 .str = &__param_string_##name, 0, perm); \ 262 .str = &__param_string_##name, 0, perm); \
263 __MODULE_PARM_TYPE(name, "string") 263 __MODULE_PARM_TYPE(name, "string")
264 264
265/**
266 * parameq - checks if two parameter names match
267 * @name1: parameter name 1
268 * @name2: parameter name 2
269 *
270 * Returns true if the two parameter names are equal.
271 * Dashes (-) are considered equal to underscores (_).
272 */
273extern bool parameq(const char *name1, const char *name2);
274
275/**
276 * parameqn - checks if two parameter names match
277 * @name1: parameter name 1
278 * @name2: parameter name 2
279 * @n: the length to compare
280 *
281 * Similar to parameq(), except it compares @n characters.
282 */
283extern bool parameqn(const char *name1, const char *name2, size_t n);
284
265/* Called on module insert or kernel boot */ 285/* Called on module insert or kernel boot */
266extern int parse_args(const char *name, 286extern int parse_args(const char *name,
267 char *args, 287 char *args,
diff --git a/init/main.c b/init/main.c
index 03b408dff825..63f5f6f8dc3b 100644
--- a/init/main.c
+++ b/init/main.c
@@ -163,7 +163,7 @@ static int __init obsolete_checksetup(char *line)
163 p = __setup_start; 163 p = __setup_start;
164 do { 164 do {
165 int n = strlen(p->str); 165 int n = strlen(p->str);
166 if (!strncmp(line, p->str, n)) { 166 if (parameqn(line, p->str, n)) {
167 if (p->early) { 167 if (p->early) {
168 /* Already done in parse_early_param? 168 /* Already done in parse_early_param?
169 * (Needs exact match on param part). 169 * (Needs exact match on param part).
@@ -392,7 +392,7 @@ static int __init do_early_param(char *param, char *val)
392 const struct obs_kernel_param *p; 392 const struct obs_kernel_param *p;
393 393
394 for (p = __setup_start; p < __setup_end; p++) { 394 for (p = __setup_start; p < __setup_end; p++) {
395 if ((p->early && strcmp(param, p->str) == 0) || 395 if ((p->early && parameq(param, p->str)) ||
396 (strcmp(param, "console") == 0 && 396 (strcmp(param, "console") == 0 &&
397 strcmp(p->str, "earlycon") == 0) 397 strcmp(p->str, "earlycon") == 0)
398 ) { 398 ) {
diff --git a/kernel/params.c b/kernel/params.c
index 22df3e0d142a..821788947e40 100644
--- a/kernel/params.c
+++ b/kernel/params.c
@@ -67,20 +67,27 @@ static void maybe_kfree_parameter(void *param)
67 } 67 }
68} 68}
69 69
70static inline char dash2underscore(char c) 70static char dash2underscore(char c)
71{ 71{
72 if (c == '-') 72 if (c == '-')
73 return '_'; 73 return '_';
74 return c; 74 return c;
75} 75}
76 76
77static inline int parameq(const char *input, const char *paramname) 77bool parameqn(const char *a, const char *b, size_t n)
78{ 78{
79 unsigned int i; 79 size_t i;
80 for (i = 0; dash2underscore(input[i]) == paramname[i]; i++) 80
81 if (input[i] == '\0') 81 for (i = 0; i < n; i++) {
82 return 1; 82 if (dash2underscore(a[i]) != dash2underscore(b[i]))
83 return 0; 83 return false;
84 }
85 return true;
86}
87
88bool parameq(const char *a, const char *b)
89{
90 return parameqn(a, b, strlen(a)+1);
84} 91}
85 92
86static int parse_one(char *param, 93static int parse_one(char *param,