usb: gadget: f_uac2: don't queue new requests when shutting down
authorAndrzej Pietrasiewicz <andrzej.p@samsung.com>
Thu, 15 May 2014 11:43:50 +0000 (13:43 +0200)
committerFelipe Balbi <balbi@ti.com>
Thu, 15 May 2014 15:30:31 +0000 (10:30 -0500)
In some circumstances when g_audio is being unloaded there happens
an endless loop in udc driver. It has happend on a board with
s3c-hsotg. If there are requests in endpoint's queue, they are completed
in a loop. But completing them might cause appending new requests
to the queue. This patch causes agdev_iso_complete() to return immediately
if request's status is -ESHUTDOWN. If it does not return immediately,
then although the current request is removed from the queue, a new one
is appended to the queue, so the above mentioned loop cannot end.

Signed-off-by: Andrzej Pietrasiewicz <andrzej.p@samsung.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
drivers/usb/gadget/f_uac2.c

index c024d27fcce21ece5e75ec82eac97ef8d4e224db..6261db4a991058c0a05acaeb65fa2a2ed6850578 100644 (file)
@@ -196,7 +196,7 @@ agdev_iso_complete(struct usb_ep *ep, struct usb_request *req)
        struct snd_uac2_chip *uac2 = prm->uac2;
 
        /* i/f shutting down */
-       if (!prm->ep_enabled)
+       if (!prm->ep_enabled || req->status == -ESHUTDOWN)
                return;
 
        /*