提交 3edbc986 编写于 作者: O Oliver Neukum 提交者: Greg Kroah-Hartman

USB: kl5kusb105 don't flush to logically disconnected devices

If disconnect() is called for a logical disconnect, no more IO must be
done after disconnect() returns, or the old and new drivers may conflict.
This patch avoids this by using the flag and lock introduced by the earlier
patch for the mos7720 driver.
Signed-off-by: NOliver Neukum <oneukum@suse.de>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 b0a239da
...@@ -461,17 +461,21 @@ static void klsi_105_close (struct usb_serial_port *port, struct file *filp) ...@@ -461,17 +461,21 @@ static void klsi_105_close (struct usb_serial_port *port, struct file *filp)
dbg("%s port %d", __FUNCTION__, port->number); dbg("%s port %d", __FUNCTION__, port->number);
/* send READ_OFF */ mutex_lock(&port->serial->disc_mutex);
rc = usb_control_msg (port->serial->dev, if (!port->serial->disconnected) {
usb_sndctrlpipe(port->serial->dev, 0), /* send READ_OFF */
KL5KUSB105A_SIO_CONFIGURE, rc = usb_control_msg (port->serial->dev,
USB_TYPE_VENDOR | USB_DIR_OUT, usb_sndctrlpipe(port->serial->dev, 0),
KL5KUSB105A_SIO_CONFIGURE_READ_OFF, KL5KUSB105A_SIO_CONFIGURE,
0, /* index */ USB_TYPE_VENDOR | USB_DIR_OUT,
NULL, 0, KL5KUSB105A_SIO_CONFIGURE_READ_OFF,
KLSI_TIMEOUT); 0, /* index */
if (rc < 0) NULL, 0,
err("Disabling read failed (error = %d)", rc); KLSI_TIMEOUT);
if (rc < 0)
err("Disabling read failed (error = %d)", rc);
}
mutex_unlock(&port->serial->disc_mutex);
/* shutdown our bulk reads and writes */ /* shutdown our bulk reads and writes */
usb_kill_urb(port->write_urb); usb_kill_urb(port->write_urb);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册