usb: host: ehci: Add missed memory barrier in the hcd driver
Jay Cheng [Wed, 27 Oct 2010 15:45:19 +0000 (11:45 -0400)]
There is one wmb missing in the usb host controller driver after the queue head
update. Due to this data transaction is not happening on the bus after urb
submission by the hcd driver. Register updates/queue heads data in the memory
is not reflected on the AHB bus. After adding the wmb after queue head update
data transaction the USB bus started with out any delay.

originally fixed by Venkat Moganty <vmoganty@nvidia.com>

Change-Id: Ic834df5172ac2f2eb3bced317d38b4a2e7a44801
Signed-off-by: Jay Cheng <jacheng@nvidia.com>

drivers/usb/host/ehci-q.c

index 0917e3a..bd7ffe0 100644 (file)
@@ -998,6 +998,7 @@ static void qh_link_async (struct ehci_hcd *ehci, struct ehci_qh *qh)
        qh_get(qh);
        qh->xacterrs = 0;
        qh->qh_state = QH_STATE_LINKED;
+       wmb();
        /* qtd completions reported later by interrupt */
 }