aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/serial/oti6858.c
diff options
context:
space:
mode:
authorJohan Hovold <jhovold@gmail.com>2013-03-21 07:37:19 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2013-03-25 16:52:25 -0400
commit215f6f04668e80543995300c9528ac0143fcda7f (patch)
tree0e71138dac557ce29bf56f8264eeeb54d1f53171 /drivers/usb/serial/oti6858.c
parent1c9f995363d4a80de72da15af3d66a3dc2f56952 (diff)
USB: oti6858: fix TIOCMIWAIT and disconnect
Use tty-port modem-status-change wait queue on which processes are woken up at hangup and disconnect. Currently a process waiting on modem-status changes will not be woken on device disconnect. Signed-off-by: Johan Hovold <jhovold@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb/serial/oti6858.c')
-rw-r--r--drivers/usb/serial/oti6858.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/usb/serial/oti6858.c b/drivers/usb/serial/oti6858.c
index fd5dcb878fa5..7e3e0782e51f 100644
--- a/drivers/usb/serial/oti6858.c
+++ b/drivers/usb/serial/oti6858.c
@@ -662,7 +662,7 @@ static int oti6858_tiocmiwait(struct tty_struct *tty, unsigned long arg)
662 spin_unlock_irqrestore(&priv->lock, flags); 662 spin_unlock_irqrestore(&priv->lock, flags);
663 663
664 while (1) { 664 while (1) {
665 wait_event_interruptible(port->delta_msr_wait, 665 wait_event_interruptible(port->port.delta_msr_wait,
666 port->serial->disconnected || 666 port->serial->disconnected ||
667 priv->status.pin_state != prev); 667 priv->status.pin_state != prev);
668 if (signal_pending(current)) 668 if (signal_pending(current))
@@ -747,7 +747,7 @@ static void oti6858_read_int_callback(struct urb *urb)
747 747
748 if (!priv->transient) { 748 if (!priv->transient) {
749 if (xs->pin_state != priv->status.pin_state) 749 if (xs->pin_state != priv->status.pin_state)
750 wake_up_interruptible(&port->delta_msr_wait); 750 wake_up_interruptible(&port->port.delta_msr_wait);
751 memcpy(&priv->status, xs, OTI6858_CTRL_PKT_SIZE); 751 memcpy(&priv->status, xs, OTI6858_CTRL_PKT_SIZE);
752 } 752 }
753 753