diff options
author | Michal Sojka <sojka@merica.cz> | 2014-09-24 16:43:18 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2014-09-25 10:58:17 -0400 |
commit | 3fc2aa5522ab958374d93ef5d2e12df7ee233c91 (patch) | |
tree | 65ffb2f11379a88d4b7aee17e47496c0677b1e61 /drivers | |
parent | 1b59fc7e3cda3f626204cadda8bb9b7d15f4f55b (diff) |
usb: gadget: Introduce usb_gadget_giveback_request()
All USB peripheral controller drivers call completion routines directly.
This patch adds usb_gadget_giveback_request() which will be used instead
of direct invocation in the next patch. The goal here is to have a place
where common functionality can be added.
Signed-off-by: Michal Sojka <sojka@merica.cz>
Acked-by: Felipe Balbi <balbi@ti.com>
Tested-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/usb/gadget/udc/udc-core.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/drivers/usb/gadget/udc/udc-core.c b/drivers/usb/gadget/udc/udc-core.c index ad1ceac15468..16d3f6fedd1c 100644 --- a/drivers/usb/gadget/udc/udc-core.c +++ b/drivers/usb/gadget/udc/udc-core.c | |||
@@ -106,6 +106,22 @@ EXPORT_SYMBOL_GPL(usb_gadget_unmap_request); | |||
106 | 106 | ||
107 | /* ------------------------------------------------------------------------- */ | 107 | /* ------------------------------------------------------------------------- */ |
108 | 108 | ||
109 | /** | ||
110 | * usb_gadget_giveback_request - give the request back to the gadget layer | ||
111 | * Context: in_interrupt() | ||
112 | * | ||
113 | * This is called by device controller drivers in order to return the | ||
114 | * completed request back to the gadget layer. | ||
115 | */ | ||
116 | void usb_gadget_giveback_request(struct usb_ep *ep, | ||
117 | struct usb_request *req) | ||
118 | { | ||
119 | req->complete(ep, req); | ||
120 | } | ||
121 | EXPORT_SYMBOL_GPL(usb_gadget_giveback_request); | ||
122 | |||
123 | /* ------------------------------------------------------------------------- */ | ||
124 | |||
109 | static void usb_gadget_state_work(struct work_struct *work) | 125 | static void usb_gadget_state_work(struct work_struct *work) |
110 | { | 126 | { |
111 | struct usb_gadget *gadget = work_to_gadget(work); | 127 | struct usb_gadget *gadget = work_to_gadget(work); |