]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
usb: dwc2: host: spinlock release channel
authorGregory Herrero <gregory.herrero@intel.com>
Thu, 5 Nov 2015 08:41:41 +0000 (09:41 +0100)
committerFelipe Balbi <balbi@ti.com>
Tue, 15 Dec 2015 15:12:41 +0000 (09:12 -0600)
Prevent dwc2 driver from accessing channel while it frees it.

Acked-by: John Youn <johnyoun@synopsys.com>
Signed-off-by: Gregory Herrero <gregory.herrero@intel.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
drivers/usb/dwc2/hcd_ddma.c

index 4801e693353a4f9220ab0e391449ea69b22bf33e..a76a58c35feabfa5ffc1a7da06b6147d50874a15 100644 (file)
@@ -360,6 +360,8 @@ err0:
  */
 void dwc2_hcd_qh_free_ddma(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh)
 {
+       unsigned long flags;
+
        dwc2_desc_list_free(hsotg, qh);
 
        /*
@@ -369,8 +371,10 @@ void dwc2_hcd_qh_free_ddma(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh)
         * when it comes here from endpoint disable routine
         * channel remains assigned.
         */
+       spin_lock_irqsave(&hsotg->lock, flags);
        if (qh->channel)
                dwc2_release_channel_ddma(hsotg, qh);
+       spin_unlock_irqrestore(&hsotg->lock, flags);
 
        if ((qh->ep_type == USB_ENDPOINT_XFER_ISOC ||
             qh->ep_type == USB_ENDPOINT_XFER_INT) &&