summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorAlexander Yurchenko <grange@cvs.openbsd.org>2004-10-17 19:00:47 +0000
committerAlexander Yurchenko <grange@cvs.openbsd.org>2004-10-17 19:00:47 +0000
commit4b00196c60b83e23bcda5b240d2e874be9950b66 (patch)
treedc70b04b07e85dca6d972d29175c7f8413933922 /sys/dev
parentb0ca8c27a68fb4f778b0f080e1eb8531e8bf345e (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')
-rw-r--r--sys/dev/pci/pciide.c10
-rw-r--r--sys/dev/pci/pciidevar.h9
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 */