summaryrefslogtreecommitdiff
path: root/sys/dev/usb/ucrcom.c
diff options
context:
space:
mode:
authorPatrick Wildt <patrick@cvs.openbsd.org>2020-04-01 08:43:34 +0000
committerPatrick Wildt <patrick@cvs.openbsd.org>2020-04-01 08:43:34 +0000
commit6b5b9a69f57b53fdb7035135ad7b9ceaf9e4b97d (patch)
tree185cbf2f85527be4806724f5aa7ba1fe32868558 /sys/dev/usb/ucrcom.c
parente3cff6a5c3dfe53f6967c27866fcdff7fbae1610 (diff)
USB control requests to the root hub differ from those to devices. For
devices we have proper DMA transfers, so that the DMA syncs before and after transfers are necessary. For the root hub, we seem to fulfill those requests ourselves, e.g. by using memcpy. The POSTREAD DMA sync on a read will invalidate the caches for the buffer, and unless our root hub code explicitly flushed the data to memory, it's possible that our memcpy got removed from history. Until a better solution is implemented, like moving the DMA syncs from the USB subsystem into the controller driver, allocate all buffers that are not explicitly allocated using USB_DMA_COHERENT. The IO buffers continue to be allocated as non-coherent. Regression found by jsg@ ok kettenis@
Diffstat (limited to 'sys/dev/usb/ucrcom.c')
0 files changed, 0 insertions, 0 deletions