diff options
author | Alexander Yurchenko <grange@cvs.openbsd.org> | 2004-10-17 19:00:47 +0000 |
---|---|---|
committer | Alexander Yurchenko <grange@cvs.openbsd.org> | 2004-10-17 19:00:47 +0000 |
commit | 4b00196c60b83e23bcda5b240d2e874be9950b66 (patch) | |
tree | dc70b04b07e85dca6d972d29175c7f8413933922 /sys/dev/pci | |
parent | b0ca8c27a68fb4f778b0f080e1eb8531e8bf345e (diff) |
Allow chip-map function to specify which bits must permanently present
in the dma command register. It's a no-op for now but sii3114 will need
it. From NetBSD.
Diffstat (limited to 'sys/dev/pci')
-rw-r--r-- | sys/dev/pci/pciide.c | 10 | ||||
-rw-r--r-- | sys/dev/pci/pciidevar.h | 9 |
2 files changed, 14 insertions, 5 deletions
diff --git a/sys/dev/pci/pciide.c b/sys/dev/pci/pciide.c index f92c766811d..82f3d0f283c 100644 --- a/sys/dev/pci/pciide.c +++ b/sys/dev/pci/pciide.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pciide.c,v 1.175 2004/10/17 18:47:08 grange Exp $ */ +/* $OpenBSD: pciide.c,v 1.176 2004/10/17 19:00:45 grange Exp $ */ /* $NetBSD: pciide.c,v 1.127 2001/08/03 01:31:08 tsutsui Exp $ */ /* @@ -1241,6 +1241,7 @@ pciide_dma_init(v, channel, drive, databuf, datalen, flags) { struct pciide_softc *sc = v; int error, seg; + struct pciide_channel *cp = &sc->pciide_channels[channel]; struct pciide_dma_maps *dma_maps = &sc->pciide_channels[channel].dma_maps[drive]; #ifndef BUS_DMA_RAW @@ -1310,7 +1311,7 @@ pciide_dma_init(v, channel, drive, databuf, datalen, flags) dma_maps->dmamap_table->dm_segs[0].ds_addr); /* set read/write */ PCIIDE_DMACMD_WRITE(sc, channel, - (flags & WDC_DMA_READ) ? IDEDMA_CMD_WRITE : 0); + ((flags & WDC_DMA_READ) ? IDEDMA_CMD_WRITE : 0) | cp->idedma_cmd); /* remember flags */ dma_maps->dma_flags = flags; return 0; @@ -1337,6 +1338,7 @@ pciide_dma_finish(v, channel, drive, force) int force; { struct pciide_softc *sc = v; + struct pciide_channel *cp = &sc->pciide_channels[channel]; u_int8_t status; int error = 0; struct pciide_dma_maps *dma_maps = @@ -1353,8 +1355,8 @@ pciide_dma_finish(v, channel, drive, force) /* stop DMA channel */ PCIIDE_DMACMD_WRITE(sc, channel, - (dma_maps->dma_flags & WDC_DMA_READ) ? - 0x00 : IDEDMA_CMD_WRITE); + ((dma_maps->dma_flags & WDC_DMA_READ) ? + 0x00 : IDEDMA_CMD_WRITE) | cp->idedma_cmd); /* Unload the map of the data buffer */ bus_dmamap_sync(sc->sc_dmat, dma_maps->dmamap_xfer, 0, diff --git a/sys/dev/pci/pciidevar.h b/sys/dev/pci/pciidevar.h index 7d6ad15623d..b552dd60036 100644 --- a/sys/dev/pci/pciidevar.h +++ b/sys/dev/pci/pciidevar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pciidevar.h,v 1.15 2004/10/17 18:47:08 grange Exp $ */ +/* $OpenBSD: pciidevar.h,v 1.16 2004/10/17 19:00:46 grange Exp $ */ /* $NetBSD: pciidevar.h,v 1.6 2001/01/12 16:04:00 bouyer Exp $ */ /* @@ -91,6 +91,13 @@ struct pciide_softc { bus_dmamap_t dmamap_xfer; int dma_flags; } dma_maps[2]; + /* + * Some controllers require certain bits to + * always be set for proper operation of the + * controller. Set those bits here, if they're + * required. + */ + uint8_t idedma_cmd; } pciide_channels[PCIIDE_MAX_CHANNELS]; /* Chip-specific private data */ |