aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/input/evdev.c44
1 files changed, 24 insertions, 20 deletions
diff --git a/drivers/input/evdev.c b/drivers/input/evdev.c
index 2d65411f6763..ef8c2ed792c3 100644
--- a/drivers/input/evdev.c
+++ b/drivers/input/evdev.c
@@ -647,6 +647,28 @@ static int str_to_user(const char *str, unsigned int maxlen, void __user *p)
647 return copy_to_user(p, str, len) ? -EFAULT : len; 647 return copy_to_user(p, str, len) ? -EFAULT : len;
648} 648}
649 649
650static int handle_eviocgbit(struct input_dev *dev, unsigned int cmd, void __user *p, int compat_mode)
651{
652 unsigned long *bits;
653 int len;
654
655 switch (_IOC_NR(cmd) & EV_MAX) {
656
657 case 0: bits = dev->evbit; len = EV_MAX; break;
658 case EV_KEY: bits = dev->keybit; len = KEY_MAX; break;
659 case EV_REL: bits = dev->relbit; len = REL_MAX; break;
660 case EV_ABS: bits = dev->absbit; len = ABS_MAX; break;
661 case EV_MSC: bits = dev->mscbit; len = MSC_MAX; break;
662 case EV_LED: bits = dev->ledbit; len = LED_MAX; break;
663 case EV_SND: bits = dev->sndbit; len = SND_MAX; break;
664 case EV_FF: bits = dev->ffbit; len = FF_MAX; break;
665 case EV_SW: bits = dev->swbit; len = SW_MAX; break;
666 default: return -EINVAL;
667 }
668 return bits_to_user(bits, len, _IOC_SIZE(cmd), p, compat_mode);
669}
670
671
650static long evdev_do_ioctl(struct file *file, unsigned int cmd, 672static long evdev_do_ioctl(struct file *file, unsigned int cmd,
651 void __user *p, int compat_mode) 673 void __user *p, int compat_mode)
652{ 674{
@@ -733,26 +755,8 @@ static long evdev_do_ioctl(struct file *file, unsigned int cmd,
733 755
734 if (_IOC_DIR(cmd) == _IOC_READ) { 756 if (_IOC_DIR(cmd) == _IOC_READ) {
735 757
736 if ((_IOC_NR(cmd) & ~EV_MAX) == _IOC_NR(EVIOCGBIT(0, 0))) { 758 if ((_IOC_NR(cmd) & ~EV_MAX) == _IOC_NR(EVIOCGBIT(0, 0)))
737 759 return handle_eviocgbit(dev, cmd, p, compat_mode);
738 unsigned long *bits;
739 int len;
740
741 switch (_IOC_NR(cmd) & EV_MAX) {
742
743 case 0: bits = dev->evbit; len = EV_MAX; break;
744 case EV_KEY: bits = dev->keybit; len = KEY_MAX; break;
745 case EV_REL: bits = dev->relbit; len = REL_MAX; break;
746 case EV_ABS: bits = dev->absbit; len = ABS_MAX; break;
747 case EV_MSC: bits = dev->mscbit; len = MSC_MAX; break;
748 case EV_LED: bits = dev->ledbit; len = LED_MAX; break;
749 case EV_SND: bits = dev->sndbit; len = SND_MAX; break;
750 case EV_FF: bits = dev->ffbit; len = FF_MAX; break;
751 case EV_SW: bits = dev->swbit; len = SW_MAX; break;
752 default: return -EINVAL;
753 }
754 return bits_to_user(bits, len, _IOC_SIZE(cmd), p, compat_mode);
755 }
756 760
757 if (_IOC_NR(cmd) == _IOC_NR(EVIOCGKEY(0))) 761 if (_IOC_NR(cmd) == _IOC_NR(EVIOCGKEY(0)))
758 return bits_to_user(dev->key, KEY_MAX, _IOC_SIZE(cmd), 762 return bits_to_user(dev->key, KEY_MAX, _IOC_SIZE(cmd),