On Thu, Feb 07, 2013 at 01:02:06PM +0100, Jean-Christophe PLAGNIOL-VILLARD wrote: > On 12:09 Thu 07 Feb , Sascha Hauer wrote: > > Signed-off-by: Sascha Hauer <s.hauer@xxxxxxxxxxxxxx> > > --- > > drivers/net/phy/mdio_bus.c | 19 +++++++++++++++++++ > > include/linux/phy.h | 3 +++ > > 2 files changed, 22 insertions(+) > > > > diff --git a/drivers/net/phy/mdio_bus.c b/drivers/net/phy/mdio_bus.c > > index d1d802b..3c4be1c 100644 > > --- a/drivers/net/phy/mdio_bus.c > > +++ b/drivers/net/phy/mdio_bus.c > > @@ -25,6 +25,8 @@ > > #include <linux/phy.h> > > #include <linux/err.h> > > > > +static LIST_HEAD(mii_bus_list); > > + > > /** > > * mdiobus_register - bring up all the PHYs on a given bus and attach them to bus > > * @bus: target mii_bus > > @@ -57,6 +59,8 @@ int mdiobus_register(struct mii_bus *bus) > > if (bus->reset) > > bus->reset(bus); > > > > + list_add_tail(&bus->list, &mii_bus_list); > > + > > pr_info("%s: probed\n", dev_name(&bus->dev)); > > return 0; > > } > > @@ -71,9 +75,24 @@ void mdiobus_unregister(struct mii_bus *bus) > > unregister_device(&bus->phy_map[i]->dev); > > bus->phy_map[i] = NULL; > > } > > + > > + list_del(&bus->list); > > } > > EXPORT_SYMBOL(mdiobus_unregister); > > > > +struct mii_bus *mdiobus_find(const char *name) > > +{ > > + struct mii_bus *bus; > > + > > + list_for_each_entry(bus, &mii_bus_list, list) { > no use bus_for_each That was my first try until I realized that not the mdio buses are registered on the mdio_bus_type, but instead the phy devices. Sascha -- Pengutronix e.K. | | Industrial Linux Solutions | http://www.pengutronix.de/ | Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 | _______________________________________________ barebox mailing list barebox@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/barebox