diff options
author | Alan Cox <alan@linux.intel.com> | 2009-09-19 16:13:23 -0400 |
---|---|---|
committer | Live-CD User <linux@linux.site> | 2009-09-19 16:13:23 -0400 |
commit | d2b391822a11302add9e46476f3da4e18e6de84c (patch) | |
tree | 26cd352e935d0cf3c65181d78f9af86b21b48e79 /drivers/usb/serial/usb-serial.c | |
parent | 9b80fee149a875a6292b2556ab2c64dc7ab7d6f5 (diff) |
tty: USB hangup is racy
The USB layer uses tty_hangup to deal with unplugs of the physical hardware
(analogous to loss of carrier) and then frees the resources. However the
tty_hangup is asynchronous. As the hangup can sleep we can use tty_vhangup
which is the non async version to avoid freeing resources too early.
Signed-off-by: Alan Cox <alan@linux.intel.com>
Cc: stable <stable@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/serial/usb-serial.c')
-rw-r--r-- | drivers/usb/serial/usb-serial.c | 5 |
1 files changed, 1 insertions, 4 deletions
diff --git a/drivers/usb/serial/usb-serial.c b/drivers/usb/serial/usb-serial.c index 99188c92068b..21dd72a5a715 100644 --- a/drivers/usb/serial/usb-serial.c +++ b/drivers/usb/serial/usb-serial.c | |||
@@ -1161,10 +1161,7 @@ void usb_serial_disconnect(struct usb_interface *interface) | |||
1161 | if (port) { | 1161 | if (port) { |
1162 | struct tty_struct *tty = tty_port_tty_get(&port->port); | 1162 | struct tty_struct *tty = tty_port_tty_get(&port->port); |
1163 | if (tty) { | 1163 | if (tty) { |
1164 | /* The hangup will occur asynchronously but | 1164 | tty_vhangup(tty); |
1165 | the object refcounts will sort out all the | ||
1166 | cleanup */ | ||
1167 | tty_hangup(tty); | ||
1168 | tty_kref_put(tty); | 1165 | tty_kref_put(tty); |
1169 | } | 1166 | } |
1170 | kill_traffic(port); | 1167 | kill_traffic(port); |