summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/hp300/dev/frodo.c66
-rw-r--r--sys/arch/hp300/dev/isabr.c29
2 files changed, 63 insertions, 32 deletions
diff --git a/sys/arch/hp300/dev/frodo.c b/sys/arch/hp300/dev/frodo.c
index e2ee8bfbb9c..2bf757e3938 100644
--- a/sys/arch/hp300/dev/frodo.c
+++ b/sys/arch/hp300/dev/frodo.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: frodo.c,v 1.10 2007/01/06 20:17:43 miod Exp $ */
+/* $OpenBSD: frodo.c,v 1.11 2007/01/14 17:54:45 miod Exp $ */
/* $NetBSD: frodo.c,v 1.5 1999/07/31 21:15:20 thorpej Exp $ */
/*-
@@ -85,6 +85,13 @@
#include "isabr.h"
+#if NISABR > 0
+#include <uvm/uvm_extern.h>
+
+#include <dev/isa/isareg.h>
+#include <hp300/dev/isabrreg.h>
+#endif
+
struct frodo_softc {
struct device sc_dev; /* generic device glue */
volatile u_int8_t *sc_regs; /* register base */
@@ -100,9 +107,9 @@ int frodoprint(void *, const char *);
int frodosubmatch(struct device *, void *, void *);
int frodointr(void *);
-void frodo_state(struct frodo_softc *);
-
void frodo_imask(struct frodo_softc *, u_int16_t, u_int16_t);
+int frodo_isa_exists(void);
+void frodo_state(struct frodo_softc *);
struct cfattach frodo_ca = {
sizeof(struct frodo_softc), frodomatch, frodoattach
@@ -117,7 +124,6 @@ struct frodo_attach_args frodo_subdevs[] = {
{ "apci", NULL, FRODO_APCI_OFFSET(1), FRODO_INTR_APCI1 },
{ "apci", NULL, FRODO_APCI_OFFSET(2), FRODO_INTR_APCI2 },
{ "apci", NULL, FRODO_APCI_OFFSET(3), FRODO_INTR_APCI3 },
- { "isabr", NULL, 0, 0 },
{ NULL, NULL, 0, 0 },
};
@@ -220,6 +226,21 @@ frodoattach(parent, self, aux)
config_found_sm(self, &frodo_subdevs[i],
frodoprint, frodosubmatch);
}
+
+#if NISABR > 0
+ /*
+ * Only attempt to attach the isa bridge if it exists on this
+ * machine.
+ */
+ if (frodo_isa_exists()) {
+ struct frodo_attach_args fa;
+
+ fa.fa_name = "isabr";
+ fa.fa_tag = ia->ia_tag;
+ fa.fa_offset = fa.fa_line = 0;
+ config_found_sm(self, &fa, frodoprint, frodosubmatch);
+ }
+#endif
}
int
@@ -327,7 +348,7 @@ frodo_intr_disestablish(frdev, line)
if (FRODO_INTR_ISA(line)) {
if (sc->sc_intr[FRODO_INTR_ILOW] == NULL &&
sc->sc_intr[FRODO_INTR_IMID] == NULL &&
- sc->sc_intr[FRODO_INTR_IHIGH] == NULL)
+ sc->sc_intr[FRODO_INTR_IHI] == NULL)
FRODO_WRITE(sc, FRODO_PIO_ISA_CONTROL, 0x80);
}
#endif
@@ -434,3 +455,38 @@ frodo_state(struct frodo_softc *sc)
printf("\n");
}
#endif
+
+#if NISABR > 0
+int
+frodo_isa_exists()
+{
+ vaddr_t va;
+ int rv;
+
+ va = uvm_km_valloc(kernel_map, PAGE_SIZE);
+ if (va == NULL)
+ return (0);
+
+ /*
+ * Check that the iomem space answers probes
+ */
+ pmap_kenter_cache(va, ISABR_IOMEM_BASE, PG_RW | PG_CI);
+ pmap_update(pmap_kernel());
+ rv = badbaddr((caddr_t)va);
+ pmap_kremove(va, PAGE_SIZE);
+ pmap_update(pmap_kernel());
+
+ /*
+ * Check that the ioport space answers probes
+ */
+ pmap_kenter_cache(va, ISABR_IOPORT_BASE, PG_RW | PG_CI);
+ pmap_update(pmap_kernel());
+ rv |= badbaddr((caddr_t)va);
+ pmap_kremove(va, PAGE_SIZE);
+ pmap_update(pmap_kernel());
+
+ uvm_km_free(kernel_map, va, PAGE_SIZE);
+
+ return (!rv);
+}
+#endif
diff --git a/sys/arch/hp300/dev/isabr.c b/sys/arch/hp300/dev/isabr.c
index bd87f71378b..10459182fb3 100644
--- a/sys/arch/hp300/dev/isabr.c
+++ b/sys/arch/hp300/dev/isabr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: isabr.c,v 1.1 2007/01/06 20:17:43 miod Exp $ */
+/* $OpenBSD: isabr.c,v 1.2 2007/01/14 17:54:45 miod Exp $ */
/*
* Copyright (c) 2007 Miodrag Vallat.
@@ -68,8 +68,6 @@ int
isabr_match(struct device *parent, void *match, void *aux)
{
struct frodo_attach_args *fa = aux;
- vaddr_t va;
- int rv;
static int isa_matched = 0;
if (isa_matched != 0)
@@ -78,32 +76,9 @@ isabr_match(struct device *parent, void *match, void *aux)
if (strcmp(fa->fa_name, isabr_cd.cd_name) != 0)
return (0);
- va = uvm_km_valloc(kernel_map, PAGE_SIZE);
- if (va == NULL)
- return (0);
-
/*
- * Check that the iomem space answers probes
+ * We assume parent has checked our physical existence for us.
*/
- pmap_kenter_cache(va, ISABR_IOMEM_BASE, PG_RW | PG_CI);
- pmap_update(pmap_kernel());
- rv = badbaddr((caddr_t)va);
- pmap_kremove(va, PAGE_SIZE);
- pmap_update(pmap_kernel());
-
- /*
- * Check that the ioport space answers probes
- */
- pmap_kenter_cache(va, ISABR_IOPORT_BASE, PG_RW | PG_CI);
- pmap_update(pmap_kernel());
- rv |= badbaddr((caddr_t)va);
- pmap_kremove(va, PAGE_SIZE);
- pmap_update(pmap_kernel());
-
- uvm_km_free(kernel_map, va, PAGE_SIZE);
-
- if (rv != 0)
- return (0);
return (isa_matched = 1);
}