aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/serial/ftdi_sio.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/usb/serial/ftdi_sio.c')
-rw-r--r--drivers/usb/serial/ftdi_sio.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/drivers/usb/serial/ftdi_sio.c b/drivers/usb/serial/ftdi_sio.c
index c186b4e73c72..88ed5c1d236c 100644
--- a/drivers/usb/serial/ftdi_sio.c
+++ b/drivers/usb/serial/ftdi_sio.c
@@ -559,7 +559,8 @@ struct ftdi_private {
559 char prev_status, diff_status; /* Used for TIOCMIWAIT */ 559 char prev_status, diff_status; /* Used for TIOCMIWAIT */
560 __u8 rx_flags; /* receive state flags (throttling) */ 560 __u8 rx_flags; /* receive state flags (throttling) */
561 spinlock_t rx_lock; /* spinlock for receive state */ 561 spinlock_t rx_lock; /* spinlock for receive state */
562 struct work_struct rx_work; 562 struct delayed_work rx_work;
563 struct usb_serial_port *port;
563 int rx_processed; 564 int rx_processed;
564 unsigned long rx_bytes; 565 unsigned long rx_bytes;
565 566
@@ -593,7 +594,7 @@ static int ftdi_write_room (struct usb_serial_port *port);
593static int ftdi_chars_in_buffer (struct usb_serial_port *port); 594static int ftdi_chars_in_buffer (struct usb_serial_port *port);
594static void ftdi_write_bulk_callback (struct urb *urb); 595static void ftdi_write_bulk_callback (struct urb *urb);
595static void ftdi_read_bulk_callback (struct urb *urb); 596static void ftdi_read_bulk_callback (struct urb *urb);
596static void ftdi_process_read (void *param); 597static void ftdi_process_read (struct work_struct *work);
597static void ftdi_set_termios (struct usb_serial_port *port, struct termios * old); 598static void ftdi_set_termios (struct usb_serial_port *port, struct termios * old);
598static int ftdi_tiocmget (struct usb_serial_port *port, struct file *file); 599static int ftdi_tiocmget (struct usb_serial_port *port, struct file *file);
599static int ftdi_tiocmset (struct usb_serial_port *port, struct file * file, unsigned int set, unsigned int clear); 600static int ftdi_tiocmset (struct usb_serial_port *port, struct file * file, unsigned int set, unsigned int clear);
@@ -1201,7 +1202,8 @@ static int ftdi_sio_attach (struct usb_serial *serial)
1201 port->read_urb->transfer_buffer_length = BUFSZ; 1202 port->read_urb->transfer_buffer_length = BUFSZ;
1202 } 1203 }
1203 1204
1204 INIT_WORK(&priv->rx_work, ftdi_process_read, port); 1205 INIT_DELAYED_WORK(&priv->rx_work, ftdi_process_read);
1206 priv->port = port;
1205 1207
1206 /* Free port's existing write urb and transfer buffer. */ 1208 /* Free port's existing write urb and transfer buffer. */
1207 if (port->write_urb) { 1209 if (port->write_urb) {
@@ -1641,17 +1643,18 @@ static void ftdi_read_bulk_callback (struct urb *urb)
1641 priv->rx_bytes += countread; 1643 priv->rx_bytes += countread;
1642 spin_unlock_irqrestore(&priv->rx_lock, flags); 1644 spin_unlock_irqrestore(&priv->rx_lock, flags);
1643 1645
1644 ftdi_process_read(port); 1646 ftdi_process_read(&priv->rx_work.work);
1645 1647
1646} /* ftdi_read_bulk_callback */ 1648} /* ftdi_read_bulk_callback */
1647 1649
1648 1650
1649static void ftdi_process_read (void *param) 1651static void ftdi_process_read (struct work_struct *work)
1650{ /* ftdi_process_read */ 1652{ /* ftdi_process_read */
1651 struct usb_serial_port *port = (struct usb_serial_port*)param; 1653 struct ftdi_private *priv =
1654 container_of(work, struct ftdi_private, rx_work.work);
1655 struct usb_serial_port *port = priv->port;
1652 struct urb *urb; 1656 struct urb *urb;
1653 struct tty_struct *tty; 1657 struct tty_struct *tty;
1654 struct ftdi_private *priv;
1655 char error_flag; 1658 char error_flag;
1656 unsigned char *data; 1659 unsigned char *data;
1657 1660
@@ -2180,7 +2183,7 @@ static void ftdi_unthrottle (struct usb_serial_port *port)
2180 spin_unlock_irqrestore(&priv->rx_lock, flags); 2183 spin_unlock_irqrestore(&priv->rx_lock, flags);
2181 2184
2182 if (actually_throttled) 2185 if (actually_throttled)
2183 schedule_work(&priv->rx_work); 2186 schedule_delayed_work(&priv->rx_work, 0);
2184} 2187}
2185 2188
2186static int __init ftdi_init (void) 2189static int __init ftdi_init (void)