|
@@ -357,12 +357,12 @@ void dwc2_hcd_stop(struct dwc2_hsotg *hsotg)
|
|
|
writel(0, hsotg->regs + HPRT0);
|
|
|
}
|
|
|
|
|
|
+/* Caller must hold driver lock */
|
|
|
static int dwc2_hcd_urb_enqueue(struct dwc2_hsotg *hsotg,
|
|
|
struct dwc2_hcd_urb *urb, void **ep_handle,
|
|
|
gfp_t mem_flags)
|
|
|
{
|
|
|
struct dwc2_qtd *qtd;
|
|
|
- unsigned long flags;
|
|
|
u32 intr_mask;
|
|
|
int retval;
|
|
|
int dev_speed;
|
|
@@ -413,11 +413,9 @@ static int dwc2_hcd_urb_enqueue(struct dwc2_hsotg *hsotg,
|
|
|
*/
|
|
|
return 0;
|
|
|
|
|
|
- spin_lock_irqsave(&hsotg->lock, flags);
|
|
|
tr_type = dwc2_hcd_select_transactions(hsotg);
|
|
|
if (tr_type != DWC2_TRANSACTION_NONE)
|
|
|
dwc2_hcd_queue_transactions(hsotg, tr_type);
|
|
|
- spin_unlock_irqrestore(&hsotg->lock, flags);
|
|
|
}
|
|
|
|
|
|
return 0;
|
|
@@ -2484,7 +2482,7 @@ static int _dwc2_hcd_urb_enqueue(struct usb_hcd *hcd, struct urb *urb,
|
|
|
"%s: unaligned transfer with no transfer_buffer",
|
|
|
__func__);
|
|
|
retval = -EINVAL;
|
|
|
- goto fail1;
|
|
|
+ goto fail0;
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -2512,7 +2510,6 @@ static int _dwc2_hcd_urb_enqueue(struct usb_hcd *hcd, struct urb *urb,
|
|
|
|
|
|
spin_lock_irqsave(&hsotg->lock, flags);
|
|
|
retval = usb_hcd_link_urb_to_ep(hcd, urb);
|
|
|
- spin_unlock_irqrestore(&hsotg->lock, flags);
|
|
|
if (retval)
|
|
|
goto fail1;
|
|
|
|
|
@@ -2521,22 +2518,22 @@ static int _dwc2_hcd_urb_enqueue(struct usb_hcd *hcd, struct urb *urb,
|
|
|
goto fail2;
|
|
|
|
|
|
if (alloc_bandwidth) {
|
|
|
- spin_lock_irqsave(&hsotg->lock, flags);
|
|
|
dwc2_allocate_bus_bandwidth(hcd,
|
|
|
dwc2_hcd_get_ep_bandwidth(hsotg, ep),
|
|
|
urb);
|
|
|
- spin_unlock_irqrestore(&hsotg->lock, flags);
|
|
|
}
|
|
|
|
|
|
+ spin_unlock_irqrestore(&hsotg->lock, flags);
|
|
|
+
|
|
|
return 0;
|
|
|
|
|
|
fail2:
|
|
|
- spin_lock_irqsave(&hsotg->lock, flags);
|
|
|
dwc2_urb->priv = NULL;
|
|
|
usb_hcd_unlink_urb_from_ep(hcd, urb);
|
|
|
- spin_unlock_irqrestore(&hsotg->lock, flags);
|
|
|
fail1:
|
|
|
+ spin_unlock_irqrestore(&hsotg->lock, flags);
|
|
|
urb->hcpriv = NULL;
|
|
|
+fail0:
|
|
|
kfree(dwc2_urb);
|
|
|
|
|
|
return retval;
|