Subject: [PATCH 003/008] USB: serial: adding sierra_submit_rx_urbs() function From: Elina Pasheva <epasheva@xxxxxxxxxxxxxxxxxx> The following is summary of changes we have made to sierra.c driver in [PATCH 003/008] from the series dealing with improving urb handling: - Added new function sierra_submit_rx_urbs() that handles the submission of receive urbs and interrupt urbs (if any) during the interface activation. This function is to be called by sierra_open(). Signed-off-by: Elina Pasheva <epasheva@xxxxxxxxxxxxxxxxxx> --- sierra.c | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) --- a/drivers/usb/serial/sierra.c 2009-05-04 17:52:20.000000000 -0700 +++ b/drivers/usb/serial/sierra.c 2009-05-04 18:05:37.000000000 -0700 @@ -617,6 +617,42 @@ static void sierra_stop_rx_urbs(struct u usb_kill_urb(port->interrupt_in_urb); } +static int sierra_submit_rx_urbs(struct usb_serial_port *port) +{ + int ok_cnt; + int err = -EINVAL; + int i; + struct urb *urb; + struct sierra_port_private *portdata = usb_get_serial_port_data(port); + + ok_cnt = 0; + for (i = 0; i < ARRAY_SIZE(portdata->in_urbs); i++) { + urb = portdata->in_urbs[i]; + if (!urb) + continue; + err = usb_submit_urb(urb, GFP_KERNEL); + if (err) { + dev_err(&port->dev, "%s: submit urb failed: %d\n", + __func__, err); + } else { + ok_cnt++; + } + } + + if (ok_cnt && port->interrupt_in_urb) { + err = usb_submit_urb(port->interrupt_in_urb, GFP_KERNEL); + if (err) { + dev_err(&port->dev, "%s: submit intr urb failed: %d\n", + __func__, err); + } + } + + if (ok_cnt > 0) /* at least one rx urb submitted */ + return 0; + else + return err; +} + static int sierra_open(struct tty_struct *tty, struct usb_serial_port *port, struct file *filp) { -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html