mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-09 06:04:05 +08:00
USB: mct_u232: fix broken close
Make sure generic close is called at close. The driver relies on the generic write implementation but did not call generic close. Note that the call to kill the read urb is not redundant, as mct_u232 uses an interrupt urb from the second port as the read urb and that generic close therefore fails to kill it. Compile-only tested. Cc: <stable@vger.kernel.org> Signed-off-by: Johan Hovold <jhovold@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
a8f2ae7a3a
commit
5260e458f5
@ -520,12 +520,14 @@ static void mct_u232_dtr_rts(struct usb_serial_port *port, int on)
|
||||
|
||||
static void mct_u232_close(struct usb_serial_port *port)
|
||||
{
|
||||
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);
|
||||
}
|
||||
/*
|
||||
* Must kill the read urb as it is actually an interrupt urb, which
|
||||
* generic close thus fails to kill.
|
||||
*/
|
||||
usb_kill_urb(port->read_urb);
|
||||
usb_kill_urb(port->interrupt_in_urb);
|
||||
|
||||
usb_serial_generic_close(port);
|
||||
} /* mct_u232_close */
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user