usb: gadget: Refactor request completion
Use the recently introduced usb_gadget_giveback_request() in favor of direct invocation of the completion routine. All places in drivers/usb/ matching "[-.]complete(" were replaced with a call to usb_gadget_giveback_request(). This was compile-tested with all ARM drivers enabled and runtime-tested for musb. 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>
Tento commit je obsažen v:

odevzdal
Greg Kroah-Hartman

rodič
3fc2aa5522
revize
304f7e5e1d
@@ -841,7 +841,7 @@ __acquires(ep->dev->lock)
|
||||
&req->req, req->req.length, ep->ep.name, sts);
|
||||
|
||||
spin_unlock(&dev->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&dev->lock);
|
||||
ep->halted = halted;
|
||||
}
|
||||
|
@@ -267,7 +267,7 @@ static void done(struct at91_ep *ep, struct at91_request *req, int status)
|
||||
|
||||
ep->stopped = 1;
|
||||
spin_unlock(&udc->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&udc->lock);
|
||||
ep->stopped = stopped;
|
||||
|
||||
|
@@ -463,7 +463,7 @@ static void receive_data(struct usba_ep *ep)
|
||||
list_del_init(&req->queue);
|
||||
usba_ep_writel(ep, CTL_DIS, USBA_RX_BK_RDY);
|
||||
spin_unlock(&udc->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&udc->lock);
|
||||
}
|
||||
|
||||
@@ -495,7 +495,7 @@ request_complete(struct usba_ep *ep, struct usba_request *req, int status)
|
||||
ep->ep.name, req, req->req.status, req->req.actual);
|
||||
|
||||
spin_unlock(&udc->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&udc->lock);
|
||||
}
|
||||
|
||||
|
@@ -1088,7 +1088,7 @@ static int bcm63xx_ep_disable(struct usb_ep *ep)
|
||||
breq->req.status = -ESHUTDOWN;
|
||||
|
||||
spin_unlock_irqrestore(&udc->lock, flags);
|
||||
breq->req.complete(&iudma->bep->ep, &breq->req);
|
||||
usb_gadget_giveback_request(&iudma->bep->ep, &breq->req);
|
||||
spin_lock_irqsave(&udc->lock, flags);
|
||||
}
|
||||
}
|
||||
|
@@ -258,7 +258,7 @@ static void nuke(struct dummy *dum, struct dummy_ep *ep)
|
||||
req->req.status = -ESHUTDOWN;
|
||||
|
||||
spin_unlock(&dum->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&dum->lock);
|
||||
}
|
||||
}
|
||||
@@ -658,7 +658,7 @@ static int dummy_queue(struct usb_ep *_ep, struct usb_request *_req,
|
||||
spin_unlock(&dum->lock);
|
||||
_req->actual = _req->length;
|
||||
_req->status = 0;
|
||||
_req->complete(_ep, _req);
|
||||
usb_gadget_giveback_request(_ep, _req);
|
||||
spin_lock(&dum->lock);
|
||||
} else
|
||||
list_add_tail(&req->queue, &ep->queue);
|
||||
@@ -702,7 +702,7 @@ static int dummy_dequeue(struct usb_ep *_ep, struct usb_request *_req)
|
||||
dev_dbg(udc_dev(dum),
|
||||
"dequeued req %p from %s, len %d buf %p\n",
|
||||
req, _ep->name, _req->length, _req->buf);
|
||||
_req->complete(_ep, _req);
|
||||
usb_gadget_giveback_request(_ep, _req);
|
||||
}
|
||||
local_irq_restore(flags);
|
||||
return retval;
|
||||
@@ -1385,7 +1385,7 @@ top:
|
||||
list_del_init(&req->queue);
|
||||
|
||||
spin_unlock(&dum->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&dum->lock);
|
||||
|
||||
/* requests might have been unlinked... */
|
||||
@@ -1761,7 +1761,7 @@ restart:
|
||||
req);
|
||||
|
||||
spin_unlock(&dum->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&dum->lock);
|
||||
ep->already_seen = 0;
|
||||
goto restart;
|
||||
|
@@ -70,7 +70,7 @@ static void fotg210_done(struct fotg210_ep *ep, struct fotg210_request *req,
|
||||
req->req.status = status;
|
||||
|
||||
spin_unlock(&ep->fotg210->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&ep->fotg210->lock);
|
||||
|
||||
if (ep->epnum) {
|
||||
|
@@ -118,10 +118,7 @@ static void done(struct qe_ep *ep, struct qe_req *req, int status)
|
||||
ep->stopped = 1;
|
||||
spin_unlock(&udc->lock);
|
||||
|
||||
/* this complete() should a func implemented by gadget layer,
|
||||
* eg fsg->bulk_in_complete() */
|
||||
if (req->req.complete)
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
|
||||
spin_lock(&udc->lock);
|
||||
|
||||
@@ -2728,4 +2725,3 @@ module_platform_driver(udc_driver);
|
||||
MODULE_DESCRIPTION(DRIVER_DESC);
|
||||
MODULE_AUTHOR(DRIVER_AUTHOR);
|
||||
MODULE_LICENSE("GPL");
|
||||
|
||||
|
@@ -197,10 +197,8 @@ __acquires(ep->udc->lock)
|
||||
ep->stopped = 1;
|
||||
|
||||
spin_unlock(&ep->udc->lock);
|
||||
/* complete() is from gadget layer,
|
||||
* eg fsg->bulk_in_complete() */
|
||||
if (req->req.complete)
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
|
||||
spin_lock(&ep->udc->lock);
|
||||
ep->stopped = stopped;
|
||||
|
@@ -876,7 +876,7 @@ static void done(struct fusb300_ep *ep, struct fusb300_request *req,
|
||||
req->req.status = status;
|
||||
|
||||
spin_unlock(&ep->fusb300->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&ep->fusb300->lock);
|
||||
|
||||
if (ep->epnum) {
|
||||
|
@@ -320,7 +320,7 @@ done(struct goku_ep *ep, struct goku_request *req, int status)
|
||||
/* don't modify queue heads during completion callback */
|
||||
ep->stopped = 1;
|
||||
spin_unlock(&dev->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&dev->lock);
|
||||
ep->stopped = stopped;
|
||||
}
|
||||
|
@@ -357,7 +357,7 @@ static void gr_finish_request(struct gr_ep *ep, struct gr_request *req,
|
||||
} else if (req->req.complete) {
|
||||
spin_unlock(&dev->lock);
|
||||
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
|
||||
spin_lock(&dev->lock);
|
||||
}
|
||||
|
@@ -1479,7 +1479,7 @@ static void done(struct lpc32xx_ep *ep, struct lpc32xx_request *req, int status)
|
||||
|
||||
ep->req_pending = 0;
|
||||
spin_unlock(&udc->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&udc->lock);
|
||||
}
|
||||
|
||||
|
@@ -729,7 +729,7 @@ __acquires(m66592->lock)
|
||||
restart = 1;
|
||||
|
||||
spin_unlock(&ep->m66592->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&ep->m66592->lock);
|
||||
|
||||
if (restart) {
|
||||
|
@@ -222,12 +222,8 @@ void mv_u3d_done(struct mv_u3d_ep *ep, struct mv_u3d_req *req, int status)
|
||||
}
|
||||
|
||||
spin_unlock(&ep->u3d->lock);
|
||||
/*
|
||||
* complete() is from gadget layer,
|
||||
* eg fsg->bulk_in_complete()
|
||||
*/
|
||||
if (req->req.complete)
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
|
||||
spin_lock(&ep->u3d->lock);
|
||||
}
|
||||
|
@@ -248,12 +248,8 @@ static void done(struct mv_ep *ep, struct mv_req *req, int status)
|
||||
ep->stopped = 1;
|
||||
|
||||
spin_unlock(&ep->udc->lock);
|
||||
/*
|
||||
* complete() is from gadget layer,
|
||||
* eg fsg->bulk_in_complete()
|
||||
*/
|
||||
if (req->req.complete)
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
|
||||
spin_lock(&ep->udc->lock);
|
||||
ep->stopped = stopped;
|
||||
|
@@ -394,7 +394,7 @@ net2272_done(struct net2272_ep *ep, struct net2272_request *req, int status)
|
||||
/* don't modify queue heads during completion callback */
|
||||
ep->stopped = 1;
|
||||
spin_unlock(&dev->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&dev->lock);
|
||||
ep->stopped = stopped;
|
||||
}
|
||||
|
@@ -928,7 +928,7 @@ done(struct net2280_ep *ep, struct net2280_request *req, int status)
|
||||
/* don't modify queue heads during completion callback */
|
||||
ep->stopped = 1;
|
||||
spin_unlock(&dev->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&dev->lock);
|
||||
ep->stopped = stopped;
|
||||
}
|
||||
|
@@ -315,7 +315,7 @@ done(struct omap_ep *ep, struct omap_req *req, int status)
|
||||
/* don't modify queue heads during completion callback */
|
||||
ep->stopped = 1;
|
||||
spin_unlock(&ep->udc->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&ep->udc->lock);
|
||||
ep->stopped = stopped;
|
||||
}
|
||||
|
@@ -1490,7 +1490,7 @@ static void complete_req(struct pch_udc_ep *ep, struct pch_udc_request *req,
|
||||
spin_unlock(&dev->lock);
|
||||
if (!ep->in)
|
||||
pch_udc_ep_clear_rrdy(ep);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&dev->lock);
|
||||
ep->halted = halted;
|
||||
}
|
||||
|
@@ -347,7 +347,7 @@ static void done(struct pxa25x_ep *ep, struct pxa25x_request *req, int status)
|
||||
|
||||
/* don't modify queue heads during completion callback */
|
||||
ep->stopped = 1;
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
ep->stopped = stopped;
|
||||
}
|
||||
|
||||
|
@@ -758,7 +758,7 @@ static void req_done(struct pxa_ep *ep, struct pxa27x_request *req, int status,
|
||||
if (pflags)
|
||||
spin_unlock_irqrestore(&ep->lock, *pflags);
|
||||
local_irq_save(flags);
|
||||
req->req.complete(&req->udc_usb_ep->usb_ep, &req->req);
|
||||
usb_gadget_giveback_request(&req->udc_usb_ep->usb_ep, &req->req);
|
||||
local_irq_restore(flags);
|
||||
if (pflags)
|
||||
spin_lock_irqsave(&ep->lock, *pflags);
|
||||
|
@@ -925,7 +925,7 @@ __acquires(r8a66597->lock)
|
||||
sudmac_free_channel(ep->r8a66597, ep, req);
|
||||
|
||||
spin_unlock(&ep->r8a66597->lock);
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
spin_lock(&ep->r8a66597->lock);
|
||||
|
||||
if (restart) {
|
||||
|
@@ -258,8 +258,7 @@ static void s3c_hsudc_complete_request(struct s3c_hsudc_ep *hsep,
|
||||
|
||||
hsep->stopped = 1;
|
||||
spin_unlock(&hsudc->lock);
|
||||
if (hsreq->req.complete != NULL)
|
||||
hsreq->req.complete(&hsep->ep, &hsreq->req);
|
||||
usb_gadget_giveback_request(&hsep->ep, &hsreq->req);
|
||||
spin_lock(&hsudc->lock);
|
||||
hsep->stopped = stopped;
|
||||
}
|
||||
|
@@ -272,7 +272,7 @@ static void s3c2410_udc_done(struct s3c2410_ep *ep,
|
||||
status = req->req.status;
|
||||
|
||||
ep->halted = 1;
|
||||
req->req.complete(&ep->ep, &req->req);
|
||||
usb_gadget_giveback_request(&ep->ep, &req->req);
|
||||
ep->halted = halted;
|
||||
}
|
||||
|
||||
|
Odkázat v novém úkolu
Zablokovat Uživatele