Commit d530296f authored by Greg Kroah-Hartman's avatar Greg Kroah-Hartman

USB: serial: opticon: hook up suspend/resume callbacks

With a previous patch, the usb_driver suspend/resume callbacks got
overridden and were never called if a usb_serial driver defined them.
This patch fixes the opticon driver to move the suspend/resume callbacks
into the usb_serial_driver structure where they will be properly called.

It then removes the unused usb_driver structure.

Cc: Johan Hovold <jhovold@gmail.com>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Cc: Julia Lawall <julia@diku.dk>
Cc: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 08dfa5c5
...@@ -557,18 +557,16 @@ static void opticon_release(struct usb_serial *serial) ...@@ -557,18 +557,16 @@ static void opticon_release(struct usb_serial *serial)
kfree(priv); kfree(priv);
} }
static int opticon_suspend(struct usb_interface *intf, pm_message_t message) static int opticon_suspend(struct usb_serial *serial, pm_message_t message)
{ {
struct usb_serial *serial = usb_get_intfdata(intf);
struct opticon_private *priv = usb_get_serial_data(serial); struct opticon_private *priv = usb_get_serial_data(serial);
usb_kill_urb(priv->bulk_read_urb); usb_kill_urb(priv->bulk_read_urb);
return 0; return 0;
} }
static int opticon_resume(struct usb_interface *intf) static int opticon_resume(struct usb_serial *serial)
{ {
struct usb_serial *serial = usb_get_intfdata(intf);
struct opticon_private *priv = usb_get_serial_data(serial); struct opticon_private *priv = usb_get_serial_data(serial);
struct usb_serial_port *port = serial->port[0]; struct usb_serial_port *port = serial->port[0];
int result; int result;
...@@ -583,13 +581,6 @@ static int opticon_resume(struct usb_interface *intf) ...@@ -583,13 +581,6 @@ static int opticon_resume(struct usb_interface *intf)
return result; return result;
} }
static struct usb_driver opticon_driver = {
.name = "opticon",
.suspend = opticon_suspend,
.resume = opticon_resume,
.id_table = id_table,
};
static struct usb_serial_driver opticon_device = { static struct usb_serial_driver opticon_device = {
.driver = { .driver = {
.owner = THIS_MODULE, .owner = THIS_MODULE,
...@@ -609,6 +600,8 @@ static struct usb_serial_driver opticon_device = { ...@@ -609,6 +600,8 @@ static struct usb_serial_driver opticon_device = {
.ioctl = opticon_ioctl, .ioctl = opticon_ioctl,
.tiocmget = opticon_tiocmget, .tiocmget = opticon_tiocmget,
.tiocmset = opticon_tiocmset, .tiocmset = opticon_tiocmset,
.suspend = opticon_suspend,
.resume = opticon_resume,
}; };
static struct usb_serial_driver * const serial_drivers[] = { static struct usb_serial_driver * const serial_drivers[] = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment