diff options
author | Johan Hovold <johan@kernel.org> | 2017-01-06 13:15:14 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-01-19 14:18:01 -0500 |
commit | 1685daad0b0cb117d6ec35fb93d848445da6b201 (patch) | |
tree | 3693c8036c47e5c2e8ae73327ae0e88f46d4c4ac | |
parent | 4aeab97a051560835668fc5c61eb56b20bd485d0 (diff) |
USB: serial: ch341: fix resume after reset
commit ce5e292828117d1b71cbd3edf9e9137cf31acd30 upstream.
Fix reset-resume handling which failed to resubmit the read and
interrupt URBs, thereby leaving a port that was open before suspend in a
broken state until closed and reopened.
Fixes: 1ded7ea47b88 ("USB: ch341 serial: fix port number changed after resume")
Fixes: 2bfd1c96a9fb ("USB: serial: ch341: remove reset_resume callback")
Signed-off-by: Johan Hovold <johan@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r-- | drivers/usb/serial/ch341.c | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/drivers/usb/serial/ch341.c b/drivers/usb/serial/ch341.c index 6c04c45bcd06..a7a16c6ced62 100644 --- a/drivers/usb/serial/ch341.c +++ b/drivers/usb/serial/ch341.c | |||
@@ -538,14 +538,23 @@ static int ch341_tiocmget(struct tty_struct *tty) | |||
538 | 538 | ||
539 | static int ch341_reset_resume(struct usb_serial *serial) | 539 | static int ch341_reset_resume(struct usb_serial *serial) |
540 | { | 540 | { |
541 | struct ch341_private *priv; | 541 | struct usb_serial_port *port = serial->port[0]; |
542 | 542 | struct ch341_private *priv = usb_get_serial_port_data(port); | |
543 | priv = usb_get_serial_port_data(serial->port[0]); | 543 | int ret; |
544 | 544 | ||
545 | /* reconfigure ch341 serial port after bus-reset */ | 545 | /* reconfigure ch341 serial port after bus-reset */ |
546 | ch341_configure(serial->dev, priv); | 546 | ch341_configure(serial->dev, priv); |
547 | 547 | ||
548 | return 0; | 548 | if (tty_port_initialized(&port->port)) { |
549 | ret = usb_submit_urb(port->interrupt_in_urb, GFP_NOIO); | ||
550 | if (ret) { | ||
551 | dev_err(&port->dev, "failed to submit interrupt urb: %d\n", | ||
552 | ret); | ||
553 | return ret; | ||
554 | } | ||
555 | } | ||
556 | |||
557 | return usb_serial_generic_resume(serial); | ||
549 | } | 558 | } |
550 | 559 | ||
551 | static struct usb_serial_driver ch341_device = { | 560 | static struct usb_serial_driver ch341_device = { |