summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorgibbs <gibbs@FreeBSD.org>2000-01-08 05:31:38 +0000
committergibbs <gibbs@FreeBSD.org>2000-01-08 05:31:38 +0000
commitf3c1b82030b5c50bbac66d69f9822a85b5dea931 (patch)
tree67bb2f8b64de4e540fe799bcd7f98c1e7505b442
parent5c1350ecfeed4558e209910f1109286cdab3725f (diff)
downloadFreeBSD-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.c35
-rw-r--r--sys/pci/ahc_pci.c35
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,
OpenPOWER on IntegriCloud