diff options
author | David Herrmann <dh.herrmann@googlemail.com> | 2011-02-11 04:10:44 -0500 |
---|---|---|
committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2011-02-21 04:02:28 -0500 |
commit | 5d9d6e91b835796c21fbd7ce479880e5181be112 (patch) | |
tree | d7881c56527eb833a33d32899a4f879d51a2a6c9 | |
parent | 26cdb1ae76f842e895ef4d09796a9101a7f8746b (diff) |
Input: uinput - fix setting up device name
The check for non-empty device name was botched since we tried to account
for extra space for the terminating zero at the same time. Convert to
kstrndup() to avoid this problem.
Signed-off-by: David Herrmann <dh.herrmann@gmail.com>
Acked-by: Aristeu Rozanski <aris@ruivo.org>
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-rw-r--r-- | drivers/input/misc/uinput.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/drivers/input/misc/uinput.c b/drivers/input/misc/uinput.c index 82542a1c1098..c0888e3d2fb4 100644 --- a/drivers/input/misc/uinput.c +++ b/drivers/input/misc/uinput.c | |||
@@ -347,8 +347,7 @@ static int uinput_setup_device(struct uinput_device *udev, const char __user *bu | |||
347 | { | 347 | { |
348 | struct uinput_user_dev *user_dev; | 348 | struct uinput_user_dev *user_dev; |
349 | struct input_dev *dev; | 349 | struct input_dev *dev; |
350 | char *name; | 350 | int i; |
351 | int i, size; | ||
352 | int retval; | 351 | int retval; |
353 | 352 | ||
354 | if (count != sizeof(struct uinput_user_dev)) | 353 | if (count != sizeof(struct uinput_user_dev)) |
@@ -373,19 +372,19 @@ static int uinput_setup_device(struct uinput_device *udev, const char __user *bu | |||
373 | 372 | ||
374 | udev->ff_effects_max = user_dev->ff_effects_max; | 373 | udev->ff_effects_max = user_dev->ff_effects_max; |
375 | 374 | ||
376 | size = strnlen(user_dev->name, UINPUT_MAX_NAME_SIZE) + 1; | 375 | /* Ensure name is filled in */ |
377 | if (!size) { | 376 | if (!user_dev->name[0]) { |
378 | retval = -EINVAL; | 377 | retval = -EINVAL; |
379 | goto exit; | 378 | goto exit; |
380 | } | 379 | } |
381 | 380 | ||
382 | kfree(dev->name); | 381 | kfree(dev->name); |
383 | dev->name = name = kmalloc(size, GFP_KERNEL); | 382 | dev->name = kstrndup(user_dev->name, UINPUT_MAX_NAME_SIZE, |
384 | if (!name) { | 383 | GFP_KERNEL); |
384 | if (!dev->name) { | ||
385 | retval = -ENOMEM; | 385 | retval = -ENOMEM; |
386 | goto exit; | 386 | goto exit; |
387 | } | 387 | } |
388 | strlcpy(name, user_dev->name, size); | ||
389 | 388 | ||
390 | dev->id.bustype = user_dev->id.bustype; | 389 | dev->id.bustype = user_dev->id.bustype; |
391 | dev->id.vendor = user_dev->id.vendor; | 390 | dev->id.vendor = user_dev->id.vendor; |