Input: usbtouchscreen - implement basic suspend/resume
authorOliver Neukum <oneukum@suse.de>
Thu, 15 Jul 2010 16:16:39 +0000 (09:16 -0700)
committerDmitry Torokhov <dmitry.torokhov@gmail.com>
Thu, 15 Jul 2010 16:30:43 +0000 (09:30 -0700)
This implements basic support for suspend & resume.

Signed-off-by: Oliver Neukum <oneukum@suse.de>
Tested-by: Petr Štetiar <ynezz@true.cz>
Tested-by: Ondrej Zary <linux@rainbow-software.org>
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
drivers/input/touchscreen/usbtouchscreen.c

index b9cee2738adba80d8d878a01b7727379dd15831a..9cda660ee7bbb9aa7dff1755db6c5b3e73c4bd12 100644 (file)
@@ -1296,6 +1296,29 @@ static void usbtouch_close(struct input_dev *input)
                usb_kill_urb(usbtouch->irq);
 }
 
+static int usbtouch_suspend
+(struct usb_interface *intf, pm_message_t message)
+{
+       struct usbtouch_usb *usbtouch = usb_get_intfdata(intf);
+
+       usb_kill_urb(usbtouch->irq);
+
+       return 0;
+}
+
+static int usbtouch_resume(struct usb_interface *intf)
+{
+       struct usbtouch_usb *usbtouch = usb_get_intfdata(intf);
+       struct input_dev *input = usbtouch->input;
+       int result = 0;
+
+       mutex_lock(&input->mutex);
+       if (input->users || usbtouch->type->irq_always)
+               result = usb_submit_urb(usbtouch->irq, GFP_NOIO);
+       mutex_unlock(&input->mutex);
+
+       return result;
+}
 
 static void usbtouch_free_buffers(struct usb_device *udev,
                                  struct usbtouch_usb *usbtouch)
@@ -1486,6 +1509,8 @@ static struct usb_driver usbtouch_driver = {
        .name           = "usbtouchscreen",
        .probe          = usbtouch_probe,
        .disconnect     = usbtouch_disconnect,
+       .suspend        = usbtouch_suspend,
+       .resume         = usbtouch_resume,
        .id_table       = usbtouch_devices,
 };