PERFORCE change 101031 for review
Warner Losh
imp at FreeBSD.org
Sat Jul 8 16:37:20 UTC 2006
http://perforce.freebsd.org/chv.cgi?CH=101031
Change 101031 by imp at imp_lighthouse on 2006/07/08 16:36:41
First steps towards making the hinted device enumeration stuff
more generic.
Affected files ...
.. //depot/projects/arm/src/sys/kern/bus_if.m#2 edit
.. //depot/projects/arm/src/sys/kern/subr_bus.c#9 edit
.. //depot/projects/arm/src/sys/sys/bus.h#5 edit
Differences ...
==== //depot/projects/arm/src/sys/kern/bus_if.m#2 (text+ko) ====
@@ -507,3 +507,25 @@
enum intr_trigger _trig;
enum intr_polarity _pol;
} DEFAULT bus_generic_config_intr;
+
+/**
+ * @brief Notify a (bus) driver about a child that the hints mechanism
+ * believes it has discovered.
+ *
+ * The bus is responsible for then adding the child in the right order
+ * and discovering other things about the child. The bus driver is
+ * free to ignore this hint, to do special things, etc. It is all up
+ * to the bus driver to interpret.
+ *
+ * This method is only called in response to the parent bus asking for
+ * hinted devices to be enumerated.
+ *
+ * @param _dev the bus device
+ * @param _dname the name of the device w/o unit numbers
+ * @param _dunit the unit number of the device
+ */
+METHOD void hinted_child {
+ device_t _dev;
+ const char * _dname;
+ int _dunit;
+};
==== //depot/projects/arm/src/sys/kern/subr_bus.c#9 (text+ko) ====
@@ -3799,6 +3799,40 @@
return (error);
}
+/**
+ * @brief Enumerate all hinted devices for this bus.
+ *
+ * Walks throught he hints for this bus and calls the bus_hinted_child
+ * routine for each one it fines. It searches first for the specific
+ * bus that's being probed for hinted children (eg isa0), and then for
+ * generic children (eg isa).
+ *
+ * @param dev bus device to enumerate
+ */
+void
+bus_enumerate_hinted_children(device_t bus)
+{
+ int i;
+ const char *dname, *busname;
+ int dunit;
+
+ /*
+ * enumerate all devices on the specific bus
+ */
+ busname = device_get_nameunit(bus);
+ i = 0;
+ while (resource_find_match(&i, &dname, &dunit, "at", busname) == 0)
+ BUS_HINTED_CHILD(bus, dname, dunit);
+
+ /*
+ * and all the generic ones.
+ */
+ busname = device_get_name(bus);
+ i = 0;
+ while (resource_find_match(&i, &dname, &dunit, "at", busname) == 0)
+ BUS_HINTED_CHILD(bus, dname, dunit);
+}
+
#ifdef BUS_DEBUG
/* the _short versions avoid iteration by not calling anything that prints
==== //depot/projects/arm/src/sys/sys/bus.h#5 (text+ko) ====
@@ -322,6 +322,7 @@
int bus_child_present(device_t child);
int bus_child_pnpinfo_str(device_t child, char *buf, size_t buflen);
int bus_child_location_str(device_t child, char *buf, size_t buflen);
+void bus_enumerate_hinted_children(device_t bus);
static __inline struct resource *
bus_alloc_resource_any(device_t dev, int type, int *rid, u_int flags)
More information about the p4-projects
mailing list