diff options
Diffstat (limited to 'drivers/input/evdev.c')
-rw-r--r-- | drivers/input/evdev.c | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/drivers/input/evdev.c b/drivers/input/evdev.c index 7a7a026ba712..114efd8dc8f5 100644 --- a/drivers/input/evdev.c +++ b/drivers/input/evdev.c | |||
@@ -25,7 +25,6 @@ struct evdev { | |||
25 | int exist; | 25 | int exist; |
26 | int open; | 26 | int open; |
27 | int minor; | 27 | int minor; |
28 | char name[16]; | ||
29 | struct input_handle handle; | 28 | struct input_handle handle; |
30 | wait_queue_head_t wait; | 29 | wait_queue_head_t wait; |
31 | struct evdev_client *grab; | 30 | struct evdev_client *grab; |
@@ -609,7 +608,8 @@ static long evdev_do_ioctl(struct file *file, unsigned int cmd, | |||
609 | p, compat_mode); | 608 | p, compat_mode); |
610 | 609 | ||
611 | if (_IOC_NR(cmd) == _IOC_NR(EVIOCGNAME(0))) | 610 | if (_IOC_NR(cmd) == _IOC_NR(EVIOCGNAME(0))) |
612 | return str_to_user(dev->name, _IOC_SIZE(cmd), p); | 611 | return str_to_user(dev_name(&evdev->dev), |
612 | _IOC_SIZE(cmd), p); | ||
613 | 613 | ||
614 | if (_IOC_NR(cmd) == _IOC_NR(EVIOCGPHYS(0))) | 614 | if (_IOC_NR(cmd) == _IOC_NR(EVIOCGPHYS(0))) |
615 | return str_to_user(dev->phys, _IOC_SIZE(cmd), p); | 615 | return str_to_user(dev->phys, _IOC_SIZE(cmd), p); |
@@ -626,8 +626,11 @@ static long evdev_do_ioctl(struct file *file, unsigned int cmd, | |||
626 | abs.maximum = dev->absmax[t]; | 626 | abs.maximum = dev->absmax[t]; |
627 | abs.fuzz = dev->absfuzz[t]; | 627 | abs.fuzz = dev->absfuzz[t]; |
628 | abs.flat = dev->absflat[t]; | 628 | abs.flat = dev->absflat[t]; |
629 | abs.resolution = dev->absres[t]; | ||
629 | 630 | ||
630 | if (copy_to_user(p, &abs, sizeof(struct input_absinfo))) | 631 | if (copy_to_user(p, &abs, min_t(size_t, |
632 | _IOC_SIZE(cmd), | ||
633 | sizeof(struct input_absinfo)))) | ||
631 | return -EFAULT; | 634 | return -EFAULT; |
632 | 635 | ||
633 | return 0; | 636 | return 0; |
@@ -654,8 +657,9 @@ static long evdev_do_ioctl(struct file *file, unsigned int cmd, | |||
654 | 657 | ||
655 | t = _IOC_NR(cmd) & ABS_MAX; | 658 | t = _IOC_NR(cmd) & ABS_MAX; |
656 | 659 | ||
657 | if (copy_from_user(&abs, p, | 660 | if (copy_from_user(&abs, p, min_t(size_t, |
658 | sizeof(struct input_absinfo))) | 661 | _IOC_SIZE(cmd), |
662 | sizeof(struct input_absinfo)))) | ||
659 | return -EFAULT; | 663 | return -EFAULT; |
660 | 664 | ||
661 | /* | 665 | /* |
@@ -670,6 +674,8 @@ static long evdev_do_ioctl(struct file *file, unsigned int cmd, | |||
670 | dev->absmax[t] = abs.maximum; | 674 | dev->absmax[t] = abs.maximum; |
671 | dev->absfuzz[t] = abs.fuzz; | 675 | dev->absfuzz[t] = abs.fuzz; |
672 | dev->absflat[t] = abs.flat; | 676 | dev->absflat[t] = abs.flat; |
677 | dev->absres[t] = _IOC_SIZE(cmd) < sizeof(struct input_absinfo) ? | ||
678 | 0 : abs.resolution; | ||
673 | 679 | ||
674 | spin_unlock_irq(&dev->event_lock); | 680 | spin_unlock_irq(&dev->event_lock); |
675 | 681 | ||
@@ -807,16 +813,15 @@ static int evdev_connect(struct input_handler *handler, struct input_dev *dev, | |||
807 | mutex_init(&evdev->mutex); | 813 | mutex_init(&evdev->mutex); |
808 | init_waitqueue_head(&evdev->wait); | 814 | init_waitqueue_head(&evdev->wait); |
809 | 815 | ||
810 | snprintf(evdev->name, sizeof(evdev->name), "event%d", minor); | 816 | dev_set_name(&evdev->dev, "event%d", minor); |
811 | evdev->exist = 1; | 817 | evdev->exist = 1; |
812 | evdev->minor = minor; | 818 | evdev->minor = minor; |
813 | 819 | ||
814 | evdev->handle.dev = input_get_device(dev); | 820 | evdev->handle.dev = input_get_device(dev); |
815 | evdev->handle.name = evdev->name; | 821 | evdev->handle.name = dev_name(&evdev->dev); |
816 | evdev->handle.handler = handler; | 822 | evdev->handle.handler = handler; |
817 | evdev->handle.private = evdev; | 823 | evdev->handle.private = evdev; |
818 | 824 | ||
819 | dev_set_name(&evdev->dev, evdev->name); | ||
820 | evdev->dev.devt = MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor); | 825 | evdev->dev.devt = MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor); |
821 | evdev->dev.class = &input_class; | 826 | evdev->dev.class = &input_class; |
822 | evdev->dev.parent = &dev->dev; | 827 | evdev->dev.parent = &dev->dev; |