usb: host: ehci: Add missed memory barrier in the hcd driver

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>
This commit is contained in:
Jay Cheng
2010-10-27 11:45:19 -04:00
committed by Benoit Goby
parent 2b32d2a33a
commit b0d63aa773

View File

@@ -1008,6 +1008,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 */
}