Subject: Re: wrong bus_dma(9) usage in dev/ic/lsi64854.c
To: Izumi Tsutsui <tsutsui@ceres.dti.ne.jp>
From: Jason R Thorpe <thorpej@zembu.com>
List: port-sparc64
Date: 03/31/2001 23:08:45
On Sun, Apr 01, 2001 at 01:20:09PM +0900, Izumi Tsutsui wrote:
> - BUS_DMA_COHERENT is specified to bus_dmamap_load() flags
> - VA is passed to bus_dmamap_sync() as offset
>
> I think the attached diff is correct, but I don't have any Ultra
> machines to test. (stream and sync are no-op on sun4c)
You should not use STREAMING -- STREAMING is the "opposite" of
STREAMING.
> Is it Ok to commit this?
> ---
> Izumi Tsutsui
> tsutsui@ceres.dti.ne.jp
>
> Index: lsi64854.c
> ===================================================================
> RCS file: /cvsroot/syssrc/sys/dev/ic/lsi64854.c,v
> retrieving revision 1.15
> diff -u -r1.15 lsi64854.c
> --- lsi64854.c 2001/03/29 02:58:39 1.15
> +++ lsi64854.c 2001/04/01 03:48:12
> @@ -331,11 +331,10 @@
> if (bus_dmamap_load(sc->sc_dmatag, sc->sc_dmamap,
> *sc->sc_dmaaddr, sc->sc_dmasize,
> NULL /* kernel address */,
> - BUS_DMA_NOWAIT | BUS_DMA_COHERENT))
> + BUS_DMA_NOWAIT | BUS_DMA_STREAMING))
> panic("%s: cannot allocate DVMA address",
> sc->sc_dev.dv_xname);
> - bus_dmamap_sync(sc->sc_dmatag, sc->sc_dmamap,
> - (bus_addr_t)(u_long)sc->sc_dvmaaddr, sc->sc_dmasize,
> + bus_dmamap_sync(sc->sc_dmatag, sc->sc_dmamap, 0, sc->sc_dmasize,
> datain
> ? BUS_DMASYNC_PREREAD
> : BUS_DMASYNC_PREWRITE);
> @@ -476,8 +475,7 @@
> trans, resid));
>
> if (sc->sc_dmamap->dm_nsegs > 0) {
> - bus_dmamap_sync(sc->sc_dmatag, sc->sc_dmamap,
> - (bus_addr_t)(u_long)sc->sc_dvmaaddr, sc->sc_dmasize,
> + bus_dmamap_sync(sc->sc_dmatag, sc->sc_dmamap, 0, sc->sc_dmasize,
> (csr & D_WRITE) != 0
> ? BUS_DMASYNC_POSTREAD
> : BUS_DMASYNC_POSTWRITE);
> @@ -580,8 +578,7 @@
> BUS_DMA_NOWAIT/*|BUS_DMA_COHERENT*/))
> panic("%s: pp cannot allocate DVMA address",
> sc->sc_dev.dv_xname);
> - bus_dmamap_sync(sc->sc_dmatag, sc->sc_dmamap,
> - (bus_addr_t)(u_long)sc->sc_dvmaaddr, sc->sc_dmasize,
> + bus_dmamap_sync(sc->sc_dmatag, sc->sc_dmamap, 0, sc->sc_dmasize,
> datain
> ? BUS_DMASYNC_PREREAD
> : BUS_DMASYNC_PREWRITE);
> @@ -666,8 +663,7 @@
> *sc->sc_dmaaddr += trans;
>
> if (sc->sc_dmamap->dm_nsegs > 0) {
> - bus_dmamap_sync(sc->sc_dmatag, sc->sc_dmamap,
> - (bus_addr_t)(u_long)sc->sc_dvmaaddr, sc->sc_dmasize,
> + bus_dmamap_sync(sc->sc_dmatag, sc->sc_dmamap, 0, sc->sc_dmasize,
> (csr & D_WRITE) != 0
> ? BUS_DMASYNC_POSTREAD
> : BUS_DMASYNC_POSTWRITE);
--
-- Jason R. Thorpe <thorpej@zembu.com>