aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/usb
diff options
context:
space:
mode:
authorTatyana Brokhman <tlinder@codeaurora.org>2011-06-28 09:33:53 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2011-06-28 14:20:15 -0400
commita59d6b91cbca52235e3ed9f7f9e34c4f2f3e1996 (patch)
tree664cd1de638695c0f4ad8c73df27382a3ecc6659 /include/linux/usb
parent7c884fe4d74d17efc83b19f3dc898a75f03859e9 (diff)
usb: gadget: add streams support to the gadget framework
This patch defines necessary fields to support streaming for USB3.0. It implements a new function, called usb_ep_autoconfig_ss(), to be used instead of the existing usb_ep_autoconfig() when working in SuperSpeed mode and there is a need to search for an endpoint according to the number of required streams. [ balbi@ti.com : slight changes to commit log ] Signed-off-by: Maya Erez <merez@codeaurora.org> Signed-off-by: Tatyana Brokhman <tlinder@codeaurora.org> Signed-off-by: Felipe Balbi <balbi@ti.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'include/linux/usb')
-rw-r--r--include/linux/usb/gadget.h13
1 files changed, 13 insertions, 0 deletions
diff --git a/include/linux/usb/gadget.h b/include/linux/usb/gadget.h
index d22b4a4936c..625971292c2 100644
--- a/include/linux/usb/gadget.h
+++ b/include/linux/usb/gadget.h
@@ -28,6 +28,7 @@ struct usb_ep;
28 * field, and the usb controller needs one, it is responsible 28 * field, and the usb controller needs one, it is responsible
29 * for mapping and unmapping the buffer. 29 * for mapping and unmapping the buffer.
30 * @length: Length of that data 30 * @length: Length of that data
31 * @stream_id: The stream id, when USB3.0 bulk streams are being used
31 * @no_interrupt: If true, hints that no completion irq is needed. 32 * @no_interrupt: If true, hints that no completion irq is needed.
32 * Helpful sometimes with deep request queues that are handled 33 * Helpful sometimes with deep request queues that are handled
33 * directly by DMA controllers. 34 * directly by DMA controllers.
@@ -82,6 +83,7 @@ struct usb_request {
82 unsigned length; 83 unsigned length;
83 dma_addr_t dma; 84 dma_addr_t dma;
84 85
86 unsigned stream_id:16;
85 unsigned no_interrupt:1; 87 unsigned no_interrupt:1;
86 unsigned zero:1; 88 unsigned zero:1;
87 unsigned short_not_ok:1; 89 unsigned short_not_ok:1;
@@ -132,11 +134,15 @@ struct usb_ep_ops {
132 * @maxpacket:The maximum packet size used on this endpoint. The initial 134 * @maxpacket:The maximum packet size used on this endpoint. The initial
133 * value can sometimes be reduced (hardware allowing), according to 135 * value can sometimes be reduced (hardware allowing), according to
134 * the endpoint descriptor used to configure the endpoint. 136 * the endpoint descriptor used to configure the endpoint.
137 * @max_streams: The maximum number of streams supported
138 * by this EP (0 - 16, actual number is 2^n)
135 * @driver_data:for use by the gadget driver. 139 * @driver_data:for use by the gadget driver.
136 * @address: used to identify the endpoint when finding descriptor that 140 * @address: used to identify the endpoint when finding descriptor that
137 * matches connection speed 141 * matches connection speed
138 * @desc: endpoint descriptor. This pointer is set before the endpoint is 142 * @desc: endpoint descriptor. This pointer is set before the endpoint is
139 * enabled and remains valid until the endpoint is disabled. 143 * enabled and remains valid until the endpoint is disabled.
144 * @comp_desc: In case of SuperSpeed support, this is the endpoint companion
145 * descriptor that is used to configure the endpoint
140 * 146 *
141 * the bus controller driver lists all the general purpose endpoints in 147 * the bus controller driver lists all the general purpose endpoints in
142 * gadget->ep_list. the control endpoint (gadget->ep0) is not in that list, 148 * gadget->ep_list. the control endpoint (gadget->ep0) is not in that list,
@@ -149,8 +155,10 @@ struct usb_ep {
149 const struct usb_ep_ops *ops; 155 const struct usb_ep_ops *ops;
150 struct list_head ep_list; 156 struct list_head ep_list;
151 unsigned maxpacket:16; 157 unsigned maxpacket:16;
158 unsigned max_streams:16;
152 u8 address; 159 u8 address;
153 const struct usb_endpoint_descriptor *desc; 160 const struct usb_endpoint_descriptor *desc;
161 const struct usb_ss_ep_comp_descriptor *comp_desc;
154}; 162};
155 163
156/*-------------------------------------------------------------------------*/ 164/*-------------------------------------------------------------------------*/
@@ -895,6 +903,11 @@ static inline void usb_free_descriptors(struct usb_descriptor_header **v)
895extern struct usb_ep *usb_ep_autoconfig(struct usb_gadget *, 903extern struct usb_ep *usb_ep_autoconfig(struct usb_gadget *,
896 struct usb_endpoint_descriptor *); 904 struct usb_endpoint_descriptor *);
897 905
906
907extern struct usb_ep *usb_ep_autoconfig_ss(struct usb_gadget *,
908 struct usb_endpoint_descriptor *,
909 struct usb_ss_ep_comp_descriptor *);
910
898extern void usb_ep_autoconfig_reset(struct usb_gadget *); 911extern void usb_ep_autoconfig_reset(struct usb_gadget *);
899 912
900#endif /* __LINUX_USB_GADGET_H */ 913#endif /* __LINUX_USB_GADGET_H */