Commit 92ca0dc5 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman

USB: mct_u232: fix broken close

Fix regression introduced by commit
f26788da (USB: serial: refactor generic
close) which broke driver close().

This driver uses non-standard semantics for the read urb which makes the
generic close function fail to kill it (the read urb is actually an
interrupt urb and therefore bulk_in size is zero).
Reported-by: default avatarEric Shattow "Eprecocious" <lucent@gmail.com>
Tested-by: default avatarEric Shattow "Eprecocious" <lucent@gmail.com>
Cc: stable <stable@kernel.org>
Signed-off-by: default avatarJohan Hovold <jhovold@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent f34c25ed
...@@ -549,9 +549,12 @@ static void mct_u232_close(struct usb_serial_port *port) ...@@ -549,9 +549,12 @@ static void mct_u232_close(struct usb_serial_port *port)
{ {
dbg("%s port %d", __func__, port->number); dbg("%s port %d", __func__, port->number);
usb_serial_generic_close(port); if (port->serial->dev) {
if (port->serial->dev) /* shutdown our urbs */
usb_kill_urb(port->write_urb);
usb_kill_urb(port->read_urb);
usb_kill_urb(port->interrupt_in_urb); usb_kill_urb(port->interrupt_in_urb);
}
} /* mct_u232_close */ } /* mct_u232_close */
......
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