diff options
| author | Rusty Russell <rusty@rustcorp.com.au> | 2002-12-29 18:59:06 -0800 |
|---|---|---|
| committer | Linus Torvalds <torvalds@home.transmeta.com> | 2002-12-29 18:59:06 -0800 |
| commit | be7a02dd2b97c2ae3ee8892d8716a09ce7b8b04e (patch) | |
| tree | 710fdc436a486ac75d36bb17396c5fb773d4aa82 /kernel | |
| parent | bec7aa00ffe5b1270837b965fdfe80be3e8e6e2e (diff) | |
[PATCH] Fix MODULE_PARM for arrays of s.
I interpreted "1-10s" to mean a string of 1-10 chars. It actually
means 1-10 comma-separated strings.
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/module.c | 17 |
1 files changed, 2 insertions, 15 deletions
diff --git a/kernel/module.c b/kernel/module.c index 4b789cf97f5d..c33aac2d23b9 100644 --- a/kernel/module.c +++ b/kernel/module.c @@ -569,20 +569,6 @@ static int param_set_byte(const char *val, struct kernel_param *kp) return 0; } -static int param_string(const char *name, const char *val, - unsigned int min, unsigned int max, - char *dest) -{ - if (strlen(val) < min || strlen(val) > max) { - printk(KERN_ERR - "Parameter %s length must be %u-%u characters\n", - name, min, max); - return -EINVAL; - } - strcpy(dest, val); - return 0; -} - extern int set_obsolete(const char *val, struct kernel_param *kp) { unsigned int min, max; @@ -618,7 +604,8 @@ extern int set_obsolete(const char *val, struct kernel_param *kp) return param_array(kp->name, val, min, max, obsparm->addr, sizeof(long), param_set_long); case 's': - return param_string(kp->name, val, min, max, obsparm->addr); + return param_array(kp->name, val, min, max, obsparm->addr, + sizeof(char *), param_set_charp); } printk(KERN_ERR "Unknown obsolete parameter type %s\n", obsparm->type); return -EINVAL; |
