Commit 74bccc9b authored by Ladislav Michl's avatar Ladislav Michl Committed by Greg Kroah-Hartman

cdc-acm: store in and out pipes in acm structure

Clearing stall needs pipe descriptor, store it in acm structure.
Signed-off-by: default avatarLadislav Michl <ladis@linux-mips.org>
Acked-by: default avatarOliver Neukum <oneukum@suse.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ba8c931d
...@@ -1338,8 +1338,16 @@ static int acm_probe(struct usb_interface *intf, ...@@ -1338,8 +1338,16 @@ static int acm_probe(struct usb_interface *intf,
spin_lock_init(&acm->read_lock); spin_lock_init(&acm->read_lock);
mutex_init(&acm->mutex); mutex_init(&acm->mutex);
acm->is_int_ep = usb_endpoint_xfer_int(epread); acm->is_int_ep = usb_endpoint_xfer_int(epread);
if (acm->is_int_ep) if (acm->is_int_ep) {
acm->bInterval = epread->bInterval; acm->bInterval = epread->bInterval;
acm->in = usb_rcvintpipe(usb_dev, epread->bEndpointAddress);
} else {
acm->in = usb_rcvbulkpipe(usb_dev, epread->bEndpointAddress);
}
if (usb_endpoint_xfer_int(epwrite))
acm->out = usb_sndintpipe(usb_dev, epwrite->bEndpointAddress);
else
acm->out = usb_sndbulkpipe(usb_dev, epwrite->bEndpointAddress);
tty_port_init(&acm->port); tty_port_init(&acm->port);
acm->port.ops = &acm_port_ops; acm->port.ops = &acm_port_ops;
init_usb_anchor(&acm->delayed); init_usb_anchor(&acm->delayed);
...@@ -1374,20 +1382,15 @@ static int acm_probe(struct usb_interface *intf, ...@@ -1374,20 +1382,15 @@ static int acm_probe(struct usb_interface *intf,
urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP; urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
urb->transfer_dma = rb->dma; urb->transfer_dma = rb->dma;
if (acm->is_int_ep) { if (acm->is_int_ep)
usb_fill_int_urb(urb, acm->dev, usb_fill_int_urb(urb, acm->dev, acm->in, rb->base,
usb_rcvintpipe(usb_dev, epread->bEndpointAddress),
rb->base,
acm->readsize, acm->readsize,
acm_read_bulk_callback, rb, acm_read_bulk_callback, rb,
acm->bInterval); acm->bInterval);
} else { else
usb_fill_bulk_urb(urb, acm->dev, usb_fill_bulk_urb(urb, acm->dev, acm->in, rb->base,
usb_rcvbulkpipe(usb_dev, epread->bEndpointAddress),
rb->base,
acm->readsize, acm->readsize,
acm_read_bulk_callback, rb); acm_read_bulk_callback, rb);
}
acm->read_urbs[i] = urb; acm->read_urbs[i] = urb;
__set_bit(i, &acm->read_urbs_free); __set_bit(i, &acm->read_urbs_free);
...@@ -1400,12 +1403,10 @@ static int acm_probe(struct usb_interface *intf, ...@@ -1400,12 +1403,10 @@ static int acm_probe(struct usb_interface *intf,
goto alloc_fail7; goto alloc_fail7;
if (usb_endpoint_xfer_int(epwrite)) if (usb_endpoint_xfer_int(epwrite))
usb_fill_int_urb(snd->urb, usb_dev, usb_fill_int_urb(snd->urb, usb_dev, acm->out,
usb_sndintpipe(usb_dev, epwrite->bEndpointAddress),
NULL, acm->writesize, acm_write_bulk, snd, epwrite->bInterval); NULL, acm->writesize, acm_write_bulk, snd, epwrite->bInterval);
else else
usb_fill_bulk_urb(snd->urb, usb_dev, usb_fill_bulk_urb(snd->urb, usb_dev, acm->out,
usb_sndbulkpipe(usb_dev, epwrite->bEndpointAddress),
NULL, acm->writesize, acm_write_bulk, snd); NULL, acm->writesize, acm_write_bulk, snd);
snd->urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP; snd->urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
if (quirks & SEND_ZERO_PACKET) if (quirks & SEND_ZERO_PACKET)
...@@ -1477,8 +1478,8 @@ static int acm_probe(struct usb_interface *intf, ...@@ -1477,8 +1478,8 @@ static int acm_probe(struct usb_interface *intf,
} }
if (quirks & CLEAR_HALT_CONDITIONS) { if (quirks & CLEAR_HALT_CONDITIONS) {
usb_clear_halt(usb_dev, usb_rcvbulkpipe(usb_dev, epread->bEndpointAddress)); usb_clear_halt(usb_dev, acm->in);
usb_clear_halt(usb_dev, usb_sndbulkpipe(usb_dev, epwrite->bEndpointAddress)); usb_clear_halt(usb_dev, acm->out);
} }
return 0; return 0;
......
...@@ -83,6 +83,7 @@ struct acm { ...@@ -83,6 +83,7 @@ struct acm {
struct usb_device *dev; /* the corresponding usb device */ struct usb_device *dev; /* the corresponding usb device */
struct usb_interface *control; /* control interface */ struct usb_interface *control; /* control interface */
struct usb_interface *data; /* data interface */ struct usb_interface *data; /* data interface */
unsigned in, out; /* i/o pipes */
struct tty_port port; /* our tty port data */ struct tty_port port; /* our tty port data */
struct urb *ctrlurb; /* urbs */ struct urb *ctrlurb; /* urbs */
u8 *ctrl_buffer; /* buffers of urbs */ u8 *ctrl_buffer; /* buffers of urbs */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment