diff options
author | gibbs <gibbs@FreeBSD.org> | 2000-01-08 05:31:38 +0000 |
---|---|---|
committer | gibbs <gibbs@FreeBSD.org> | 2000-01-08 05:31:38 +0000 |
commit | f3c1b82030b5c50bbac66d69f9822a85b5dea931 (patch) | |
tree | 67bb2f8b64de4e540fe799bcd7f98c1e7505b442 | |
parent | 5c1350ecfeed4558e209910f1109286cdab3725f (diff) | |
download | FreeBSD-src-f3c1b82030b5c50bbac66d69f9822a85b5dea931.zip FreeBSD-src-f3c1b82030b5c50bbac66d69f9822a85b5dea931.tar.gz |
Turn on parity error reporting before configuring external sram. This
makes it a little easier to notice that parity checking an 8bit sram
isn't working.
Turn on scb and internal data-path parity checking for all pci chips types.
We were only doing this for ultra2 chips.
After clearing the parity interrupt status, clear the BRKADRINT. This
avoids seeing a bogus BRKADRINT interrupt after external SCB probing
once normal interrupts are enabled.
-rw-r--r-- | sys/dev/aic7xxx/ahc_pci.c | 35 | ||||
-rw-r--r-- | sys/pci/ahc_pci.c | 35 |
2 files changed, 42 insertions, 28 deletions
diff --git a/sys/dev/aic7xxx/ahc_pci.c b/sys/dev/aic7xxx/ahc_pci.c index f803bb5..918e91d 100644 --- a/sys/dev/aic7xxx/ahc_pci.c +++ b/sys/dev/aic7xxx/ahc_pci.c @@ -726,13 +726,6 @@ ahc_pci_attach(device_t dev) return (ENXIO); } - /* - * Take a look to see if we have external SRAM. - * We currently do not attempt to use SRAM that is - * shared among multiple controllers. - */ - ahc_probe_ext_scbram(ahc); - if ((ahc->features & AHC_DT) != 0) { u_int optionmode; u_int sfunct; @@ -767,20 +760,22 @@ ahc_pci_attach(device_t dev) */ { u_int8_t sblkctl; + u_int dscommand0; + dscommand0 = ahc_inb(ahc, DSCOMMAND0); + dscommand0 |= DPARCKEN|MPARCKEN; if ((ahc->features & AHC_ULTRA2) != 0) { - u_int dscommand0; /* * DPARCKEN doesn't work correctly on * some MBs so don't use it. */ - dscommand0 = ahc_inb(ahc, DSCOMMAND0); dscommand0 &= ~(USCBSIZE32|DPARCKEN); - dscommand0 |= CACHETHEN|MPARCKEN; - ahc_outb(ahc, DSCOMMAND0, dscommand0); + dscommand0 |= CACHETHEN; } + ahc_outb(ahc, DSCOMMAND0, dscommand0); + /* See if we have an SEEPROM and perform auto-term */ check_extport(ahc, &sxfrctl1); @@ -824,12 +819,20 @@ ahc_pci_attach(device_t dev) ahc->our_id = our_id; } - - printf("%s: %s ", ahc_name(ahc), - ahc_chip_names[ahc->chip & AHC_CHIPID_MASK]); } /* + * Take a look to see if we have external SRAM. + * We currently do not attempt to use SRAM that is + * shared among multiple controllers. + */ + ahc_probe_ext_scbram(ahc); + + + printf("%s: %s ", ahc_name(ahc), + ahc_chip_names[ahc->chip & AHC_CHIPID_MASK]); + + /* * Record our termination setting for the * generic initialization routine. */ @@ -960,7 +963,9 @@ ahc_probe_ext_scbram(struct ahc_softc *ahc) || (ahc_inb(ahc, ERROR) & MPARERR) == 0) pcheck = TRUE; + /* Clear any resulting parity error */ ahc_outb(ahc, CLRINT, CLRPARERR); + ahc_outb(ahc, CLRINT, CLRBRKADRINT); /* Now see if we can do fast timing */ ahc_ext_scbram_config(ahc, enable, pcheck, /*fast*/TRUE); @@ -971,7 +976,9 @@ ahc_probe_ext_scbram(struct ahc_softc *ahc) fast = TRUE; done: + /* Clear any resulting parity error */ ahc_outb(ahc, CLRINT, CLRPARERR); + ahc_outb(ahc, CLRINT, CLRBRKADRINT); if (bootverbose && enable) { printf("%s: External SRAM, %dns access%s\n", ahc_name(ahc), fast ? 10 : 20, diff --git a/sys/pci/ahc_pci.c b/sys/pci/ahc_pci.c index f803bb5..918e91d 100644 --- a/sys/pci/ahc_pci.c +++ b/sys/pci/ahc_pci.c @@ -726,13 +726,6 @@ ahc_pci_attach(device_t dev) return (ENXIO); } - /* - * Take a look to see if we have external SRAM. - * We currently do not attempt to use SRAM that is - * shared among multiple controllers. - */ - ahc_probe_ext_scbram(ahc); - if ((ahc->features & AHC_DT) != 0) { u_int optionmode; u_int sfunct; @@ -767,20 +760,22 @@ ahc_pci_attach(device_t dev) */ { u_int8_t sblkctl; + u_int dscommand0; + dscommand0 = ahc_inb(ahc, DSCOMMAND0); + dscommand0 |= DPARCKEN|MPARCKEN; if ((ahc->features & AHC_ULTRA2) != 0) { - u_int dscommand0; /* * DPARCKEN doesn't work correctly on * some MBs so don't use it. */ - dscommand0 = ahc_inb(ahc, DSCOMMAND0); dscommand0 &= ~(USCBSIZE32|DPARCKEN); - dscommand0 |= CACHETHEN|MPARCKEN; - ahc_outb(ahc, DSCOMMAND0, dscommand0); + dscommand0 |= CACHETHEN; } + ahc_outb(ahc, DSCOMMAND0, dscommand0); + /* See if we have an SEEPROM and perform auto-term */ check_extport(ahc, &sxfrctl1); @@ -824,12 +819,20 @@ ahc_pci_attach(device_t dev) ahc->our_id = our_id; } - - printf("%s: %s ", ahc_name(ahc), - ahc_chip_names[ahc->chip & AHC_CHIPID_MASK]); } /* + * Take a look to see if we have external SRAM. + * We currently do not attempt to use SRAM that is + * shared among multiple controllers. + */ + ahc_probe_ext_scbram(ahc); + + + printf("%s: %s ", ahc_name(ahc), + ahc_chip_names[ahc->chip & AHC_CHIPID_MASK]); + + /* * Record our termination setting for the * generic initialization routine. */ @@ -960,7 +963,9 @@ ahc_probe_ext_scbram(struct ahc_softc *ahc) || (ahc_inb(ahc, ERROR) & MPARERR) == 0) pcheck = TRUE; + /* Clear any resulting parity error */ ahc_outb(ahc, CLRINT, CLRPARERR); + ahc_outb(ahc, CLRINT, CLRBRKADRINT); /* Now see if we can do fast timing */ ahc_ext_scbram_config(ahc, enable, pcheck, /*fast*/TRUE); @@ -971,7 +976,9 @@ ahc_probe_ext_scbram(struct ahc_softc *ahc) fast = TRUE; done: + /* Clear any resulting parity error */ ahc_outb(ahc, CLRINT, CLRPARERR); + ahc_outb(ahc, CLRINT, CLRBRKADRINT); if (bootverbose && enable) { printf("%s: External SRAM, %dns access%s\n", ahc_name(ahc), fast ? 10 : 20, |