summaryrefslogtreecommitdiff
path: root/sys/dev/usb
diff options
context:
space:
mode:
authorHans Petter Selasky <hselasky@FreeBSD.org>2020-09-26 08:44:16 +0000
committerHans Petter Selasky <hselasky@FreeBSD.org>2020-09-26 08:44:16 +0000
commit4cb98e0bea637b18e196015291441feb1c5107fe (patch)
tree443674671e40f64084ee75fe7c0aa7b841b4b6c7 /sys/dev/usb
parent3cfb9a8386efee3fbdfd3b41cf2b512c1ffccc73 (diff)
Notes
Diffstat (limited to 'sys/dev/usb')
-rw-r--r--sys/dev/usb/controller/xhci.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/sys/dev/usb/controller/xhci.c b/sys/dev/usb/controller/xhci.c
index 31d66544fe80..9c3c58639df8 100644
--- a/sys/dev/usb/controller/xhci.c
+++ b/sys/dev/usb/controller/xhci.c
@@ -431,6 +431,19 @@ xhci_start_controller(struct xhci_softc *sc)
phwr->hwr_ring_seg[0].qwEvrsTablePtr = htole64(addr);
phwr->hwr_ring_seg[0].dwEvrsTableSize = htole32(XHCI_MAX_EVENTS);
+ /*
+ * PR 237666:
+ *
+ * According to the XHCI specification, the XWRITE4's to
+ * XHCI_ERSTBA_LO and _HI lead to the XHCI to copy the
+ * qwEvrsTablePtr and dwEvrsTableSize values above at that
+ * time, as the XHCI initializes its event ring support. This
+ * is before the event ring starts to pay attention to the
+ * RUN/STOP bit. Thus, make sure the values are observable to
+ * the XHCI before that point.
+ */
+ usb_bus_mem_flush_all(&sc->sc_bus, &xhci_iterate_hw_softc);
+
DPRINTF("ERDP(0)=0x%016llx\n", (unsigned long long)addr);
XWRITE4(sc, runt, XHCI_ERDP_LO(0), (uint32_t)addr);