summaryrefslogtreecommitdiff
path: root/sys/dev/pci
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/pci')
-rw-r--r--sys/dev/pci/pci.c30
-rw-r--r--sys/dev/pci/pcivar.h3
2 files changed, 8 insertions, 25 deletions
diff --git a/sys/dev/pci/pci.c b/sys/dev/pci/pci.c
index b897f7b15e4..ed49597d71a 100644
--- a/sys/dev/pci/pci.c
+++ b/sys/dev/pci/pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci.c,v 1.34 2004/06/25 08:57:10 art Exp $ */
+/* $OpenBSD: pci.c,v 1.35 2004/12/07 02:11:24 brad Exp $ */
/* $NetBSD: pci.c,v 1.31 1997/06/06 23:48:04 thorpej Exp $ */
/*
@@ -74,8 +74,10 @@ int pciprint(void *, const char *);
int pcisubmatch(struct device *, void *, void *);
/*
- * Callback so that ISA/EISA bridges can attach their child busses
- * after PCI configuration is done.
+ * Important note about PCI-ISA bridges:
+ *
+ * Callbacks are used to configure these devices so that ISA/EISA bridges
+ * can attach their child busses after PCI configuration is done.
*
* This works because:
* (1) there can be at most one ISA/EISA bridge per PCI bus, and
@@ -93,9 +95,9 @@ int pcisubmatch(struct device *, void *, void *);
* and the bridge is seen before the video board is, the board can show
* up as an ISA device, and that can (bogusly) complicate the PCI device's
* attach code, or make the PCI device not be properly attached at all.
+ *
+ * We use the generic config_defer() facility to achieve this.
*/
-static void (*pci_isa_bridge_callback)(void *);
-static void *pci_isa_bridge_callback_arg;
int
pcimatch(parent, match, aux)
@@ -159,9 +161,6 @@ pciattach(parent, self, aux)
sc->sc_bus = bus;
#endif
- if (bus == 0)
- pci_isa_bridge_callback = NULL;
-
#ifdef __PCI_BUS_DEVORDER
pci_bus_devorder(pc, bus, devs);
for (i = 0; (device = devs[i]) < 32 && device >= 0; i++) {
@@ -279,9 +278,6 @@ pciattach(parent, self, aux)
config_found_sm(self, &pa, pciprint, pcisubmatch);
}
}
-
- if (bus == 0 && pci_isa_bridge_callback != NULL)
- (*pci_isa_bridge_callback)(pci_isa_bridge_callback_arg);
}
int
@@ -343,18 +339,6 @@ pcisubmatch(parent, match, aux)
return (success);
}
-void
-set_pci_isa_bridge_callback(fn, arg)
- void (*fn)(void *);
- void *arg;
-{
-
- if (pci_isa_bridge_callback != NULL)
- panic("set_pci_isa_bridge_callback");
- pci_isa_bridge_callback = fn;
- pci_isa_bridge_callback_arg = arg;
-}
-
int
pci_get_capability(pc, tag, capid, offset, value)
pci_chipset_tag_t pc;
diff --git a/sys/dev/pci/pcivar.h b/sys/dev/pci/pcivar.h
index b0a23f05e87..a0dc1209041 100644
--- a/sys/dev/pci/pcivar.h
+++ b/sys/dev/pci/pcivar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: pcivar.h,v 1.39 2004/11/30 22:30:47 mickey Exp $ */
+/* $OpenBSD: pcivar.h,v 1.40 2004/12/07 02:11:24 brad Exp $ */
/* $NetBSD: pcivar.h,v 1.23 1997/06/06 23:48:05 thorpej Exp $ */
/*
@@ -208,7 +208,6 @@ int pci_matchbyid(struct pci_attach_args *, const struct pci_matchid *, int);
*/
const char *pci_findvendor(pcireg_t);
void pci_devinfo(pcireg_t, pcireg_t, int, char *, size_t);
-void set_pci_isa_bridge_callback(void (*)(void *), void *);
const struct pci_quirkdata *
pci_lookup_quirkdata(pci_vendor_id_t, pci_product_id_t);
void pciagp_set_pchb(struct pci_attach_args *);