xref: /linux/drivers/usb/dwc3/gadget.c (revision 9e8ba5f3ec35cba4fd8a8bebda548c4db2651e40)
1 /**
2  * gadget.c - DesignWare USB3 DRD Controller Gadget Framework Link
3  *
4  * Copyright (C) 2010-2011 Texas Instruments Incorporated - http://www.ti.com
5  *
6  * Authors: Felipe Balbi <balbi@ti.com>,
7  *	    Sebastian Andrzej Siewior <bigeasy@linutronix.de>
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  * 1. Redistributions of source code must retain the above copyright
13  *    notice, this list of conditions, and the following disclaimer,
14  *    without modification.
15  * 2. Redistributions in binary form must reproduce the above copyright
16  *    notice, this list of conditions and the following disclaimer in the
17  *    documentation and/or other materials provided with the distribution.
18  * 3. The names of the above-listed copyright holders may not be used
19  *    to endorse or promote products derived from this software without
20  *    specific prior written permission.
21  *
22  * ALTERNATIVELY, this software may be distributed under the terms of the
23  * GNU General Public License ("GPL") version 2, as published by the Free
24  * Software Foundation.
25  *
26  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
27  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
28  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
30  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
31  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
32  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
33  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
34  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
35  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
36  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37  */
38 
39 #include <linux/kernel.h>
40 #include <linux/delay.h>
41 #include <linux/slab.h>
42 #include <linux/spinlock.h>
43 #include <linux/platform_device.h>
44 #include <linux/pm_runtime.h>
45 #include <linux/interrupt.h>
46 #include <linux/io.h>
47 #include <linux/list.h>
48 #include <linux/dma-mapping.h>
49 
50 #include <linux/usb/ch9.h>
51 #include <linux/usb/gadget.h>
52 
53 #include "core.h"
54 #include "gadget.h"
55 #include "io.h"
56 
57 #define	DMA_ADDR_INVALID	(~(dma_addr_t)0)
58 
59 void dwc3_map_buffer_to_dma(struct dwc3_request *req)
60 {
61 	struct dwc3			*dwc = req->dep->dwc;
62 
63 	if (req->request.length == 0) {
64 		/* req->request.dma = dwc->setup_buf_addr; */
65 		return;
66 	}
67 
68 	if (req->request.dma == DMA_ADDR_INVALID) {
69 		req->request.dma = dma_map_single(dwc->dev, req->request.buf,
70 				req->request.length, req->direction
71 				? DMA_TO_DEVICE : DMA_FROM_DEVICE);
72 		req->mapped = true;
73 	}
74 }
75 
76 void dwc3_unmap_buffer_from_dma(struct dwc3_request *req)
77 {
78 	struct dwc3			*dwc = req->dep->dwc;
79 
80 	if (req->request.length == 0) {
81 		req->request.dma = DMA_ADDR_INVALID;
82 		return;
83 	}
84 
85 	if (req->mapped) {
86 		dma_unmap_single(dwc->dev, req->request.dma,
87 				req->request.length, req->direction
88 				? DMA_TO_DEVICE : DMA_FROM_DEVICE);
89 		req->mapped = 0;
90 		req->request.dma = DMA_ADDR_INVALID;
91 	}
92 }
93 
94 void dwc3_gadget_giveback(struct dwc3_ep *dep, struct dwc3_request *req,
95 		int status)
96 {
97 	struct dwc3			*dwc = dep->dwc;
98 
99 	if (req->queued) {
100 		dep->busy_slot++;
101 		/*
102 		 * Skip LINK TRB. We can't use req->trb and check for
103 		 * DWC3_TRBCTL_LINK_TRB because it points the TRB we just
104 		 * completed (not the LINK TRB).
105 		 */
106 		if (((dep->busy_slot & DWC3_TRB_MASK) == DWC3_TRB_NUM - 1) &&
107 				usb_endpoint_xfer_isoc(dep->desc))
108 			dep->busy_slot++;
109 	}
110 	list_del(&req->list);
111 
112 	if (req->request.status == -EINPROGRESS)
113 		req->request.status = status;
114 
115 	dwc3_unmap_buffer_from_dma(req);
116 
117 	dev_dbg(dwc->dev, "request %p from %s completed %d/%d ===> %d\n",
118 			req, dep->name, req->request.actual,
119 			req->request.length, status);
120 
121 	spin_unlock(&dwc->lock);
122 	req->request.complete(&req->dep->endpoint, &req->request);
123 	spin_lock(&dwc->lock);
124 }
125 
126 static const char *dwc3_gadget_ep_cmd_string(u8 cmd)
127 {
128 	switch (cmd) {
129 	case DWC3_DEPCMD_DEPSTARTCFG:
130 		return "Start New Configuration";
131 	case DWC3_DEPCMD_ENDTRANSFER:
132 		return "End Transfer";
133 	case DWC3_DEPCMD_UPDATETRANSFER:
134 		return "Update Transfer";
135 	case DWC3_DEPCMD_STARTTRANSFER:
136 		return "Start Transfer";
137 	case DWC3_DEPCMD_CLEARSTALL:
138 		return "Clear Stall";
139 	case DWC3_DEPCMD_SETSTALL:
140 		return "Set Stall";
141 	case DWC3_DEPCMD_GETSEQNUMBER:
142 		return "Get Data Sequence Number";
143 	case DWC3_DEPCMD_SETTRANSFRESOURCE:
144 		return "Set Endpoint Transfer Resource";
145 	case DWC3_DEPCMD_SETEPCONFIG:
146 		return "Set Endpoint Configuration";
147 	default:
148 		return "UNKNOWN command";
149 	}
150 }
151 
152 int dwc3_send_gadget_ep_cmd(struct dwc3 *dwc, unsigned ep,
153 		unsigned cmd, struct dwc3_gadget_ep_cmd_params *params)
154 {
155 	struct dwc3_ep		*dep = dwc->eps[ep];
156 	u32			timeout = 500;
157 	u32			reg;
158 
159 	dev_vdbg(dwc->dev, "%s: cmd '%s' params %08x %08x %08x\n",
160 			dep->name,
161 			dwc3_gadget_ep_cmd_string(cmd), params->param0,
162 			params->param1, params->param2);
163 
164 	dwc3_writel(dwc->regs, DWC3_DEPCMDPAR0(ep), params->param0);
165 	dwc3_writel(dwc->regs, DWC3_DEPCMDPAR1(ep), params->param1);
166 	dwc3_writel(dwc->regs, DWC3_DEPCMDPAR2(ep), params->param2);
167 
168 	dwc3_writel(dwc->regs, DWC3_DEPCMD(ep), cmd | DWC3_DEPCMD_CMDACT);
169 	do {
170 		reg = dwc3_readl(dwc->regs, DWC3_DEPCMD(ep));
171 		if (!(reg & DWC3_DEPCMD_CMDACT)) {
172 			dev_vdbg(dwc->dev, "Command Complete --> %d\n",
173 					DWC3_DEPCMD_STATUS(reg));
174 			return 0;
175 		}
176 
177 		/*
178 		 * We can't sleep here, because it is also called from
179 		 * interrupt context.
180 		 */
181 		timeout--;
182 		if (!timeout)
183 			return -ETIMEDOUT;
184 
185 		udelay(1);
186 	} while (1);
187 }
188 
189 static dma_addr_t dwc3_trb_dma_offset(struct dwc3_ep *dep,
190 		struct dwc3_trb_hw *trb)
191 {
192 	u32		offset = (char *) trb - (char *) dep->trb_pool;
193 
194 	return dep->trb_pool_dma + offset;
195 }
196 
197 static int dwc3_alloc_trb_pool(struct dwc3_ep *dep)
198 {
199 	struct dwc3		*dwc = dep->dwc;
200 
201 	if (dep->trb_pool)
202 		return 0;
203 
204 	if (dep->number == 0 || dep->number == 1)
205 		return 0;
206 
207 	dep->trb_pool = dma_alloc_coherent(dwc->dev,
208 			sizeof(struct dwc3_trb) * DWC3_TRB_NUM,
209 			&dep->trb_pool_dma, GFP_KERNEL);
210 	if (!dep->trb_pool) {
211 		dev_err(dep->dwc->dev, "failed to allocate trb pool for %s\n",
212 				dep->name);
213 		return -ENOMEM;
214 	}
215 
216 	return 0;
217 }
218 
219 static void dwc3_free_trb_pool(struct dwc3_ep *dep)
220 {
221 	struct dwc3		*dwc = dep->dwc;
222 
223 	dma_free_coherent(dwc->dev, sizeof(struct dwc3_trb) * DWC3_TRB_NUM,
224 			dep->trb_pool, dep->trb_pool_dma);
225 
226 	dep->trb_pool = NULL;
227 	dep->trb_pool_dma = 0;
228 }
229 
230 static int dwc3_gadget_start_config(struct dwc3 *dwc, struct dwc3_ep *dep)
231 {
232 	struct dwc3_gadget_ep_cmd_params params;
233 	u32			cmd;
234 
235 	memset(&params, 0x00, sizeof(params));
236 
237 	if (dep->number != 1) {
238 		cmd = DWC3_DEPCMD_DEPSTARTCFG;
239 		/* XferRscIdx == 0 for ep0 and 2 for the remaining */
240 		if (dep->number > 1) {
241 			if (dwc->start_config_issued)
242 				return 0;
243 			dwc->start_config_issued = true;
244 			cmd |= DWC3_DEPCMD_PARAM(2);
245 		}
246 
247 		return dwc3_send_gadget_ep_cmd(dwc, 0, cmd, &params);
248 	}
249 
250 	return 0;
251 }
252 
253 static int dwc3_gadget_set_ep_config(struct dwc3 *dwc, struct dwc3_ep *dep,
254 		const struct usb_endpoint_descriptor *desc)
255 {
256 	struct dwc3_gadget_ep_cmd_params params;
257 
258 	memset(&params, 0x00, sizeof(params));
259 
260 	params.param0 = DWC3_DEPCFG_EP_TYPE(usb_endpoint_type(desc))
261 		| DWC3_DEPCFG_MAX_PACKET_SIZE(usb_endpoint_maxp(desc))
262 		| DWC3_DEPCFG_BURST_SIZE(dep->endpoint.maxburst);
263 
264 	params.param1 = DWC3_DEPCFG_XFER_COMPLETE_EN
265 		| DWC3_DEPCFG_XFER_NOT_READY_EN;
266 
267 	if (usb_endpoint_xfer_bulk(desc) && dep->endpoint.max_streams) {
268 		params.param1 |= DWC3_DEPCFG_STREAM_CAPABLE
269 			| DWC3_DEPCFG_STREAM_EVENT_EN;
270 		dep->stream_capable = true;
271 	}
272 
273 	if (usb_endpoint_xfer_isoc(desc))
274 		params.param1 |= DWC3_DEPCFG_XFER_IN_PROGRESS_EN;
275 
276 	/*
277 	 * We are doing 1:1 mapping for endpoints, meaning
278 	 * Physical Endpoints 2 maps to Logical Endpoint 2 and
279 	 * so on. We consider the direction bit as part of the physical
280 	 * endpoint number. So USB endpoint 0x81 is 0x03.
281 	 */
282 	params.param1 |= DWC3_DEPCFG_EP_NUMBER(dep->number);
283 
284 	/*
285 	 * We must use the lower 16 TX FIFOs even though
286 	 * HW might have more
287 	 */
288 	if (dep->direction)
289 		params.param0 |= DWC3_DEPCFG_FIFO_NUMBER(dep->number >> 1);
290 
291 	if (desc->bInterval) {
292 		params.param1 |= DWC3_DEPCFG_BINTERVAL_M1(desc->bInterval - 1);
293 		dep->interval = 1 << (desc->bInterval - 1);
294 	}
295 
296 	return dwc3_send_gadget_ep_cmd(dwc, dep->number,
297 			DWC3_DEPCMD_SETEPCONFIG, &params);
298 }
299 
300 static int dwc3_gadget_set_xfer_resource(struct dwc3 *dwc, struct dwc3_ep *dep)
301 {
302 	struct dwc3_gadget_ep_cmd_params params;
303 
304 	memset(&params, 0x00, sizeof(params));
305 
306 	params.param0 = DWC3_DEPXFERCFG_NUM_XFER_RES(1);
307 
308 	return dwc3_send_gadget_ep_cmd(dwc, dep->number,
309 			DWC3_DEPCMD_SETTRANSFRESOURCE, &params);
310 }
311 
312 /**
313  * __dwc3_gadget_ep_enable - Initializes a HW endpoint
314  * @dep: endpoint to be initialized
315  * @desc: USB Endpoint Descriptor
316  *
317  * Caller should take care of locking
318  */
319 static int __dwc3_gadget_ep_enable(struct dwc3_ep *dep,
320 		const struct usb_endpoint_descriptor *desc)
321 {
322 	struct dwc3		*dwc = dep->dwc;
323 	u32			reg;
324 	int			ret = -ENOMEM;
325 
326 	if (!(dep->flags & DWC3_EP_ENABLED)) {
327 		ret = dwc3_gadget_start_config(dwc, dep);
328 		if (ret)
329 			return ret;
330 	}
331 
332 	ret = dwc3_gadget_set_ep_config(dwc, dep, desc);
333 	if (ret)
334 		return ret;
335 
336 	if (!(dep->flags & DWC3_EP_ENABLED)) {
337 		struct dwc3_trb_hw	*trb_st_hw;
338 		struct dwc3_trb_hw	*trb_link_hw;
339 		struct dwc3_trb		trb_link;
340 
341 		ret = dwc3_gadget_set_xfer_resource(dwc, dep);
342 		if (ret)
343 			return ret;
344 
345 		dep->desc = desc;
346 		dep->type = usb_endpoint_type(desc);
347 		dep->flags |= DWC3_EP_ENABLED;
348 
349 		reg = dwc3_readl(dwc->regs, DWC3_DALEPENA);
350 		reg |= DWC3_DALEPENA_EP(dep->number);
351 		dwc3_writel(dwc->regs, DWC3_DALEPENA, reg);
352 
353 		if (!usb_endpoint_xfer_isoc(desc))
354 			return 0;
355 
356 		memset(&trb_link, 0, sizeof(trb_link));
357 
358 		/* Link TRB for ISOC. The HWO but is never reset */
359 		trb_st_hw = &dep->trb_pool[0];
360 
361 		trb_link.bplh = dwc3_trb_dma_offset(dep, trb_st_hw);
362 		trb_link.trbctl = DWC3_TRBCTL_LINK_TRB;
363 		trb_link.hwo = true;
364 
365 		trb_link_hw = &dep->trb_pool[DWC3_TRB_NUM - 1];
366 		dwc3_trb_to_hw(&trb_link, trb_link_hw);
367 	}
368 
369 	return 0;
370 }
371 
372 static void dwc3_stop_active_transfer(struct dwc3 *dwc, u32 epnum);
373 static void dwc3_remove_requests(struct dwc3 *dwc, struct dwc3_ep *dep)
374 {
375 	struct dwc3_request		*req;
376 
377 	if (!list_empty(&dep->req_queued))
378 		dwc3_stop_active_transfer(dwc, dep->number);
379 
380 	while (!list_empty(&dep->request_list)) {
381 		req = next_request(&dep->request_list);
382 
383 		dwc3_gadget_giveback(dep, req, -ESHUTDOWN);
384 	}
385 }
386 
387 /**
388  * __dwc3_gadget_ep_disable - Disables a HW endpoint
389  * @dep: the endpoint to disable
390  *
391  * This function also removes requests which are currently processed ny the
392  * hardware and those which are not yet scheduled.
393  * Caller should take care of locking.
394  */
395 static int __dwc3_gadget_ep_disable(struct dwc3_ep *dep)
396 {
397 	struct dwc3		*dwc = dep->dwc;
398 	u32			reg;
399 
400 	dwc3_remove_requests(dwc, dep);
401 
402 	reg = dwc3_readl(dwc->regs, DWC3_DALEPENA);
403 	reg &= ~DWC3_DALEPENA_EP(dep->number);
404 	dwc3_writel(dwc->regs, DWC3_DALEPENA, reg);
405 
406 	dep->stream_capable = false;
407 	dep->desc = NULL;
408 	dep->type = 0;
409 	dep->flags = 0;
410 
411 	return 0;
412 }
413 
414 /* -------------------------------------------------------------------------- */
415 
416 static int dwc3_gadget_ep0_enable(struct usb_ep *ep,
417 		const struct usb_endpoint_descriptor *desc)
418 {
419 	return -EINVAL;
420 }
421 
422 static int dwc3_gadget_ep0_disable(struct usb_ep *ep)
423 {
424 	return -EINVAL;
425 }
426 
427 /* -------------------------------------------------------------------------- */
428 
429 static int dwc3_gadget_ep_enable(struct usb_ep *ep,
430 		const struct usb_endpoint_descriptor *desc)
431 {
432 	struct dwc3_ep			*dep;
433 	struct dwc3			*dwc;
434 	unsigned long			flags;
435 	int				ret;
436 
437 	if (!ep || !desc || desc->bDescriptorType != USB_DT_ENDPOINT) {
438 		pr_debug("dwc3: invalid parameters\n");
439 		return -EINVAL;
440 	}
441 
442 	if (!desc->wMaxPacketSize) {
443 		pr_debug("dwc3: missing wMaxPacketSize\n");
444 		return -EINVAL;
445 	}
446 
447 	dep = to_dwc3_ep(ep);
448 	dwc = dep->dwc;
449 
450 	switch (usb_endpoint_type(desc)) {
451 	case USB_ENDPOINT_XFER_CONTROL:
452 		strncat(dep->name, "-control", sizeof(dep->name));
453 		break;
454 	case USB_ENDPOINT_XFER_ISOC:
455 		strncat(dep->name, "-isoc", sizeof(dep->name));
456 		break;
457 	case USB_ENDPOINT_XFER_BULK:
458 		strncat(dep->name, "-bulk", sizeof(dep->name));
459 		break;
460 	case USB_ENDPOINT_XFER_INT:
461 		strncat(dep->name, "-int", sizeof(dep->name));
462 		break;
463 	default:
464 		dev_err(dwc->dev, "invalid endpoint transfer type\n");
465 	}
466 
467 	if (dep->flags & DWC3_EP_ENABLED) {
468 		dev_WARN_ONCE(dwc->dev, true, "%s is already enabled\n",
469 				dep->name);
470 		return 0;
471 	}
472 
473 	dev_vdbg(dwc->dev, "Enabling %s\n", dep->name);
474 
475 	spin_lock_irqsave(&dwc->lock, flags);
476 	ret = __dwc3_gadget_ep_enable(dep, desc);
477 	spin_unlock_irqrestore(&dwc->lock, flags);
478 
479 	return ret;
480 }
481 
482 static int dwc3_gadget_ep_disable(struct usb_ep *ep)
483 {
484 	struct dwc3_ep			*dep;
485 	struct dwc3			*dwc;
486 	unsigned long			flags;
487 	int				ret;
488 
489 	if (!ep) {
490 		pr_debug("dwc3: invalid parameters\n");
491 		return -EINVAL;
492 	}
493 
494 	dep = to_dwc3_ep(ep);
495 	dwc = dep->dwc;
496 
497 	if (!(dep->flags & DWC3_EP_ENABLED)) {
498 		dev_WARN_ONCE(dwc->dev, true, "%s is already disabled\n",
499 				dep->name);
500 		return 0;
501 	}
502 
503 	snprintf(dep->name, sizeof(dep->name), "ep%d%s",
504 			dep->number >> 1,
505 			(dep->number & 1) ? "in" : "out");
506 
507 	spin_lock_irqsave(&dwc->lock, flags);
508 	ret = __dwc3_gadget_ep_disable(dep);
509 	spin_unlock_irqrestore(&dwc->lock, flags);
510 
511 	return ret;
512 }
513 
514 static struct usb_request *dwc3_gadget_ep_alloc_request(struct usb_ep *ep,
515 	gfp_t gfp_flags)
516 {
517 	struct dwc3_request		*req;
518 	struct dwc3_ep			*dep = to_dwc3_ep(ep);
519 	struct dwc3			*dwc = dep->dwc;
520 
521 	req = kzalloc(sizeof(*req), gfp_flags);
522 	if (!req) {
523 		dev_err(dwc->dev, "not enough memory\n");
524 		return NULL;
525 	}
526 
527 	req->epnum	= dep->number;
528 	req->dep	= dep;
529 	req->request.dma = DMA_ADDR_INVALID;
530 
531 	return &req->request;
532 }
533 
534 static void dwc3_gadget_ep_free_request(struct usb_ep *ep,
535 		struct usb_request *request)
536 {
537 	struct dwc3_request		*req = to_dwc3_request(request);
538 
539 	kfree(req);
540 }
541 
542 /*
543  * dwc3_prepare_trbs - setup TRBs from requests
544  * @dep: endpoint for which requests are being prepared
545  * @starting: true if the endpoint is idle and no requests are queued.
546  *
547  * The functions goes through the requests list and setups TRBs for the
548  * transfers. The functions returns once there are not more TRBs available or
549  * it run out of requests.
550  */
551 static struct dwc3_request *dwc3_prepare_trbs(struct dwc3_ep *dep,
552 		bool starting)
553 {
554 	struct dwc3_request	*req, *n, *ret = NULL;
555 	struct dwc3_trb_hw	*trb_hw;
556 	struct dwc3_trb		trb;
557 	u32			trbs_left;
558 
559 	BUILD_BUG_ON_NOT_POWER_OF_2(DWC3_TRB_NUM);
560 
561 	/* the first request must not be queued */
562 	trbs_left = (dep->busy_slot - dep->free_slot) & DWC3_TRB_MASK;
563 	/*
564 	 * if busy & slot are equal than it is either full or empty. If we are
565 	 * starting to proceed requests then we are empty. Otherwise we ar
566 	 * full and don't do anything
567 	 */
568 	if (!trbs_left) {
569 		if (!starting)
570 			return NULL;
571 		trbs_left = DWC3_TRB_NUM;
572 		/*
573 		 * In case we start from scratch, we queue the ISOC requests
574 		 * starting from slot 1. This is done because we use ring
575 		 * buffer and have no LST bit to stop us. Instead, we place
576 		 * IOC bit TRB_NUM/4. We try to avoid to having an interrupt
577 		 * after the first request so we start at slot 1 and have
578 		 * 7 requests proceed before we hit the first IOC.
579 		 * Other transfer types don't use the ring buffer and are
580 		 * processed from the first TRB until the last one. Since we
581 		 * don't wrap around we have to start at the beginning.
582 		 */
583 		if (usb_endpoint_xfer_isoc(dep->desc)) {
584 			dep->busy_slot = 1;
585 			dep->free_slot = 1;
586 		} else {
587 			dep->busy_slot = 0;
588 			dep->free_slot = 0;
589 		}
590 	}
591 
592 	/* The last TRB is a link TRB, not used for xfer */
593 	if ((trbs_left <= 1) && usb_endpoint_xfer_isoc(dep->desc))
594 		return NULL;
595 
596 	list_for_each_entry_safe(req, n, &dep->request_list, list) {
597 		unsigned int last_one = 0;
598 		unsigned int cur_slot;
599 
600 		trb_hw = &dep->trb_pool[dep->free_slot & DWC3_TRB_MASK];
601 		cur_slot = dep->free_slot;
602 		dep->free_slot++;
603 
604 		/* Skip the LINK-TRB on ISOC */
605 		if (((cur_slot & DWC3_TRB_MASK) == DWC3_TRB_NUM - 1) &&
606 				usb_endpoint_xfer_isoc(dep->desc))
607 			continue;
608 
609 		dwc3_gadget_move_request_queued(req);
610 		memset(&trb, 0, sizeof(trb));
611 		trbs_left--;
612 
613 		/* Is our TRB pool empty? */
614 		if (!trbs_left)
615 			last_one = 1;
616 		/* Is this the last request? */
617 		if (list_empty(&dep->request_list))
618 			last_one = 1;
619 
620 		/*
621 		 * FIXME we shouldn't need to set LST bit always but we are
622 		 * facing some weird problem with the Hardware where it doesn't
623 		 * complete even though it has been previously started.
624 		 *
625 		 * While we're debugging the problem, as a workaround to
626 		 * multiple TRBs handling, use only one TRB at a time.
627 		 */
628 		last_one = 1;
629 
630 		req->trb = trb_hw;
631 		if (!ret)
632 			ret = req;
633 
634 		trb.bplh = req->request.dma;
635 
636 		if (usb_endpoint_xfer_isoc(dep->desc)) {
637 			trb.isp_imi = true;
638 			trb.csp = true;
639 		} else {
640 			trb.lst = last_one;
641 		}
642 
643 		if (usb_endpoint_xfer_bulk(dep->desc) && dep->stream_capable)
644 			trb.sid_sofn = req->request.stream_id;
645 
646 		switch (usb_endpoint_type(dep->desc)) {
647 		case USB_ENDPOINT_XFER_CONTROL:
648 			trb.trbctl = DWC3_TRBCTL_CONTROL_SETUP;
649 			break;
650 
651 		case USB_ENDPOINT_XFER_ISOC:
652 			trb.trbctl = DWC3_TRBCTL_ISOCHRONOUS_FIRST;
653 
654 			/* IOC every DWC3_TRB_NUM / 4 so we can refill */
655 			if (!(cur_slot % (DWC3_TRB_NUM / 4)))
656 				trb.ioc = last_one;
657 			break;
658 
659 		case USB_ENDPOINT_XFER_BULK:
660 		case USB_ENDPOINT_XFER_INT:
661 			trb.trbctl = DWC3_TRBCTL_NORMAL;
662 			break;
663 		default:
664 			/*
665 			 * This is only possible with faulty memory because we
666 			 * checked it already :)
667 			 */
668 			BUG();
669 		}
670 
671 		trb.length	= req->request.length;
672 		trb.hwo = true;
673 
674 		dwc3_trb_to_hw(&trb, trb_hw);
675 		req->trb_dma = dwc3_trb_dma_offset(dep, trb_hw);
676 
677 		if (last_one)
678 			break;
679 	}
680 
681 	return ret;
682 }
683 
684 static int __dwc3_gadget_kick_transfer(struct dwc3_ep *dep, u16 cmd_param,
685 		int start_new)
686 {
687 	struct dwc3_gadget_ep_cmd_params params;
688 	struct dwc3_request		*req;
689 	struct dwc3			*dwc = dep->dwc;
690 	int				ret;
691 	u32				cmd;
692 
693 	if (start_new && (dep->flags & DWC3_EP_BUSY)) {
694 		dev_vdbg(dwc->dev, "%s: endpoint busy\n", dep->name);
695 		return -EBUSY;
696 	}
697 	dep->flags &= ~DWC3_EP_PENDING_REQUEST;
698 
699 	/*
700 	 * If we are getting here after a short-out-packet we don't enqueue any
701 	 * new requests as we try to set the IOC bit only on the last request.
702 	 */
703 	if (start_new) {
704 		if (list_empty(&dep->req_queued))
705 			dwc3_prepare_trbs(dep, start_new);
706 
707 		/* req points to the first request which will be sent */
708 		req = next_request(&dep->req_queued);
709 	} else {
710 		/*
711 		 * req points to the first request where HWO changed
712 		 * from 0 to 1
713 		 */
714 		req = dwc3_prepare_trbs(dep, start_new);
715 	}
716 	if (!req) {
717 		dep->flags |= DWC3_EP_PENDING_REQUEST;
718 		return 0;
719 	}
720 
721 	memset(&params, 0, sizeof(params));
722 	params.param0 = upper_32_bits(req->trb_dma);
723 	params.param1 = lower_32_bits(req->trb_dma);
724 
725 	if (start_new)
726 		cmd = DWC3_DEPCMD_STARTTRANSFER;
727 	else
728 		cmd = DWC3_DEPCMD_UPDATETRANSFER;
729 
730 	cmd |= DWC3_DEPCMD_PARAM(cmd_param);
731 	ret = dwc3_send_gadget_ep_cmd(dwc, dep->number, cmd, &params);
732 	if (ret < 0) {
733 		dev_dbg(dwc->dev, "failed to send STARTTRANSFER command\n");
734 
735 		/*
736 		 * FIXME we need to iterate over the list of requests
737 		 * here and stop, unmap, free and del each of the linked
738 		 * requests instead of we do now.
739 		 */
740 		dwc3_unmap_buffer_from_dma(req);
741 		list_del(&req->list);
742 		return ret;
743 	}
744 
745 	dep->flags |= DWC3_EP_BUSY;
746 	dep->res_trans_idx = dwc3_gadget_ep_get_transfer_index(dwc,
747 			dep->number);
748 	if (!dep->res_trans_idx)
749 		printk_once(KERN_ERR "%s() res_trans_idx is invalid\n", __func__);
750 	return 0;
751 }
752 
753 static int __dwc3_gadget_ep_queue(struct dwc3_ep *dep, struct dwc3_request *req)
754 {
755 	req->request.actual	= 0;
756 	req->request.status	= -EINPROGRESS;
757 	req->direction		= dep->direction;
758 	req->epnum		= dep->number;
759 
760 	/*
761 	 * We only add to our list of requests now and
762 	 * start consuming the list once we get XferNotReady
763 	 * IRQ.
764 	 *
765 	 * That way, we avoid doing anything that we don't need
766 	 * to do now and defer it until the point we receive a
767 	 * particular token from the Host side.
768 	 *
769 	 * This will also avoid Host cancelling URBs due to too
770 	 * many NACKs.
771 	 */
772 	dwc3_map_buffer_to_dma(req);
773 	list_add_tail(&req->list, &dep->request_list);
774 
775 	/*
776 	 * There is one special case: XferNotReady with
777 	 * empty list of requests. We need to kick the
778 	 * transfer here in that situation, otherwise
779 	 * we will be NAKing forever.
780 	 *
781 	 * If we get XferNotReady before gadget driver
782 	 * has a chance to queue a request, we will ACK
783 	 * the IRQ but won't be able to receive the data
784 	 * until the next request is queued. The following
785 	 * code is handling exactly that.
786 	 */
787 	if (dep->flags & DWC3_EP_PENDING_REQUEST) {
788 		int ret;
789 		int start_trans;
790 
791 		start_trans = 1;
792 		if (usb_endpoint_xfer_isoc(dep->endpoint.desc) &&
793 				dep->flags & DWC3_EP_BUSY)
794 			start_trans = 0;
795 
796 		ret =  __dwc3_gadget_kick_transfer(dep, 0, start_trans);
797 		if (ret && ret != -EBUSY) {
798 			struct dwc3	*dwc = dep->dwc;
799 
800 			dev_dbg(dwc->dev, "%s: failed to kick transfers\n",
801 					dep->name);
802 		}
803 	};
804 
805 	return 0;
806 }
807 
808 static int dwc3_gadget_ep_queue(struct usb_ep *ep, struct usb_request *request,
809 	gfp_t gfp_flags)
810 {
811 	struct dwc3_request		*req = to_dwc3_request(request);
812 	struct dwc3_ep			*dep = to_dwc3_ep(ep);
813 	struct dwc3			*dwc = dep->dwc;
814 
815 	unsigned long			flags;
816 
817 	int				ret;
818 
819 	if (!dep->desc) {
820 		dev_dbg(dwc->dev, "trying to queue request %p to disabled %s\n",
821 				request, ep->name);
822 		return -ESHUTDOWN;
823 	}
824 
825 	dev_vdbg(dwc->dev, "queing request %p to %s length %d\n",
826 			request, ep->name, request->length);
827 
828 	spin_lock_irqsave(&dwc->lock, flags);
829 	ret = __dwc3_gadget_ep_queue(dep, req);
830 	spin_unlock_irqrestore(&dwc->lock, flags);
831 
832 	return ret;
833 }
834 
835 static int dwc3_gadget_ep_dequeue(struct usb_ep *ep,
836 		struct usb_request *request)
837 {
838 	struct dwc3_request		*req = to_dwc3_request(request);
839 	struct dwc3_request		*r = NULL;
840 
841 	struct dwc3_ep			*dep = to_dwc3_ep(ep);
842 	struct dwc3			*dwc = dep->dwc;
843 
844 	unsigned long			flags;
845 	int				ret = 0;
846 
847 	spin_lock_irqsave(&dwc->lock, flags);
848 
849 	list_for_each_entry(r, &dep->request_list, list) {
850 		if (r == req)
851 			break;
852 	}
853 
854 	if (r != req) {
855 		list_for_each_entry(r, &dep->req_queued, list) {
856 			if (r == req)
857 				break;
858 		}
859 		if (r == req) {
860 			/* wait until it is processed */
861 			dwc3_stop_active_transfer(dwc, dep->number);
862 			goto out0;
863 		}
864 		dev_err(dwc->dev, "request %p was not queued to %s\n",
865 				request, ep->name);
866 		ret = -EINVAL;
867 		goto out0;
868 	}
869 
870 	/* giveback the request */
871 	dwc3_gadget_giveback(dep, req, -ECONNRESET);
872 
873 out0:
874 	spin_unlock_irqrestore(&dwc->lock, flags);
875 
876 	return ret;
877 }
878 
879 int __dwc3_gadget_ep_set_halt(struct dwc3_ep *dep, int value)
880 {
881 	struct dwc3_gadget_ep_cmd_params	params;
882 	struct dwc3				*dwc = dep->dwc;
883 	int					ret;
884 
885 	memset(&params, 0x00, sizeof(params));
886 
887 	if (value) {
888 		if (dep->number == 0 || dep->number == 1) {
889 			/*
890 			 * Whenever EP0 is stalled, we will restart
891 			 * the state machine, thus moving back to
892 			 * Setup Phase
893 			 */
894 			dwc->ep0state = EP0_SETUP_PHASE;
895 		}
896 
897 		ret = dwc3_send_gadget_ep_cmd(dwc, dep->number,
898 			DWC3_DEPCMD_SETSTALL, &params);
899 		if (ret)
900 			dev_err(dwc->dev, "failed to %s STALL on %s\n",
901 					value ? "set" : "clear",
902 					dep->name);
903 		else
904 			dep->flags |= DWC3_EP_STALL;
905 	} else {
906 		if (dep->flags & DWC3_EP_WEDGE)
907 			return 0;
908 
909 		ret = dwc3_send_gadget_ep_cmd(dwc, dep->number,
910 			DWC3_DEPCMD_CLEARSTALL, &params);
911 		if (ret)
912 			dev_err(dwc->dev, "failed to %s STALL on %s\n",
913 					value ? "set" : "clear",
914 					dep->name);
915 		else
916 			dep->flags &= ~DWC3_EP_STALL;
917 	}
918 
919 	return ret;
920 }
921 
922 static int dwc3_gadget_ep_set_halt(struct usb_ep *ep, int value)
923 {
924 	struct dwc3_ep			*dep = to_dwc3_ep(ep);
925 	struct dwc3			*dwc = dep->dwc;
926 
927 	unsigned long			flags;
928 
929 	int				ret;
930 
931 	spin_lock_irqsave(&dwc->lock, flags);
932 
933 	if (usb_endpoint_xfer_isoc(dep->desc)) {
934 		dev_err(dwc->dev, "%s is of Isochronous type\n", dep->name);
935 		ret = -EINVAL;
936 		goto out;
937 	}
938 
939 	ret = __dwc3_gadget_ep_set_halt(dep, value);
940 out:
941 	spin_unlock_irqrestore(&dwc->lock, flags);
942 
943 	return ret;
944 }
945 
946 static int dwc3_gadget_ep_set_wedge(struct usb_ep *ep)
947 {
948 	struct dwc3_ep			*dep = to_dwc3_ep(ep);
949 
950 	dep->flags |= DWC3_EP_WEDGE;
951 
952 	return dwc3_gadget_ep_set_halt(ep, 1);
953 }
954 
955 /* -------------------------------------------------------------------------- */
956 
957 static struct usb_endpoint_descriptor dwc3_gadget_ep0_desc = {
958 	.bLength	= USB_DT_ENDPOINT_SIZE,
959 	.bDescriptorType = USB_DT_ENDPOINT,
960 	.bmAttributes	= USB_ENDPOINT_XFER_CONTROL,
961 };
962 
963 static const struct usb_ep_ops dwc3_gadget_ep0_ops = {
964 	.enable		= dwc3_gadget_ep0_enable,
965 	.disable	= dwc3_gadget_ep0_disable,
966 	.alloc_request	= dwc3_gadget_ep_alloc_request,
967 	.free_request	= dwc3_gadget_ep_free_request,
968 	.queue		= dwc3_gadget_ep0_queue,
969 	.dequeue	= dwc3_gadget_ep_dequeue,
970 	.set_halt	= dwc3_gadget_ep_set_halt,
971 	.set_wedge	= dwc3_gadget_ep_set_wedge,
972 };
973 
974 static const struct usb_ep_ops dwc3_gadget_ep_ops = {
975 	.enable		= dwc3_gadget_ep_enable,
976 	.disable	= dwc3_gadget_ep_disable,
977 	.alloc_request	= dwc3_gadget_ep_alloc_request,
978 	.free_request	= dwc3_gadget_ep_free_request,
979 	.queue		= dwc3_gadget_ep_queue,
980 	.dequeue	= dwc3_gadget_ep_dequeue,
981 	.set_halt	= dwc3_gadget_ep_set_halt,
982 	.set_wedge	= dwc3_gadget_ep_set_wedge,
983 };
984 
985 /* -------------------------------------------------------------------------- */
986 
987 static int dwc3_gadget_get_frame(struct usb_gadget *g)
988 {
989 	struct dwc3		*dwc = gadget_to_dwc(g);
990 	u32			reg;
991 
992 	reg = dwc3_readl(dwc->regs, DWC3_DSTS);
993 	return DWC3_DSTS_SOFFN(reg);
994 }
995 
996 static int dwc3_gadget_wakeup(struct usb_gadget *g)
997 {
998 	struct dwc3		*dwc = gadget_to_dwc(g);
999 
1000 	unsigned long		timeout;
1001 	unsigned long		flags;
1002 
1003 	u32			reg;
1004 
1005 	int			ret = 0;
1006 
1007 	u8			link_state;
1008 	u8			speed;
1009 
1010 	spin_lock_irqsave(&dwc->lock, flags);
1011 
1012 	/*
1013 	 * According to the Databook Remote wakeup request should
1014 	 * be issued only when the device is in early suspend state.
1015 	 *
1016 	 * We can check that via USB Link State bits in DSTS register.
1017 	 */
1018 	reg = dwc3_readl(dwc->regs, DWC3_DSTS);
1019 
1020 	speed = reg & DWC3_DSTS_CONNECTSPD;
1021 	if (speed == DWC3_DSTS_SUPERSPEED) {
1022 		dev_dbg(dwc->dev, "no wakeup on SuperSpeed\n");
1023 		ret = -EINVAL;
1024 		goto out;
1025 	}
1026 
1027 	link_state = DWC3_DSTS_USBLNKST(reg);
1028 
1029 	switch (link_state) {
1030 	case DWC3_LINK_STATE_RX_DET:	/* in HS, means Early Suspend */
1031 	case DWC3_LINK_STATE_U3:	/* in HS, means SUSPEND */
1032 		break;
1033 	default:
1034 		dev_dbg(dwc->dev, "can't wakeup from link state %d\n",
1035 				link_state);
1036 		ret = -EINVAL;
1037 		goto out;
1038 	}
1039 
1040 	reg = dwc3_readl(dwc->regs, DWC3_DCTL);
1041 
1042 	/*
1043 	 * Switch link state to Recovery. In HS/FS/LS this means
1044 	 * RemoteWakeup Request
1045 	 */
1046 	reg |= DWC3_DCTL_ULSTCHNG_RECOVERY;
1047 	dwc3_writel(dwc->regs, DWC3_DCTL, reg);
1048 
1049 	/* wait for at least 2000us */
1050 	usleep_range(2000, 2500);
1051 
1052 	/* write zeroes to Link Change Request */
1053 	reg &= ~DWC3_DCTL_ULSTCHNGREQ_MASK;
1054 	dwc3_writel(dwc->regs, DWC3_DCTL, reg);
1055 
1056 	/* pool until Link State change to ON */
1057 	timeout = jiffies + msecs_to_jiffies(100);
1058 
1059 	while (!(time_after(jiffies, timeout))) {
1060 		reg = dwc3_readl(dwc->regs, DWC3_DSTS);
1061 
1062 		/* in HS, means ON */
1063 		if (DWC3_DSTS_USBLNKST(reg) == DWC3_LINK_STATE_U0)
1064 			break;
1065 	}
1066 
1067 	if (DWC3_DSTS_USBLNKST(reg) != DWC3_LINK_STATE_U0) {
1068 		dev_err(dwc->dev, "failed to send remote wakeup\n");
1069 		ret = -EINVAL;
1070 	}
1071 
1072 out:
1073 	spin_unlock_irqrestore(&dwc->lock, flags);
1074 
1075 	return ret;
1076 }
1077 
1078 static int dwc3_gadget_set_selfpowered(struct usb_gadget *g,
1079 		int is_selfpowered)
1080 {
1081 	struct dwc3		*dwc = gadget_to_dwc(g);
1082 
1083 	dwc->is_selfpowered = !!is_selfpowered;
1084 
1085 	return 0;
1086 }
1087 
1088 static void dwc3_gadget_run_stop(struct dwc3 *dwc, int is_on)
1089 {
1090 	u32			reg;
1091 	u32			timeout = 500;
1092 
1093 	reg = dwc3_readl(dwc->regs, DWC3_DCTL);
1094 	if (is_on)
1095 		reg |= DWC3_DCTL_RUN_STOP;
1096 	else
1097 		reg &= ~DWC3_DCTL_RUN_STOP;
1098 
1099 	dwc3_writel(dwc->regs, DWC3_DCTL, reg);
1100 
1101 	do {
1102 		reg = dwc3_readl(dwc->regs, DWC3_DSTS);
1103 		if (is_on) {
1104 			if (!(reg & DWC3_DSTS_DEVCTRLHLT))
1105 				break;
1106 		} else {
1107 			if (reg & DWC3_DSTS_DEVCTRLHLT)
1108 				break;
1109 		}
1110 		timeout--;
1111 		if (!timeout)
1112 			break;
1113 		udelay(1);
1114 	} while (1);
1115 
1116 	dev_vdbg(dwc->dev, "gadget %s data soft-%s\n",
1117 			dwc->gadget_driver
1118 			? dwc->gadget_driver->function : "no-function",
1119 			is_on ? "connect" : "disconnect");
1120 }
1121 
1122 static int dwc3_gadget_pullup(struct usb_gadget *g, int is_on)
1123 {
1124 	struct dwc3		*dwc = gadget_to_dwc(g);
1125 	unsigned long		flags;
1126 
1127 	is_on = !!is_on;
1128 
1129 	spin_lock_irqsave(&dwc->lock, flags);
1130 	dwc3_gadget_run_stop(dwc, is_on);
1131 	spin_unlock_irqrestore(&dwc->lock, flags);
1132 
1133 	return 0;
1134 }
1135 
1136 static int dwc3_gadget_start(struct usb_gadget *g,
1137 		struct usb_gadget_driver *driver)
1138 {
1139 	struct dwc3		*dwc = gadget_to_dwc(g);
1140 	struct dwc3_ep		*dep;
1141 	unsigned long		flags;
1142 	int			ret = 0;
1143 	u32			reg;
1144 
1145 	spin_lock_irqsave(&dwc->lock, flags);
1146 
1147 	if (dwc->gadget_driver) {
1148 		dev_err(dwc->dev, "%s is already bound to %s\n",
1149 				dwc->gadget.name,
1150 				dwc->gadget_driver->driver.name);
1151 		ret = -EBUSY;
1152 		goto err0;
1153 	}
1154 
1155 	dwc->gadget_driver	= driver;
1156 	dwc->gadget.dev.driver	= &driver->driver;
1157 
1158 	reg = dwc3_readl(dwc->regs, DWC3_GCTL);
1159 
1160 	reg &= ~DWC3_GCTL_SCALEDOWN(3);
1161 	reg &= ~DWC3_GCTL_PRTCAPDIR(DWC3_GCTL_PRTCAP_OTG);
1162 	reg &= ~DWC3_GCTL_DISSCRAMBLE;
1163 	reg |= DWC3_GCTL_PRTCAPDIR(DWC3_GCTL_PRTCAP_DEVICE);
1164 
1165 	switch (DWC3_GHWPARAMS1_EN_PWROPT(dwc->hwparams.hwparams0)) {
1166 	case DWC3_GHWPARAMS1_EN_PWROPT_CLK:
1167 		reg &= ~DWC3_GCTL_DSBLCLKGTNG;
1168 		break;
1169 	default:
1170 		dev_dbg(dwc->dev, "No power optimization available\n");
1171 	}
1172 
1173 	/*
1174 	 * WORKAROUND: DWC3 revisions <1.90a have a bug
1175 	 * when The device fails to connect at SuperSpeed
1176 	 * and falls back to high-speed mode which causes
1177 	 * the device to enter in a Connect/Disconnect loop
1178 	 */
1179 	if (dwc->revision < DWC3_REVISION_190A)
1180 		reg |= DWC3_GCTL_U2RSTECN;
1181 
1182 	dwc3_writel(dwc->regs, DWC3_GCTL, reg);
1183 
1184 	reg = dwc3_readl(dwc->regs, DWC3_DCFG);
1185 	reg &= ~(DWC3_DCFG_SPEED_MASK);
1186 	reg |= DWC3_DCFG_SUPERSPEED;
1187 	dwc3_writel(dwc->regs, DWC3_DCFG, reg);
1188 
1189 	dwc->start_config_issued = false;
1190 
1191 	/* Start with SuperSpeed Default */
1192 	dwc3_gadget_ep0_desc.wMaxPacketSize = cpu_to_le16(512);
1193 
1194 	dep = dwc->eps[0];
1195 	ret = __dwc3_gadget_ep_enable(dep, &dwc3_gadget_ep0_desc);
1196 	if (ret) {
1197 		dev_err(dwc->dev, "failed to enable %s\n", dep->name);
1198 		goto err0;
1199 	}
1200 
1201 	dep = dwc->eps[1];
1202 	ret = __dwc3_gadget_ep_enable(dep, &dwc3_gadget_ep0_desc);
1203 	if (ret) {
1204 		dev_err(dwc->dev, "failed to enable %s\n", dep->name);
1205 		goto err1;
1206 	}
1207 
1208 	/* begin to receive SETUP packets */
1209 	dwc->ep0state = EP0_SETUP_PHASE;
1210 	dwc3_ep0_out_start(dwc);
1211 
1212 	spin_unlock_irqrestore(&dwc->lock, flags);
1213 
1214 	return 0;
1215 
1216 err1:
1217 	__dwc3_gadget_ep_disable(dwc->eps[0]);
1218 
1219 err0:
1220 	spin_unlock_irqrestore(&dwc->lock, flags);
1221 
1222 	return ret;
1223 }
1224 
1225 static int dwc3_gadget_stop(struct usb_gadget *g,
1226 		struct usb_gadget_driver *driver)
1227 {
1228 	struct dwc3		*dwc = gadget_to_dwc(g);
1229 	unsigned long		flags;
1230 
1231 	spin_lock_irqsave(&dwc->lock, flags);
1232 
1233 	__dwc3_gadget_ep_disable(dwc->eps[0]);
1234 	__dwc3_gadget_ep_disable(dwc->eps[1]);
1235 
1236 	dwc->gadget_driver	= NULL;
1237 	dwc->gadget.dev.driver	= NULL;
1238 
1239 	spin_unlock_irqrestore(&dwc->lock, flags);
1240 
1241 	return 0;
1242 }
1243 static const struct usb_gadget_ops dwc3_gadget_ops = {
1244 	.get_frame		= dwc3_gadget_get_frame,
1245 	.wakeup			= dwc3_gadget_wakeup,
1246 	.set_selfpowered	= dwc3_gadget_set_selfpowered,
1247 	.pullup			= dwc3_gadget_pullup,
1248 	.udc_start		= dwc3_gadget_start,
1249 	.udc_stop		= dwc3_gadget_stop,
1250 };
1251 
1252 /* -------------------------------------------------------------------------- */
1253 
1254 static int __devinit dwc3_gadget_init_endpoints(struct dwc3 *dwc)
1255 {
1256 	struct dwc3_ep			*dep;
1257 	u8				epnum;
1258 
1259 	INIT_LIST_HEAD(&dwc->gadget.ep_list);
1260 
1261 	for (epnum = 0; epnum < DWC3_ENDPOINTS_NUM; epnum++) {
1262 		dep = kzalloc(sizeof(*dep), GFP_KERNEL);
1263 		if (!dep) {
1264 			dev_err(dwc->dev, "can't allocate endpoint %d\n",
1265 					epnum);
1266 			return -ENOMEM;
1267 		}
1268 
1269 		dep->dwc = dwc;
1270 		dep->number = epnum;
1271 		dwc->eps[epnum] = dep;
1272 
1273 		snprintf(dep->name, sizeof(dep->name), "ep%d%s", epnum >> 1,
1274 				(epnum & 1) ? "in" : "out");
1275 		dep->endpoint.name = dep->name;
1276 		dep->direction = (epnum & 1);
1277 
1278 		if (epnum == 0 || epnum == 1) {
1279 			dep->endpoint.maxpacket = 512;
1280 			dep->endpoint.ops = &dwc3_gadget_ep0_ops;
1281 			if (!epnum)
1282 				dwc->gadget.ep0 = &dep->endpoint;
1283 		} else {
1284 			int		ret;
1285 
1286 			dep->endpoint.maxpacket = 1024;
1287 			dep->endpoint.max_streams = 15;
1288 			dep->endpoint.ops = &dwc3_gadget_ep_ops;
1289 			list_add_tail(&dep->endpoint.ep_list,
1290 					&dwc->gadget.ep_list);
1291 
1292 			ret = dwc3_alloc_trb_pool(dep);
1293 			if (ret) {
1294 				dev_err(dwc->dev, "%s: failed to allocate TRB pool\n", dep->name);
1295 				return ret;
1296 			}
1297 		}
1298 		INIT_LIST_HEAD(&dep->request_list);
1299 		INIT_LIST_HEAD(&dep->req_queued);
1300 	}
1301 
1302 	return 0;
1303 }
1304 
1305 static void dwc3_gadget_free_endpoints(struct dwc3 *dwc)
1306 {
1307 	struct dwc3_ep			*dep;
1308 	u8				epnum;
1309 
1310 	for (epnum = 0; epnum < DWC3_ENDPOINTS_NUM; epnum++) {
1311 		dep = dwc->eps[epnum];
1312 		dwc3_free_trb_pool(dep);
1313 
1314 		if (epnum != 0 && epnum != 1)
1315 			list_del(&dep->endpoint.ep_list);
1316 
1317 		kfree(dep);
1318 	}
1319 }
1320 
1321 static void dwc3_gadget_release(struct device *dev)
1322 {
1323 	dev_dbg(dev, "%s\n", __func__);
1324 }
1325 
1326 /* -------------------------------------------------------------------------- */
1327 static int dwc3_cleanup_done_reqs(struct dwc3 *dwc, struct dwc3_ep *dep,
1328 		const struct dwc3_event_depevt *event, int status)
1329 {
1330 	struct dwc3_request	*req;
1331 	struct dwc3_trb         trb;
1332 	unsigned int		count;
1333 	unsigned int		s_pkt = 0;
1334 
1335 	do {
1336 		req = next_request(&dep->req_queued);
1337 		if (!req)
1338 			break;
1339 
1340 		dwc3_trb_to_nat(req->trb, &trb);
1341 
1342 		if (trb.hwo && status != -ESHUTDOWN)
1343 			/*
1344 			 * We continue despite the error. There is not much we
1345 			 * can do. If we don't clean in up we loop for ever. If
1346 			 * we skip the TRB than it gets overwritten reused after
1347 			 * a while since we use them in a ring buffer. a BUG()
1348 			 * would help. Lets hope that if this occures, someone
1349 			 * fixes the root cause instead of looking away :)
1350 			 */
1351 			dev_err(dwc->dev, "%s's TRB (%p) still owned by HW\n",
1352 					dep->name, req->trb);
1353 		count = trb.length;
1354 
1355 		if (dep->direction) {
1356 			if (count) {
1357 				dev_err(dwc->dev, "incomplete IN transfer %s\n",
1358 						dep->name);
1359 				status = -ECONNRESET;
1360 			}
1361 		} else {
1362 			if (count && (event->status & DEPEVT_STATUS_SHORT))
1363 				s_pkt = 1;
1364 		}
1365 
1366 		/*
1367 		 * We assume here we will always receive the entire data block
1368 		 * which we should receive. Meaning, if we program RX to
1369 		 * receive 4K but we receive only 2K, we assume that's all we
1370 		 * should receive and we simply bounce the request back to the
1371 		 * gadget driver for further processing.
1372 		 */
1373 		req->request.actual += req->request.length - count;
1374 		dwc3_gadget_giveback(dep, req, status);
1375 		if (s_pkt)
1376 			break;
1377 		if ((event->status & DEPEVT_STATUS_LST) && trb.lst)
1378 			break;
1379 		if ((event->status & DEPEVT_STATUS_IOC) && trb.ioc)
1380 			break;
1381 	} while (1);
1382 
1383 	if ((event->status & DEPEVT_STATUS_IOC) && trb.ioc)
1384 		return 0;
1385 	return 1;
1386 }
1387 
1388 static void dwc3_endpoint_transfer_complete(struct dwc3 *dwc,
1389 		struct dwc3_ep *dep, const struct dwc3_event_depevt *event,
1390 		int start_new)
1391 {
1392 	unsigned		status = 0;
1393 	int			clean_busy;
1394 
1395 	if (event->status & DEPEVT_STATUS_BUSERR)
1396 		status = -ECONNRESET;
1397 
1398 	clean_busy =  dwc3_cleanup_done_reqs(dwc, dep, event, status);
1399 	if (clean_busy) {
1400 		dep->flags &= ~DWC3_EP_BUSY;
1401 		dep->res_trans_idx = 0;
1402 	}
1403 }
1404 
1405 static void dwc3_gadget_start_isoc(struct dwc3 *dwc,
1406 		struct dwc3_ep *dep, const struct dwc3_event_depevt *event)
1407 {
1408 	u32 uf;
1409 
1410 	if (list_empty(&dep->request_list)) {
1411 		dev_vdbg(dwc->dev, "ISOC ep %s run out for requests.\n",
1412 			dep->name);
1413 		return;
1414 	}
1415 
1416 	if (event->parameters) {
1417 		u32 mask;
1418 
1419 		mask = ~(dep->interval - 1);
1420 		uf = event->parameters & mask;
1421 		/* 4 micro frames in the future */
1422 		uf += dep->interval * 4;
1423 	} else {
1424 		uf = 0;
1425 	}
1426 
1427 	__dwc3_gadget_kick_transfer(dep, uf, 1);
1428 }
1429 
1430 static void dwc3_process_ep_cmd_complete(struct dwc3_ep *dep,
1431 		const struct dwc3_event_depevt *event)
1432 {
1433 	struct dwc3 *dwc = dep->dwc;
1434 	struct dwc3_event_depevt mod_ev = *event;
1435 
1436 	/*
1437 	 * We were asked to remove one requests. It is possible that this
1438 	 * request and a few other were started together and have the same
1439 	 * transfer index. Since we stopped the complete endpoint we don't
1440 	 * know how many requests were already completed (and not yet)
1441 	 * reported and how could be done (later). We purge them all until
1442 	 * the end of the list.
1443 	 */
1444 	mod_ev.status = DEPEVT_STATUS_LST;
1445 	dwc3_cleanup_done_reqs(dwc, dep, &mod_ev, -ESHUTDOWN);
1446 	dep->flags &= ~DWC3_EP_BUSY;
1447 	/* pending requets are ignored and are queued on XferNotReady */
1448 }
1449 
1450 static void dwc3_ep_cmd_compl(struct dwc3_ep *dep,
1451 		const struct dwc3_event_depevt *event)
1452 {
1453 	u32 param = event->parameters;
1454 	u32 cmd_type = (param >> 8) & ((1 << 5) - 1);
1455 
1456 	switch (cmd_type) {
1457 	case DWC3_DEPCMD_ENDTRANSFER:
1458 		dwc3_process_ep_cmd_complete(dep, event);
1459 		break;
1460 	case DWC3_DEPCMD_STARTTRANSFER:
1461 		dep->res_trans_idx = param & 0x7f;
1462 		break;
1463 	default:
1464 		printk(KERN_ERR "%s() unknown /unexpected type: %d\n",
1465 				__func__, cmd_type);
1466 		break;
1467 	};
1468 }
1469 
1470 static void dwc3_endpoint_interrupt(struct dwc3 *dwc,
1471 		const struct dwc3_event_depevt *event)
1472 {
1473 	struct dwc3_ep		*dep;
1474 	u8			epnum = event->endpoint_number;
1475 
1476 	dep = dwc->eps[epnum];
1477 
1478 	dev_vdbg(dwc->dev, "%s: %s\n", dep->name,
1479 			dwc3_ep_event_string(event->endpoint_event));
1480 
1481 	if (epnum == 0 || epnum == 1) {
1482 		dwc3_ep0_interrupt(dwc, event);
1483 		return;
1484 	}
1485 
1486 	switch (event->endpoint_event) {
1487 	case DWC3_DEPEVT_XFERCOMPLETE:
1488 		if (usb_endpoint_xfer_isoc(dep->desc)) {
1489 			dev_dbg(dwc->dev, "%s is an Isochronous endpoint\n",
1490 					dep->name);
1491 			return;
1492 		}
1493 
1494 		dwc3_endpoint_transfer_complete(dwc, dep, event, 1);
1495 		break;
1496 	case DWC3_DEPEVT_XFERINPROGRESS:
1497 		if (!usb_endpoint_xfer_isoc(dep->desc)) {
1498 			dev_dbg(dwc->dev, "%s is not an Isochronous endpoint\n",
1499 					dep->name);
1500 			return;
1501 		}
1502 
1503 		dwc3_endpoint_transfer_complete(dwc, dep, event, 0);
1504 		break;
1505 	case DWC3_DEPEVT_XFERNOTREADY:
1506 		if (usb_endpoint_xfer_isoc(dep->desc)) {
1507 			dwc3_gadget_start_isoc(dwc, dep, event);
1508 		} else {
1509 			int ret;
1510 
1511 			dev_vdbg(dwc->dev, "%s: reason %s\n",
1512 					dep->name, event->status
1513 					? "Transfer Active"
1514 					: "Transfer Not Active");
1515 
1516 			ret = __dwc3_gadget_kick_transfer(dep, 0, 1);
1517 			if (!ret || ret == -EBUSY)
1518 				return;
1519 
1520 			dev_dbg(dwc->dev, "%s: failed to kick transfers\n",
1521 					dep->name);
1522 		}
1523 
1524 		break;
1525 	case DWC3_DEPEVT_STREAMEVT:
1526 		if (!usb_endpoint_xfer_bulk(dep->desc)) {
1527 			dev_err(dwc->dev, "Stream event for non-Bulk %s\n",
1528 					dep->name);
1529 			return;
1530 		}
1531 
1532 		switch (event->status) {
1533 		case DEPEVT_STREAMEVT_FOUND:
1534 			dev_vdbg(dwc->dev, "Stream %d found and started\n",
1535 					event->parameters);
1536 
1537 			break;
1538 		case DEPEVT_STREAMEVT_NOTFOUND:
1539 			/* FALLTHROUGH */
1540 		default:
1541 			dev_dbg(dwc->dev, "Couldn't find suitable stream\n");
1542 		}
1543 		break;
1544 	case DWC3_DEPEVT_RXTXFIFOEVT:
1545 		dev_dbg(dwc->dev, "%s FIFO Overrun\n", dep->name);
1546 		break;
1547 	case DWC3_DEPEVT_EPCMDCMPLT:
1548 		dwc3_ep_cmd_compl(dep, event);
1549 		break;
1550 	}
1551 }
1552 
1553 static void dwc3_disconnect_gadget(struct dwc3 *dwc)
1554 {
1555 	if (dwc->gadget_driver && dwc->gadget_driver->disconnect) {
1556 		spin_unlock(&dwc->lock);
1557 		dwc->gadget_driver->disconnect(&dwc->gadget);
1558 		spin_lock(&dwc->lock);
1559 	}
1560 }
1561 
1562 static void dwc3_stop_active_transfer(struct dwc3 *dwc, u32 epnum)
1563 {
1564 	struct dwc3_ep *dep;
1565 	struct dwc3_gadget_ep_cmd_params params;
1566 	u32 cmd;
1567 	int ret;
1568 
1569 	dep = dwc->eps[epnum];
1570 
1571 	WARN_ON(!dep->res_trans_idx);
1572 	if (dep->res_trans_idx) {
1573 		cmd = DWC3_DEPCMD_ENDTRANSFER;
1574 		cmd |= DWC3_DEPCMD_HIPRI_FORCERM | DWC3_DEPCMD_CMDIOC;
1575 		cmd |= DWC3_DEPCMD_PARAM(dep->res_trans_idx);
1576 		memset(&params, 0, sizeof(params));
1577 		ret = dwc3_send_gadget_ep_cmd(dwc, dep->number, cmd, &params);
1578 		WARN_ON_ONCE(ret);
1579 		dep->res_trans_idx = 0;
1580 	}
1581 }
1582 
1583 static void dwc3_stop_active_transfers(struct dwc3 *dwc)
1584 {
1585 	u32 epnum;
1586 
1587 	for (epnum = 2; epnum < DWC3_ENDPOINTS_NUM; epnum++) {
1588 		struct dwc3_ep *dep;
1589 
1590 		dep = dwc->eps[epnum];
1591 		if (!(dep->flags & DWC3_EP_ENABLED))
1592 			continue;
1593 
1594 		dwc3_remove_requests(dwc, dep);
1595 	}
1596 }
1597 
1598 static void dwc3_clear_stall_all_ep(struct dwc3 *dwc)
1599 {
1600 	u32 epnum;
1601 
1602 	for (epnum = 1; epnum < DWC3_ENDPOINTS_NUM; epnum++) {
1603 		struct dwc3_ep *dep;
1604 		struct dwc3_gadget_ep_cmd_params params;
1605 		int ret;
1606 
1607 		dep = dwc->eps[epnum];
1608 
1609 		if (!(dep->flags & DWC3_EP_STALL))
1610 			continue;
1611 
1612 		dep->flags &= ~DWC3_EP_STALL;
1613 
1614 		memset(&params, 0, sizeof(params));
1615 		ret = dwc3_send_gadget_ep_cmd(dwc, dep->number,
1616 				DWC3_DEPCMD_CLEARSTALL, &params);
1617 		WARN_ON_ONCE(ret);
1618 	}
1619 }
1620 
1621 static void dwc3_gadget_disconnect_interrupt(struct dwc3 *dwc)
1622 {
1623 	dev_vdbg(dwc->dev, "%s\n", __func__);
1624 #if 0
1625 	XXX
1626 	U1/U2 is powersave optimization. Skip it for now. Anyway we need to
1627 	enable it before we can disable it.
1628 
1629 	reg = dwc3_readl(dwc->regs, DWC3_DCTL);
1630 	reg &= ~DWC3_DCTL_INITU1ENA;
1631 	dwc3_writel(dwc->regs, DWC3_DCTL, reg);
1632 
1633 	reg &= ~DWC3_DCTL_INITU2ENA;
1634 	dwc3_writel(dwc->regs, DWC3_DCTL, reg);
1635 #endif
1636 
1637 	dwc3_stop_active_transfers(dwc);
1638 	dwc3_disconnect_gadget(dwc);
1639 	dwc->start_config_issued = false;
1640 
1641 	dwc->gadget.speed = USB_SPEED_UNKNOWN;
1642 }
1643 
1644 static void dwc3_gadget_usb3_phy_power(struct dwc3 *dwc, int on)
1645 {
1646 	u32			reg;
1647 
1648 	reg = dwc3_readl(dwc->regs, DWC3_GUSB3PIPECTL(0));
1649 
1650 	if (on)
1651 		reg &= ~DWC3_GUSB3PIPECTL_SUSPHY;
1652 	else
1653 		reg |= DWC3_GUSB3PIPECTL_SUSPHY;
1654 
1655 	dwc3_writel(dwc->regs, DWC3_GUSB3PIPECTL(0), reg);
1656 }
1657 
1658 static void dwc3_gadget_usb2_phy_power(struct dwc3 *dwc, int on)
1659 {
1660 	u32			reg;
1661 
1662 	reg = dwc3_readl(dwc->regs, DWC3_GUSB2PHYCFG(0));
1663 
1664 	if (on)
1665 		reg &= ~DWC3_GUSB2PHYCFG_SUSPHY;
1666 	else
1667 		reg |= DWC3_GUSB2PHYCFG_SUSPHY;
1668 
1669 	dwc3_writel(dwc->regs, DWC3_GUSB2PHYCFG(0), reg);
1670 }
1671 
1672 static void dwc3_gadget_reset_interrupt(struct dwc3 *dwc)
1673 {
1674 	u32			reg;
1675 
1676 	dev_vdbg(dwc->dev, "%s\n", __func__);
1677 
1678 	/* Enable PHYs */
1679 	dwc3_gadget_usb2_phy_power(dwc, true);
1680 	dwc3_gadget_usb3_phy_power(dwc, true);
1681 
1682 	if (dwc->gadget.speed != USB_SPEED_UNKNOWN)
1683 		dwc3_disconnect_gadget(dwc);
1684 
1685 	reg = dwc3_readl(dwc->regs, DWC3_DCTL);
1686 	reg &= ~DWC3_DCTL_TSTCTRL_MASK;
1687 	dwc3_writel(dwc->regs, DWC3_DCTL, reg);
1688 
1689 	dwc3_stop_active_transfers(dwc);
1690 	dwc3_clear_stall_all_ep(dwc);
1691 	dwc->start_config_issued = false;
1692 
1693 	/* Reset device address to zero */
1694 	reg = dwc3_readl(dwc->regs, DWC3_DCFG);
1695 	reg &= ~(DWC3_DCFG_DEVADDR_MASK);
1696 	dwc3_writel(dwc->regs, DWC3_DCFG, reg);
1697 }
1698 
1699 static void dwc3_update_ram_clk_sel(struct dwc3 *dwc, u32 speed)
1700 {
1701 	u32 reg;
1702 	u32 usb30_clock = DWC3_GCTL_CLK_BUS;
1703 
1704 	/*
1705 	 * We change the clock only at SS but I dunno why I would want to do
1706 	 * this. Maybe it becomes part of the power saving plan.
1707 	 */
1708 
1709 	if (speed != DWC3_DSTS_SUPERSPEED)
1710 		return;
1711 
1712 	/*
1713 	 * RAMClkSel is reset to 0 after USB reset, so it must be reprogrammed
1714 	 * each time on Connect Done.
1715 	 */
1716 	if (!usb30_clock)
1717 		return;
1718 
1719 	reg = dwc3_readl(dwc->regs, DWC3_GCTL);
1720 	reg |= DWC3_GCTL_RAMCLKSEL(usb30_clock);
1721 	dwc3_writel(dwc->regs, DWC3_GCTL, reg);
1722 }
1723 
1724 static void dwc3_gadget_disable_phy(struct dwc3 *dwc, u8 speed)
1725 {
1726 	switch (speed) {
1727 	case USB_SPEED_SUPER:
1728 		dwc3_gadget_usb2_phy_power(dwc, false);
1729 		break;
1730 	case USB_SPEED_HIGH:
1731 	case USB_SPEED_FULL:
1732 	case USB_SPEED_LOW:
1733 		dwc3_gadget_usb3_phy_power(dwc, false);
1734 		break;
1735 	}
1736 }
1737 
1738 static void dwc3_gadget_conndone_interrupt(struct dwc3 *dwc)
1739 {
1740 	struct dwc3_gadget_ep_cmd_params params;
1741 	struct dwc3_ep		*dep;
1742 	int			ret;
1743 	u32			reg;
1744 	u8			speed;
1745 
1746 	dev_vdbg(dwc->dev, "%s\n", __func__);
1747 
1748 	memset(&params, 0x00, sizeof(params));
1749 
1750 	reg = dwc3_readl(dwc->regs, DWC3_DSTS);
1751 	speed = reg & DWC3_DSTS_CONNECTSPD;
1752 	dwc->speed = speed;
1753 
1754 	dwc3_update_ram_clk_sel(dwc, speed);
1755 
1756 	switch (speed) {
1757 	case DWC3_DCFG_SUPERSPEED:
1758 		dwc3_gadget_ep0_desc.wMaxPacketSize = cpu_to_le16(512);
1759 		dwc->gadget.ep0->maxpacket = 512;
1760 		dwc->gadget.speed = USB_SPEED_SUPER;
1761 		break;
1762 	case DWC3_DCFG_HIGHSPEED:
1763 		dwc3_gadget_ep0_desc.wMaxPacketSize = cpu_to_le16(64);
1764 		dwc->gadget.ep0->maxpacket = 64;
1765 		dwc->gadget.speed = USB_SPEED_HIGH;
1766 		break;
1767 	case DWC3_DCFG_FULLSPEED2:
1768 	case DWC3_DCFG_FULLSPEED1:
1769 		dwc3_gadget_ep0_desc.wMaxPacketSize = cpu_to_le16(64);
1770 		dwc->gadget.ep0->maxpacket = 64;
1771 		dwc->gadget.speed = USB_SPEED_FULL;
1772 		break;
1773 	case DWC3_DCFG_LOWSPEED:
1774 		dwc3_gadget_ep0_desc.wMaxPacketSize = cpu_to_le16(8);
1775 		dwc->gadget.ep0->maxpacket = 8;
1776 		dwc->gadget.speed = USB_SPEED_LOW;
1777 		break;
1778 	}
1779 
1780 	/* Disable unneded PHY */
1781 	dwc3_gadget_disable_phy(dwc, dwc->gadget.speed);
1782 
1783 	dep = dwc->eps[0];
1784 	ret = __dwc3_gadget_ep_enable(dep, &dwc3_gadget_ep0_desc);
1785 	if (ret) {
1786 		dev_err(dwc->dev, "failed to enable %s\n", dep->name);
1787 		return;
1788 	}
1789 
1790 	dep = dwc->eps[1];
1791 	ret = __dwc3_gadget_ep_enable(dep, &dwc3_gadget_ep0_desc);
1792 	if (ret) {
1793 		dev_err(dwc->dev, "failed to enable %s\n", dep->name);
1794 		return;
1795 	}
1796 
1797 	/*
1798 	 * Configure PHY via GUSB3PIPECTLn if required.
1799 	 *
1800 	 * Update GTXFIFOSIZn
1801 	 *
1802 	 * In both cases reset values should be sufficient.
1803 	 */
1804 }
1805 
1806 static void dwc3_gadget_wakeup_interrupt(struct dwc3 *dwc)
1807 {
1808 	dev_vdbg(dwc->dev, "%s\n", __func__);
1809 
1810 	/*
1811 	 * TODO take core out of low power mode when that's
1812 	 * implemented.
1813 	 */
1814 
1815 	dwc->gadget_driver->resume(&dwc->gadget);
1816 }
1817 
1818 static void dwc3_gadget_linksts_change_interrupt(struct dwc3 *dwc,
1819 		unsigned int evtinfo)
1820 {
1821 	/*  The fith bit says SuperSpeed yes or no. */
1822 	dwc->link_state = evtinfo & DWC3_LINK_STATE_MASK;
1823 
1824 	dev_vdbg(dwc->dev, "%s link %d\n", __func__, dwc->link_state);
1825 }
1826 
1827 static void dwc3_gadget_interrupt(struct dwc3 *dwc,
1828 		const struct dwc3_event_devt *event)
1829 {
1830 	switch (event->type) {
1831 	case DWC3_DEVICE_EVENT_DISCONNECT:
1832 		dwc3_gadget_disconnect_interrupt(dwc);
1833 		break;
1834 	case DWC3_DEVICE_EVENT_RESET:
1835 		dwc3_gadget_reset_interrupt(dwc);
1836 		break;
1837 	case DWC3_DEVICE_EVENT_CONNECT_DONE:
1838 		dwc3_gadget_conndone_interrupt(dwc);
1839 		break;
1840 	case DWC3_DEVICE_EVENT_WAKEUP:
1841 		dwc3_gadget_wakeup_interrupt(dwc);
1842 		break;
1843 	case DWC3_DEVICE_EVENT_LINK_STATUS_CHANGE:
1844 		dwc3_gadget_linksts_change_interrupt(dwc, event->event_info);
1845 		break;
1846 	case DWC3_DEVICE_EVENT_EOPF:
1847 		dev_vdbg(dwc->dev, "End of Periodic Frame\n");
1848 		break;
1849 	case DWC3_DEVICE_EVENT_SOF:
1850 		dev_vdbg(dwc->dev, "Start of Periodic Frame\n");
1851 		break;
1852 	case DWC3_DEVICE_EVENT_ERRATIC_ERROR:
1853 		dev_vdbg(dwc->dev, "Erratic Error\n");
1854 		break;
1855 	case DWC3_DEVICE_EVENT_CMD_CMPL:
1856 		dev_vdbg(dwc->dev, "Command Complete\n");
1857 		break;
1858 	case DWC3_DEVICE_EVENT_OVERFLOW:
1859 		dev_vdbg(dwc->dev, "Overflow\n");
1860 		break;
1861 	default:
1862 		dev_dbg(dwc->dev, "UNKNOWN IRQ %d\n", event->type);
1863 	}
1864 }
1865 
1866 static void dwc3_process_event_entry(struct dwc3 *dwc,
1867 		const union dwc3_event *event)
1868 {
1869 	/* Endpoint IRQ, handle it and return early */
1870 	if (event->type.is_devspec == 0) {
1871 		/* depevt */
1872 		return dwc3_endpoint_interrupt(dwc, &event->depevt);
1873 	}
1874 
1875 	switch (event->type.type) {
1876 	case DWC3_EVENT_TYPE_DEV:
1877 		dwc3_gadget_interrupt(dwc, &event->devt);
1878 		break;
1879 	/* REVISIT what to do with Carkit and I2C events ? */
1880 	default:
1881 		dev_err(dwc->dev, "UNKNOWN IRQ type %d\n", event->raw);
1882 	}
1883 }
1884 
1885 static irqreturn_t dwc3_process_event_buf(struct dwc3 *dwc, u32 buf)
1886 {
1887 	struct dwc3_event_buffer *evt;
1888 	int left;
1889 	u32 count;
1890 
1891 	count = dwc3_readl(dwc->regs, DWC3_GEVNTCOUNT(buf));
1892 	count &= DWC3_GEVNTCOUNT_MASK;
1893 	if (!count)
1894 		return IRQ_NONE;
1895 
1896 	evt = dwc->ev_buffs[buf];
1897 	left = count;
1898 
1899 	while (left > 0) {
1900 		union dwc3_event event;
1901 
1902 		memcpy(&event.raw, (evt->buf + evt->lpos), sizeof(event.raw));
1903 		dwc3_process_event_entry(dwc, &event);
1904 		/*
1905 		 * XXX we wrap around correctly to the next entry as almost all
1906 		 * entries are 4 bytes in size. There is one entry which has 12
1907 		 * bytes which is a regular entry followed by 8 bytes data. ATM
1908 		 * I don't know how things are organized if were get next to the
1909 		 * a boundary so I worry about that once we try to handle that.
1910 		 */
1911 		evt->lpos = (evt->lpos + 4) % DWC3_EVENT_BUFFERS_SIZE;
1912 		left -= 4;
1913 
1914 		dwc3_writel(dwc->regs, DWC3_GEVNTCOUNT(buf), 4);
1915 	}
1916 
1917 	return IRQ_HANDLED;
1918 }
1919 
1920 static irqreturn_t dwc3_interrupt(int irq, void *_dwc)
1921 {
1922 	struct dwc3			*dwc = _dwc;
1923 	int				i;
1924 	irqreturn_t			ret = IRQ_NONE;
1925 
1926 	spin_lock(&dwc->lock);
1927 
1928 	for (i = 0; i < DWC3_EVENT_BUFFERS_NUM; i++) {
1929 		irqreturn_t status;
1930 
1931 		status = dwc3_process_event_buf(dwc, i);
1932 		if (status == IRQ_HANDLED)
1933 			ret = status;
1934 	}
1935 
1936 	spin_unlock(&dwc->lock);
1937 
1938 	return ret;
1939 }
1940 
1941 /**
1942  * dwc3_gadget_init - Initializes gadget related registers
1943  * @dwc: Pointer to out controller context structure
1944  *
1945  * Returns 0 on success otherwise negative errno.
1946  */
1947 int __devinit dwc3_gadget_init(struct dwc3 *dwc)
1948 {
1949 	u32					reg;
1950 	int					ret;
1951 	int					irq;
1952 
1953 	dwc->ctrl_req = dma_alloc_coherent(dwc->dev, sizeof(*dwc->ctrl_req),
1954 			&dwc->ctrl_req_addr, GFP_KERNEL);
1955 	if (!dwc->ctrl_req) {
1956 		dev_err(dwc->dev, "failed to allocate ctrl request\n");
1957 		ret = -ENOMEM;
1958 		goto err0;
1959 	}
1960 
1961 	dwc->ep0_trb = dma_alloc_coherent(dwc->dev, sizeof(*dwc->ep0_trb),
1962 			&dwc->ep0_trb_addr, GFP_KERNEL);
1963 	if (!dwc->ep0_trb) {
1964 		dev_err(dwc->dev, "failed to allocate ep0 trb\n");
1965 		ret = -ENOMEM;
1966 		goto err1;
1967 	}
1968 
1969 	dwc->setup_buf = dma_alloc_coherent(dwc->dev,
1970 			sizeof(*dwc->setup_buf) * 2,
1971 			&dwc->setup_buf_addr, GFP_KERNEL);
1972 	if (!dwc->setup_buf) {
1973 		dev_err(dwc->dev, "failed to allocate setup buffer\n");
1974 		ret = -ENOMEM;
1975 		goto err2;
1976 	}
1977 
1978 	dwc->ep0_bounce = dma_alloc_coherent(dwc->dev,
1979 			512, &dwc->ep0_bounce_addr, GFP_KERNEL);
1980 	if (!dwc->ep0_bounce) {
1981 		dev_err(dwc->dev, "failed to allocate ep0 bounce buffer\n");
1982 		ret = -ENOMEM;
1983 		goto err3;
1984 	}
1985 
1986 	dev_set_name(&dwc->gadget.dev, "gadget");
1987 
1988 	dwc->gadget.ops			= &dwc3_gadget_ops;
1989 	dwc->gadget.is_dualspeed	= true;
1990 	dwc->gadget.speed		= USB_SPEED_UNKNOWN;
1991 	dwc->gadget.dev.parent		= dwc->dev;
1992 
1993 	dma_set_coherent_mask(&dwc->gadget.dev, dwc->dev->coherent_dma_mask);
1994 
1995 	dwc->gadget.dev.dma_parms	= dwc->dev->dma_parms;
1996 	dwc->gadget.dev.dma_mask	= dwc->dev->dma_mask;
1997 	dwc->gadget.dev.release		= dwc3_gadget_release;
1998 	dwc->gadget.name		= "dwc3-gadget";
1999 
2000 	/*
2001 	 * REVISIT: Here we should clear all pending IRQs to be
2002 	 * sure we're starting from a well known location.
2003 	 */
2004 
2005 	ret = dwc3_gadget_init_endpoints(dwc);
2006 	if (ret)
2007 		goto err4;
2008 
2009 	irq = platform_get_irq(to_platform_device(dwc->dev), 0);
2010 
2011 	ret = request_irq(irq, dwc3_interrupt, IRQF_SHARED,
2012 			"dwc3", dwc);
2013 	if (ret) {
2014 		dev_err(dwc->dev, "failed to request irq #%d --> %d\n",
2015 				irq, ret);
2016 		goto err5;
2017 	}
2018 
2019 	/* Enable all but Start and End of Frame IRQs */
2020 	reg = (DWC3_DEVTEN_VNDRDEVTSTRCVEDEN |
2021 			DWC3_DEVTEN_EVNTOVERFLOWEN |
2022 			DWC3_DEVTEN_CMDCMPLTEN |
2023 			DWC3_DEVTEN_ERRTICERREN |
2024 			DWC3_DEVTEN_WKUPEVTEN |
2025 			DWC3_DEVTEN_ULSTCNGEN |
2026 			DWC3_DEVTEN_CONNECTDONEEN |
2027 			DWC3_DEVTEN_USBRSTEN |
2028 			DWC3_DEVTEN_DISCONNEVTEN);
2029 	dwc3_writel(dwc->regs, DWC3_DEVTEN, reg);
2030 
2031 	ret = device_register(&dwc->gadget.dev);
2032 	if (ret) {
2033 		dev_err(dwc->dev, "failed to register gadget device\n");
2034 		put_device(&dwc->gadget.dev);
2035 		goto err6;
2036 	}
2037 
2038 	ret = usb_add_gadget_udc(dwc->dev, &dwc->gadget);
2039 	if (ret) {
2040 		dev_err(dwc->dev, "failed to register udc\n");
2041 		goto err7;
2042 	}
2043 
2044 	return 0;
2045 
2046 err7:
2047 	device_unregister(&dwc->gadget.dev);
2048 
2049 err6:
2050 	dwc3_writel(dwc->regs, DWC3_DEVTEN, 0x00);
2051 	free_irq(irq, dwc);
2052 
2053 err5:
2054 	dwc3_gadget_free_endpoints(dwc);
2055 
2056 err4:
2057 	dma_free_coherent(dwc->dev, 512, dwc->ep0_bounce,
2058 			dwc->ep0_bounce_addr);
2059 
2060 err3:
2061 	dma_free_coherent(dwc->dev, sizeof(*dwc->setup_buf) * 2,
2062 			dwc->setup_buf, dwc->setup_buf_addr);
2063 
2064 err2:
2065 	dma_free_coherent(dwc->dev, sizeof(*dwc->ep0_trb),
2066 			dwc->ep0_trb, dwc->ep0_trb_addr);
2067 
2068 err1:
2069 	dma_free_coherent(dwc->dev, sizeof(*dwc->ctrl_req),
2070 			dwc->ctrl_req, dwc->ctrl_req_addr);
2071 
2072 err0:
2073 	return ret;
2074 }
2075 
2076 void dwc3_gadget_exit(struct dwc3 *dwc)
2077 {
2078 	int			irq;
2079 	int			i;
2080 
2081 	usb_del_gadget_udc(&dwc->gadget);
2082 	irq = platform_get_irq(to_platform_device(dwc->dev), 0);
2083 
2084 	dwc3_writel(dwc->regs, DWC3_DEVTEN, 0x00);
2085 	free_irq(irq, dwc);
2086 
2087 	for (i = 0; i < ARRAY_SIZE(dwc->eps); i++)
2088 		__dwc3_gadget_ep_disable(dwc->eps[i]);
2089 
2090 	dwc3_gadget_free_endpoints(dwc);
2091 
2092 	dma_free_coherent(dwc->dev, 512, dwc->ep0_bounce,
2093 			dwc->ep0_bounce_addr);
2094 
2095 	dma_free_coherent(dwc->dev, sizeof(*dwc->setup_buf) * 2,
2096 			dwc->setup_buf, dwc->setup_buf_addr);
2097 
2098 	dma_free_coherent(dwc->dev, sizeof(*dwc->ep0_trb),
2099 			dwc->ep0_trb, dwc->ep0_trb_addr);
2100 
2101 	dma_free_coherent(dwc->dev, sizeof(*dwc->ctrl_req),
2102 			dwc->ctrl_req, dwc->ctrl_req_addr);
2103 
2104 	device_unregister(&dwc->gadget.dev);
2105 }
2106