summaryrefslogtreecommitdiff
path: root/sys/dev/pci/pciide.c
diff options
context:
space:
mode:
authorJonathan Gray <jsg@cvs.openbsd.org>2005-04-20 00:53:12 +0000
committerJonathan Gray <jsg@cvs.openbsd.org>2005-04-20 00:53:12 +0000
commit33e91575565bb3a8cc83ceb556c4f059787f4f31 (patch)
tree20dbd5fbe03a4cd3aeb2e41eab89827470fa386c /sys/dev/pci/pciide.c
parent2e3249ac0bb20e6fccf3530d313e189225a9f6fb (diff)
Replace VIA SATA chip map routine with generic sata_chip_map().
ok grange@
Diffstat (limited to 'sys/dev/pci/pciide.c')
-rw-r--r--sys/dev/pci/pciide.c100
1 files changed, 50 insertions, 50 deletions
diff --git a/sys/dev/pci/pciide.c b/sys/dev/pci/pciide.c
index 754e29591f9..d0ca8b05b4d 100644
--- a/sys/dev/pci/pciide.c
+++ b/sys/dev/pci/pciide.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pciide.c,v 1.189 2005/04/20 00:46:20 jsg Exp $ */
+/* $OpenBSD: pciide.c,v 1.190 2005/04/20 00:53:11 jsg Exp $ */
/* $NetBSD: pciide.c,v 1.127 2001/08/03 01:31:08 tsutsui Exp $ */
/*
@@ -154,6 +154,7 @@ pciide_pci_write(pci_chipset_tag_t pc, pcitag_t pa, int reg, u_int8_t val)
void default_chip_map(struct pciide_softc *, struct pci_attach_args *);
+void sata_chip_map(struct pciide_softc *, struct pci_attach_args *);
void sata_setup_channel(struct channel_softc *);
void piix_chip_map(struct pciide_softc *, struct pci_attach_args *);
@@ -168,7 +169,6 @@ void amd756_chip_map(struct pciide_softc *, struct pci_attach_args *);
void amd756_setup_channel(struct channel_softc *);
void apollo_chip_map(struct pciide_softc *, struct pci_attach_args *);
-void apollo_sata_chip_map(struct pciide_softc *, struct pci_attach_args *);
void apollo_setup_channel(struct channel_softc *);
void cmd_chip_map(struct pciide_softc *, struct pci_attach_args *);
@@ -472,7 +472,7 @@ const struct pciide_product_desc pciide_via_products[] = {
},
{ PCI_PRODUCT_VIATECH_VT8237_SATA, /* VIA VT8237 SATA */
IDE_PCI_CLASS_OVERRIDE,
- apollo_sata_chip_map
+ sata_chip_map
}
};
@@ -1666,6 +1666,53 @@ next:
}
void
+sata_chip_map(struct pciide_softc *sc, struct pci_attach_args *pa)
+{
+ struct pciide_channel *cp;
+ pcireg_t interface = PCI_INTERFACE(pa->pa_class);
+ int channel;
+ bus_size_t cmdsize, ctlsize;
+
+ if (pciide_chipen(sc, pa) == 0)
+ return;
+
+ if (interface == 0) {
+ WDCDEBUG_PRINT(("sata_chip_map interface == 0\n"),
+ DEBUG_PROBE);
+ interface = PCIIDE_INTERFACE_BUS_MASTER_DMA |
+ PCIIDE_INTERFACE_PCI(0) | PCIIDE_INTERFACE_PCI(1);
+ }
+
+ printf(": DMA");
+ pciide_mapreg_dma(sc, pa);
+ printf("\n");
+
+ if (sc->sc_dma_ok) {
+ sc->sc_wdcdev.cap |= WDC_CAPABILITY_UDMA |
+ WDC_CAPABILITY_DMA | WDC_CAPABILITY_IRQACK;
+ sc->sc_wdcdev.irqack = pciide_irqack;
+ }
+ sc->sc_wdcdev.PIO_cap = 4;
+ sc->sc_wdcdev.DMA_cap = 2;
+ sc->sc_wdcdev.UDMA_cap = 6;
+
+ sc->sc_wdcdev.channels = sc->wdc_chanarray;
+ sc->sc_wdcdev.nchannels = PCIIDE_NUM_CHANNELS;
+ sc->sc_wdcdev.cap |= WDC_CAPABILITY_DATA16 | WDC_CAPABILITY_DATA32 |
+ WDC_CAPABILITY_MODE | WDC_CAPABILITY_SATA;
+ sc->sc_wdcdev.set_modes = sata_setup_channel;
+
+ for (channel = 0; channel < sc->sc_wdcdev.nchannels; channel++) {
+ cp = &sc->pciide_channels[channel];
+ if (pciide_chansetup(sc, channel, interface) == 0)
+ continue;
+ pciide_mapchan(pa, cp, interface, &cmdsize, &ctlsize,
+ pciide_pci_intr);
+ sata_setup_channel(&cp->wdc_channel);
+ }
+}
+
+void
sata_setup_channel(struct channel_softc *chp)
{
struct ata_drive_datas *drvp;
@@ -2580,53 +2627,6 @@ next:
}
void
-apollo_sata_chip_map(struct pciide_softc *sc, struct pci_attach_args *pa)
-{
- struct pciide_channel *cp;
- pcireg_t interface = PCI_INTERFACE(pa->pa_class);
- int channel;
- bus_size_t cmdsize, ctlsize;
-
- if (pciide_chipen(sc, pa) == 0)
- return;
-
- if (interface == 0) {
- WDCDEBUG_PRINT(("apollo_sata_chip_map interface == 0\n"),
- DEBUG_PROBE);
- interface = PCIIDE_INTERFACE_BUS_MASTER_DMA |
- PCIIDE_INTERFACE_PCI(0) | PCIIDE_INTERFACE_PCI(1);
- }
-
- printf(": DMA");
- pciide_mapreg_dma(sc, pa);
- printf("\n");
-
- if (sc->sc_dma_ok) {
- sc->sc_wdcdev.cap |= WDC_CAPABILITY_UDMA |
- WDC_CAPABILITY_DMA | WDC_CAPABILITY_IRQACK;
- sc->sc_wdcdev.irqack = pciide_irqack;
- }
- sc->sc_wdcdev.PIO_cap = 4;
- sc->sc_wdcdev.DMA_cap = 2;
- sc->sc_wdcdev.UDMA_cap = 6;
-
- sc->sc_wdcdev.channels = sc->wdc_chanarray;
- sc->sc_wdcdev.nchannels = PCIIDE_NUM_CHANNELS;
- sc->sc_wdcdev.cap |= WDC_CAPABILITY_DATA16 | WDC_CAPABILITY_DATA32 |
- WDC_CAPABILITY_MODE | WDC_CAPABILITY_SATA;
- sc->sc_wdcdev.set_modes = sata_setup_channel;
-
- for (channel = 0; channel < sc->sc_wdcdev.nchannels; channel++) {
- cp = &sc->pciide_channels[channel];
- if (pciide_chansetup(sc, channel, interface) == 0)
- continue;
- pciide_mapchan(pa, cp, interface, &cmdsize, &ctlsize,
- pciide_pci_intr);
- sata_setup_channel(&cp->wdc_channel);
- }
-}
-
-void
apollo_setup_channel(struct channel_softc *chp)
{
u_int32_t udmatim_reg, datatim_reg;