diff options
author | Grigoriy Orlov <gluk@cvs.openbsd.org> | 2002-07-06 14:35:48 +0000 |
---|---|---|
committer | Grigoriy Orlov <gluk@cvs.openbsd.org> | 2002-07-06 14:35:48 +0000 |
commit | 6a562d6086cddc67b259e043e83a9a3958fa7169 (patch) | |
tree | 26807dcfcbbe1d0e0a3ebc0bd9f3380a0e4ad9e0 /sys/dev/pci/pciide.c | |
parent | 71a7b6dc7e3396d99f0a727e7a8e185d5a162ac6 (diff) |
HPT 372, 372A and 374. Only HPT372 was tested.
Mostly from NetBSD.
deraadt@ ok.
Diffstat (limited to 'sys/dev/pci/pciide.c')
-rw-r--r-- | sys/dev/pci/pciide.c | 72 |
1 files changed, 56 insertions, 16 deletions
diff --git a/sys/dev/pci/pciide.c b/sys/dev/pci/pciide.c index 0638df5f566..edf31294dc2 100644 --- a/sys/dev/pci/pciide.c +++ b/sys/dev/pci/pciide.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pciide.c,v 1.85 2002/06/08 23:32:51 chris Exp $ */ +/* $OpenBSD: pciide.c,v 1.86 2002/07/06 14:35:47 gluk Exp $ */ /* $NetBSD: pciide.c,v 1.127 2001/08/03 01:31:08 tsutsui Exp $ */ /* @@ -420,6 +420,14 @@ const struct pciide_product_desc pciide_triones_products[] = { { PCI_PRODUCT_TRIONES_HPT366, /* Highpoint HPT36x/37x IDE */ IDE_PCI_CLASS_OVERRIDE, hpt_chip_map, + }, + { PCI_PRODUCT_TRIONES_HPT372A, /* Highpoint HPT372A IDE */ + IDE_PCI_CLASS_OVERRIDE, + hpt_chip_map + }, + { PCI_PRODUCT_TRIONES_HPT374, /* Highpoint HPT374 IDE */ + IDE_PCI_CLASS_OVERRIDE, + hpt_chip_map } }; @@ -3466,7 +3474,11 @@ hpt_chip_map(sc, pa) } else { interface = PCIIDE_INTERFACE_BUS_MASTER_DMA | PCIIDE_INTERFACE_PCI(0); - if (revision == HPT370_REV || revision == HPT370A_REV) + if ((sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT366 && + (revision == HPT370_REV || revision == HPT370A_REV || + revision == HPT372_REV)) || + sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT372A || + sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT374) interface |= PCIIDE_INTERFACE_PCI(1); } @@ -3485,7 +3497,8 @@ hpt_chip_map(sc, pa) sc->sc_wdcdev.set_modes = hpt_setup_channel; sc->sc_wdcdev.channels = sc->wdc_chanarray; - if (revision < HPT370_REV) { + if (sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT366 && + revision == HPT366_REV) { sc->sc_wdcdev.UDMA_cap = 4; /* * The 366 has 2 PCI IDE functions, one for primary and one @@ -3504,13 +3517,21 @@ hpt_chip_map(sc, pa) sc->sc_wdcdev.nchannels = 1; } else { sc->sc_wdcdev.nchannels = 2; - /* - * XXX disable udma5 for now. - */ - if (revision == HPT370_REV) - sc->sc_wdcdev.UDMA_cap = 4; - else - sc->sc_wdcdev.UDMA_cap = 5; + if (sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT374 || + sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT372A) + sc->sc_wdcdev.UDMA_cap = 6; + else if (sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT366) { + if (revision == HPT372_REV) + sc->sc_wdcdev.UDMA_cap = 6; + else + sc->sc_wdcdev.UDMA_cap = 5; + if (revision == HPT370_REV) { + /* + * XXX disable udma5 for now. + */ + sc->sc_wdcdev.UDMA_cap = 4; + } + } } for (i = 0; i < sc->sc_wdcdev.nchannels; i++) { cp = &sc->pciide_channels[i]; @@ -3539,15 +3560,28 @@ hpt_chip_map(sc, pa) wdcattach(&cp->wdc_channel); hpt_setup_channel(&cp->wdc_channel); } - if (revision == HPT370_REV || revision == HPT370A_REV) { + if ((sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT366 && + (revision == HPT370_REV || revision == HPT370A_REV || + revision == HPT372_REV)) || + sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT372A || + sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT374) { /* - * HPT370_REV has a bit to disable interrupts, make sure - * to clear it + * HPT370 and highter has a bit to disable interrupts, + * make sure to clear it */ pciide_pci_write(sc->sc_pc, sc->sc_tag, HPT_CSEL, pciide_pci_read(sc->sc_pc, sc->sc_tag, HPT_CSEL) & ~HPT_CSEL_IRQDIS); } + /* set clocks, etc (mandatory on 372/4, optional otherwise) */ + if (sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT372A || + sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT374 || + (sc->sc_pp->ide_product == PCI_PRODUCT_TRIONES_HPT366 && + revision == HPT372_REV)) + pciide_pci_write(sc->sc_pc, sc->sc_tag, HPT_SC2, + (pciide_pci_read(sc->sc_pc, sc->sc_tag, HPT_SC2) & + HPT_SC2_MAEN) | HPT_SC2_OSC_EN); + return; } @@ -3587,7 +3621,9 @@ hpt_setup_channel(chp) drvp->UDMA_mode > 2) drvp->UDMA_mode = 2; after = (sc->sc_wdcdev.nchannels == 2) ? - hpt370_udma[drvp->UDMA_mode] : + ((sc->sc_wdcdev.UDMA_cap == 6) ? + hpt374_udma[drvp->UDMA_mode] : + hpt370_udma[drvp->UDMA_mode]) : hpt366_udma[drvp->UDMA_mode]; idedma_ctl |= IDEDMA_CTL_DRV_DMA(drive); } else if (drvp->drive_flags & DRIVE_DMA) { @@ -3601,13 +3637,17 @@ hpt_setup_channel(chp) drvp->DMA_mode = drvp->PIO_mode - 2; } after = (sc->sc_wdcdev.nchannels == 2) ? - hpt370_dma[drvp->DMA_mode] : + ((sc->sc_wdcdev.UDMA_cap == 6) ? + hpt374_dma[drvp->DMA_mode] : + hpt370_dma[drvp->DMA_mode]) : hpt366_dma[drvp->DMA_mode]; idedma_ctl |= IDEDMA_CTL_DRV_DMA(drive); } else { /* PIO only */ after = (sc->sc_wdcdev.nchannels == 2) ? - hpt370_pio[drvp->PIO_mode] : + ( (sc->sc_wdcdev.UDMA_cap == 6) ? + hpt374_pio[drvp->PIO_mode] : + hpt370_pio[drvp->PIO_mode]) : hpt366_pio[drvp->PIO_mode]; } pci_conf_write(sc->sc_pc, sc->sc_tag, |