usb: dwc3: gadget: Refactor dwc3_gadget_ep_dequeue
authorThinh Nguyen <Thinh.Nguyen@synopsys.com>
Thu, 5 Mar 2020 21:24:20 +0000 (13:24 -0800)
committerFelipe Balbi <balbi@kernel.org>
Tue, 5 May 2020 07:58:53 +0000 (10:58 +0300)
The flow from function dwc3_gadget_ep_dequeue() is not easy to follow.
Refactor it for easier read. No functional change in this commit.

Signed-off-by: Thinh Nguyen <thinhn@synopsys.com>
Signed-off-by: Felipe Balbi <balbi@kernel.org>
drivers/usb/dwc3/gadget.c

index 2b58f0e..58a05c5 100644 (file)
@@ -1562,19 +1562,17 @@ static int dwc3_gadget_ep_dequeue(struct usb_ep *ep,
 
        list_for_each_entry(r, &dep->cancelled_list, list) {
                if (r == req)
-                       goto out0;
+                       goto out;
        }
 
        list_for_each_entry(r, &dep->pending_list, list) {
-               if (r == req)
-                       break;
+               if (r == req) {
+                       dwc3_gadget_giveback(dep, req, -ECONNRESET);
+                       goto out;
+               }
        }
 
-       if (r != req) {
-               list_for_each_entry(r, &dep->started_list, list) {
-                       if (r == req)
-                               break;
-               }
+       list_for_each_entry(r, &dep->started_list, list) {
                if (r == req) {
                        struct dwc3_request *t;
 
@@ -1588,17 +1586,14 @@ static int dwc3_gadget_ep_dequeue(struct usb_ep *ep,
                        list_for_each_entry_safe(r, t, &dep->started_list, list)
                                dwc3_gadget_move_cancelled_request(r);
 
-                       goto out0;
+                       goto out;
                }
-               dev_err(dwc->dev, "request %pK was not queued to %s\n",
-                               request, ep->name);
-               ret = -EINVAL;
-               goto out0;
        }
 
-       dwc3_gadget_giveback(dep, req, -ECONNRESET);
-
-out0:
+       dev_err(dwc->dev, "request %pK was not queued to %s\n",
+               request, ep->name);
+       ret = -EINVAL;
+out:
        spin_unlock_irqrestore(&dwc->lock, flags);
 
        return ret;