mirror of
https://github.com/opnsense/src.git
synced 2026-05-28 04:12:45 -04:00
Fix coherency issue. From submitter:
I have been debugging the usb problems some more. Your were right in your assumption (thanks for the pointer) about lack of calls to bus_dmamap_sync(). In usbdi.c bus_dmamap_sync() does get used for transfers that move data from PC to USB and it is used for transfers that move data from USB to PC. But someone forgot that control transfers consist of possibly two data chunks : the request itself and optionally a buffer of data that should be transfered to or from the USB device. On requests to the control endpoint without additional data bus_dmamap_sync() didn't get called. For some reason my first tests with umass worked (due to enough cache poisening I guess). The attached patch adds a call to bus_dmamap_sync() to usbdi.c and now all devices I have tried work out of the box. I have successfully transfered large files using the if_axe driver and I have mounted several different umass devices. submitted by: Daan Vreeken sponsored by: Vitsch Electronics reviewed by: cognet@
This commit is contained in:
parent
21367f630d
commit
5128f7357c
1 changed files with 7 additions and 0 deletions
|
|
@ -377,6 +377,13 @@ usbd_start_transfer(void *arg, bus_dma_segment_t *segs, int nseg, int error)
|
|||
xfer->buffer != xfer->allocbuf)
|
||||
memcpy(xfer->allocbuf, xfer->buffer, xfer->length);
|
||||
bus_dmamap_sync(tag, dmap->map, BUS_DMASYNC_PREWRITE);
|
||||
} else {
|
||||
/*
|
||||
* Even if we have no data portion we still need to sync the
|
||||
* dmamap for the request data in the SETUP packet
|
||||
*/
|
||||
if (xfer->rqflags & URQ_REQUEST)
|
||||
bus_dmamap_sync(tag, dmap->map, BUS_DMASYNC_PREWRITE);
|
||||
}
|
||||
err = pipe->methods->transfer(xfer);
|
||||
if (err != USBD_IN_PROGRESS && err) {
|
||||
|
|
|
|||
Loading…
Reference in a new issue