diff options
author | Michal Schmidt <mschmidt@redhat.com> | 2011-10-09 18:03:37 -0400 |
---|---|---|
committer | Rusty Russell <rusty@rustcorp.com.au> | 2011-10-25 22:40:39 -0400 |
commit | b1e4d20cbf2ef8e27515da032b95fdcbb5b06bf1 (patch) | |
tree | f080e839635fa36f55d22d147baa12ae64d4c181 | |
parent | 37252db6aa576c34fd794a5a54fb32d7a8b3a07a (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.h | 20 | ||||
-rw-r--r-- | init/main.c | 4 | ||||
-rw-r--r-- | kernel/params.c | 21 |
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 | */ | ||
273 | extern 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 | */ | ||
283 | extern 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 */ |
266 | extern int parse_args(const char *name, | 286 | extern 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 | ||
70 | static inline char dash2underscore(char c) | 70 | static 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 | ||
77 | static inline int parameq(const char *input, const char *paramname) | 77 | bool 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 | |||
88 | bool parameq(const char *a, const char *b) | ||
89 | { | ||
90 | return parameqn(a, b, strlen(a)+1); | ||
84 | } | 91 | } |
85 | 92 | ||
86 | static int parse_one(char *param, | 93 | static int parse_one(char *param, |