diff options
author | Duncan Sands <baldrick@free.fr> | 2006-01-13 04:59:23 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2006-01-31 20:23:40 -0500 |
commit | 80aae7a17afd21f7ba900dd566fb23a2444021f8 (patch) | |
tree | 2193fe416373daddbc2b1da8bca61664081b927b /drivers/usb/atm/usbatm.h | |
parent | 6f7494759870ec6fbb066f7202c5585fe36fbe82 (diff) |
[PATCH] USBATM: allow isochronous transfer
While the usbatm core has had some support for using isoc urbs
for some time, there was no way for users to turn it on. While
use of isoc transfer should still be considered experimental, it
now works well enough to let users turn it on. Minidrivers signal
to the core that they want to use isoc transfer by setting the new
UDSL_USE_ISOC flag. The speedtch minidriver gets a new module
parameter enable_isoc (defaults to false), plus some logic that
checks for the existence of an isoc receive endpoint (not all
speedtouch modems have one).
Signed-off-by: Duncan Sands <baldrick@free.fr>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/atm/usbatm.h')
-rw-r--r-- | drivers/usb/atm/usbatm.h | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/usb/atm/usbatm.h b/drivers/usb/atm/usbatm.h index 1a31cf87bb1f..0e2caa0967c1 100644 --- a/drivers/usb/atm/usbatm.h +++ b/drivers/usb/atm/usbatm.h | |||
@@ -87,6 +87,7 @@ | |||
87 | /* flags, set by mini-driver in bind() */ | 87 | /* flags, set by mini-driver in bind() */ |
88 | 88 | ||
89 | #define UDSL_SKIP_HEAVY_INIT (1<<0) | 89 | #define UDSL_SKIP_HEAVY_INIT (1<<0) |
90 | #define UDSL_USE_ISOC (1<<1) | ||
90 | 91 | ||
91 | 92 | ||
92 | /* mini driver */ | 93 | /* mini driver */ |
@@ -118,8 +119,9 @@ struct usbatm_driver { | |||
118 | /* cleanup ATM device ... can sleep, but can't fail */ | 119 | /* cleanup ATM device ... can sleep, but can't fail */ |
119 | void (*atm_stop) (struct usbatm_data *, struct atm_dev *); | 120 | void (*atm_stop) (struct usbatm_data *, struct atm_dev *); |
120 | 121 | ||
121 | int in; /* rx endpoint */ | 122 | int bulk_in; /* bulk rx endpoint */ |
122 | int out; /* tx endpoint */ | 123 | int isoc_in; /* isochronous rx endpoint */ |
124 | int bulk_out; /* bulk tx endpoint */ | ||
123 | 125 | ||
124 | unsigned rx_padding; | 126 | unsigned rx_padding; |
125 | unsigned tx_padding; | 127 | unsigned tx_padding; |
@@ -134,6 +136,7 @@ struct usbatm_channel { | |||
134 | int endpoint; /* usb pipe */ | 136 | int endpoint; /* usb pipe */ |
135 | unsigned int stride; /* ATM cell size + padding */ | 137 | unsigned int stride; /* ATM cell size + padding */ |
136 | unsigned int buf_size; /* urb buffer size */ | 138 | unsigned int buf_size; /* urb buffer size */ |
139 | unsigned int packet_size; /* endpoint maxpacket */ | ||
137 | spinlock_t lock; | 140 | spinlock_t lock; |
138 | struct list_head list; | 141 | struct list_head list; |
139 | struct tasklet_struct tasklet; | 142 | struct tasklet_struct tasklet; |