Lines Matching refs:mep

12 void mtu3_req_complete(struct mtu3_ep *mep,  in mtu3_req_complete()  argument
14 __releases(mep->mtu->lock) in mtu3_req_complete()
15 __acquires(mep->mtu->lock) in mtu3_req_complete()
19 int busy = mep->busy; in mtu3_req_complete()
27 mep->busy = 1; in mtu3_req_complete()
31 if (mep->epnum) in mtu3_req_complete()
32 usb_gadget_unmap_request(&mtu->g, req, mep->is_in); in mtu3_req_complete()
34 dev_dbg(mtu->dev, "%s complete req: %p, sts %d, %d/%d\n", mep->name, in mtu3_req_complete()
37 usb_gadget_giveback_request(&mep->ep, &mreq->request); in mtu3_req_complete()
40 mep->busy = busy; in mtu3_req_complete()
43 static void nuke(struct mtu3_ep *mep, const int status) in nuke() argument
47 mep->busy = 1; in nuke()
48 if (list_empty(&mep->req_list)) in nuke()
51 dev_dbg(mep->mtu->dev, "abort %s's req: sts %d\n", mep->name, status); in nuke()
54 if (mep->epnum) in nuke()
55 mtu3_qmu_flush(mep); in nuke()
57 while (!list_empty(&mep->req_list)) { in nuke()
58 mreq = list_first_entry(&mep->req_list, in nuke()
60 mtu3_req_complete(mep, &mreq->request, status); in nuke()
64 static int mtu3_ep_enable(struct mtu3_ep *mep) in mtu3_ep_enable() argument
68 struct mtu3 *mtu = mep->mtu; in mtu3_ep_enable()
75 desc = mep->desc; in mtu3_ep_enable()
76 comp_desc = mep->comp_desc; in mtu3_ep_enable()
77 mep->type = usb_endpoint_type(desc); in mtu3_ep_enable()
79 mep->maxp = max_packet & GENMASK(10, 0); in mtu3_ep_enable()
108 __func__, mep->maxp, interval, burst, mult); in mtu3_ep_enable()
110 mep->ep.maxpacket = mep->maxp; in mtu3_ep_enable()
111 mep->ep.desc = desc; in mtu3_ep_enable()
112 mep->ep.comp_desc = comp_desc; in mtu3_ep_enable()
115 mep->slot = usb_endpoint_xfer_int(desc) ? 0 : mtu->slot; in mtu3_ep_enable()
117 ret = mtu3_config_ep(mtu, mep, interval, burst, mult); in mtu3_ep_enable()
121 ret = mtu3_gpd_ring_alloc(mep); in mtu3_ep_enable()
123 mtu3_deconfig_ep(mtu, mep); in mtu3_ep_enable()
127 mtu3_qmu_start(mep); in mtu3_ep_enable()
132 static int mtu3_ep_disable(struct mtu3_ep *mep) in mtu3_ep_disable() argument
134 struct mtu3 *mtu = mep->mtu; in mtu3_ep_disable()
136 mtu3_qmu_stop(mep); in mtu3_ep_disable()
139 nuke(mep, -ESHUTDOWN); in mtu3_ep_disable()
140 mtu3_deconfig_ep(mtu, mep); in mtu3_ep_disable()
141 mtu3_gpd_ring_free(mep); in mtu3_ep_disable()
143 mep->desc = NULL; in mtu3_ep_disable()
144 mep->ep.desc = NULL; in mtu3_ep_disable()
145 mep->comp_desc = NULL; in mtu3_ep_disable()
146 mep->type = 0; in mtu3_ep_disable()
147 mep->flags = 0; in mtu3_ep_disable()
155 struct mtu3_ep *mep; in mtu3_gadget_ep_enable() local
169 mep = to_mtu3_ep(ep); in mtu3_gadget_ep_enable()
170 mtu = mep->mtu; in mtu3_gadget_ep_enable()
173 if (usb_endpoint_num(desc) != mep->epnum) in mtu3_gadget_ep_enable()
176 if (!!usb_endpoint_dir_in(desc) ^ !!mep->is_in) in mtu3_gadget_ep_enable()
181 if (mep->flags & MTU3_EP_ENABLED) { in mtu3_gadget_ep_enable()
183 mep->name); in mtu3_gadget_ep_enable()
188 mep->desc = desc; in mtu3_gadget_ep_enable()
189 mep->comp_desc = ep->comp_desc; in mtu3_gadget_ep_enable()
191 ret = mtu3_ep_enable(mep); in mtu3_gadget_ep_enable()
195 mep->busy = 0; in mtu3_gadget_ep_enable()
196 mep->wedged = 0; in mtu3_gadget_ep_enable()
197 mep->flags |= MTU3_EP_ENABLED; in mtu3_gadget_ep_enable()
210 struct mtu3_ep *mep = to_mtu3_ep(ep); in mtu3_gadget_ep_disable() local
211 struct mtu3 *mtu = mep->mtu; in mtu3_gadget_ep_disable()
214 dev_dbg(mtu->dev, "%s %s\n", __func__, mep->name); in mtu3_gadget_ep_disable()
216 if (!(mep->flags & MTU3_EP_ENABLED)) { in mtu3_gadget_ep_disable()
217 dev_warn(mtu->dev, "%s is already disabled\n", mep->name); in mtu3_gadget_ep_disable()
222 mtu3_ep_disable(mep); in mtu3_gadget_ep_disable()
223 mep->flags &= ~MTU3_EP_ENABLED; in mtu3_gadget_ep_disable()
235 struct mtu3_ep *mep = to_mtu3_ep(ep); in mtu3_alloc_request() local
243 mreq->epnum = mep->epnum; in mtu3_alloc_request()
244 mreq->mep = mep; in mtu3_alloc_request()
257 struct mtu3_ep *mep; in mtu3_gadget_queue() local
269 mep = to_mtu3_ep(ep); in mtu3_gadget_queue()
270 mtu = mep->mtu; in mtu3_gadget_queue()
274 if (mreq->mep != mep) in mtu3_gadget_queue()
278 __func__, mep->is_in ? "TX" : "RX", mreq->epnum, ep->name, in mtu3_gadget_queue()
289 if (!mep->desc) { in mtu3_gadget_queue()
298 ret = usb_gadget_map_request(&mtu->g, req, mep->is_in); in mtu3_gadget_queue()
306 if (mtu3_prepare_transfer(mep)) { in mtu3_gadget_queue()
311 list_add_tail(&mreq->list, &mep->req_list); in mtu3_gadget_queue()
312 mtu3_insert_gpd(mep, mreq); in mtu3_gadget_queue()
313 mtu3_qmu_resume(mep); in mtu3_gadget_queue()
323 struct mtu3_ep *mep = to_mtu3_ep(ep); in mtu3_gadget_dequeue() local
328 struct mtu3 *mtu = mep->mtu; in mtu3_gadget_dequeue()
330 if (!ep || !req || mreq->mep != mep) in mtu3_gadget_dequeue()
337 list_for_each_entry(r, &mep->req_list, list) { in mtu3_gadget_dequeue()
347 mtu3_qmu_flush(mep); /* REVISIT: set BPS ?? */ in mtu3_gadget_dequeue()
348 mtu3_req_complete(mep, req, -ECONNRESET); in mtu3_gadget_dequeue()
349 mtu3_qmu_start(mep); in mtu3_gadget_dequeue()
363 struct mtu3_ep *mep = to_mtu3_ep(ep); in mtu3_gadget_ep_set_halt() local
364 struct mtu3 *mtu = mep->mtu; in mtu3_gadget_ep_set_halt()
376 if (mep->type == USB_ENDPOINT_XFER_ISOC) { in mtu3_gadget_ep_set_halt()
381 mreq = next_request(mep); in mtu3_gadget_ep_set_halt()
395 mep->wedged = 0; in mtu3_gadget_ep_set_halt()
400 mtu3_ep_stall_set(mep, value); in mtu3_gadget_ep_set_halt()
411 struct mtu3_ep *mep = to_mtu3_ep(ep); in mtu3_gadget_ep_set_wedge() local
416 mep->wedged = 1; in mtu3_gadget_ep_set_wedge()
588 static void init_hw_ep(struct mtu3 *mtu, struct mtu3_ep *mep, in init_hw_ep() argument
591 mep->epnum = epnum; in init_hw_ep()
592 mep->mtu = mtu; in init_hw_ep()
593 mep->is_in = is_in; in init_hw_ep()
595 INIT_LIST_HEAD(&mep->req_list); in init_hw_ep()
597 sprintf(mep->name, "ep%d%s", epnum, in init_hw_ep()
600 mep->ep.name = mep->name; in init_hw_ep()
601 INIT_LIST_HEAD(&mep->ep.ep_list); in init_hw_ep()
605 usb_ep_set_maxpacket_limit(&mep->ep, 512); in init_hw_ep()
606 mep->ep.caps.type_control = true; in init_hw_ep()
607 mep->ep.ops = &mtu3_ep0_ops; in init_hw_ep()
608 mtu->g.ep0 = &mep->ep; in init_hw_ep()
610 usb_ep_set_maxpacket_limit(&mep->ep, 1024); in init_hw_ep()
611 mep->ep.caps.type_iso = true; in init_hw_ep()
612 mep->ep.caps.type_bulk = true; in init_hw_ep()
613 mep->ep.caps.type_int = true; in init_hw_ep()
614 mep->ep.ops = &mtu3_ep_ops; in init_hw_ep()
615 list_add_tail(&mep->ep.ep_list, &mtu->g.ep_list); in init_hw_ep()
618 dev_dbg(mtu->dev, "%s, name=%s, maxp=%d\n", __func__, mep->ep.name, in init_hw_ep()
619 mep->ep.maxpacket); in init_hw_ep()
622 mep->ep.caps.dir_in = true; in init_hw_ep()
623 mep->ep.caps.dir_out = true; in init_hw_ep()
625 mep->ep.caps.dir_in = true; in init_hw_ep()
627 mep->ep.caps.dir_out = true; in init_hw_ep()