Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/sgimips/hpc - MAXPHYS is enough for DMA xfer size (...
details: https://anonhg.NetBSD.org/src/rev/6cd4fee703bd
branches: trunk
changeset: 761355:6cd4fee703bd
user: tsutsui <tsutsui%NetBSD.org@localhost>
date: Tue Jan 25 12:14:02 2011 +0000
description:
- MAXPHYS is enough for DMA xfer size (hpc->scsi_max_xfer seems too large)
- switch BUS_DMASYNC_*READ and BUS_DMASYNC_*WRITE properly in
bus_dmamap_sync(9) ops per each xfer dir
Tested on R5000 Indy.
diffstat:
sys/arch/sgimips/hpc/wdsc.c | 12 +++++++-----
1 files changed, 7 insertions(+), 5 deletions(-)
diffs (47 lines):
diff -r 049a00fde544 -r 6cd4fee703bd sys/arch/sgimips/hpc/wdsc.c
--- a/sys/arch/sgimips/hpc/wdsc.c Tue Jan 25 12:11:27 2011 +0000
+++ b/sys/arch/sgimips/hpc/wdsc.c Tue Jan 25 12:14:02 2011 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: wdsc.c,v 1.29 2009/12/14 00:46:13 matt Exp $ */
+/* $NetBSD: wdsc.c,v 1.30 2011/01/25 12:14:02 tsutsui Exp $ */
/*
* Copyright (c) 2001 Wayne Knowles
@@ -37,7 +37,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: wdsc.c,v 1.29 2009/12/14 00:46:13 matt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: wdsc.c,v 1.30 2011/01/25 12:14:02 tsutsui Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -162,7 +162,7 @@
}
if (bus_dmamap_create(wsc->sc_dmat,
- wsc->sc_hpcdma.hpc->scsi_max_xfer,
+ MAXPHYS,
wsc->sc_hpcdma.hpc->scsi_dma_segs,
wsc->sc_hpcdma.hpc->scsi_dma_segs_size,
wsc->sc_hpcdma.hpc->scsi_dma_segs_size,
@@ -261,7 +261,8 @@
bus_dmamap_sync(wsc->sc_dmat, wsc->sc_dmamap, 0,
wsc->sc_dmamap->dm_mapsize,
- BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE);
+ (dsc->sc_flags & HPCDMA_READ) ?
+ BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
hpcdma_cntl(dsc, dsc->sc_dmacmd); /* Thunderbirds are go! */
@@ -283,7 +284,8 @@
hpcdma_cntl(dsc, 0); /* Stop DMA */
bus_dmamap_sync(wsc->sc_dmat, wsc->sc_dmamap, 0,
wsc->sc_dmamap->dm_mapsize,
- BUS_DMASYNC_POSTREAD|BUS_DMASYNC_POSTWRITE);
+ (dsc->sc_flags & HPCDMA_READ) ?
+ BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
}
if (wsc->sc_flags & WDSC_DMA_MAPLOADED)
bus_dmamap_unload(wsc->sc_dmat, wsc->sc_dmamap);
Home |
Main Index |
Thread Index |
Old Index