diff options
author | David Daney <david.daney@cavium.com> | 2012-05-02 11:16:37 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-05-07 22:58:09 -0400 |
commit | 251060220021283eef3652145a41f5b26db97ce5 (patch) | |
tree | e04d2a1695e19e959873cf8a6d571a925ca59cc5 /drivers/net | |
parent | 7dc2ce5f12cb5d166140820d5063027dc2449ac1 (diff) |
netdev/of/phy: New function: of_mdio_find_bus().
Add of_mdio_find_bus() which allows an mii_bus to be located given its
associated the device tree node.
This is needed by the follow-on patch to add a driver for MDIO bus
multiplexers.
The of_mdiobus_register() function is modified so that the device tree
node is recorded in the mii_bus. Then we can find it again by
iterating over all mdio_bus_class devices.
Because the OF device tree has now become an integral part of the
kernel, this can live in mdio_bus.c (which contains the needed
mdio_bus_class structure) instead of of_mdio.c.
Signed-off-by: David Daney <david.daney@cavium.com>
Cc: Grant Likely <grant.likely@secretlab.ca>
Cc: "David S. Miller" <davem@davemloft.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/phy/mdio_bus.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/drivers/net/phy/mdio_bus.c b/drivers/net/phy/mdio_bus.c index 8985cc62cf41..83d5c9f55686 100644 --- a/drivers/net/phy/mdio_bus.c +++ b/drivers/net/phy/mdio_bus.c | |||
@@ -88,6 +88,38 @@ static struct class mdio_bus_class = { | |||
88 | .dev_release = mdiobus_release, | 88 | .dev_release = mdiobus_release, |
89 | }; | 89 | }; |
90 | 90 | ||
91 | #ifdef CONFIG_OF_MDIO | ||
92 | /* Helper function for of_mdio_find_bus */ | ||
93 | static int of_mdio_bus_match(struct device *dev, void *mdio_bus_np) | ||
94 | { | ||
95 | return dev->of_node == mdio_bus_np; | ||
96 | } | ||
97 | /** | ||
98 | * of_mdio_find_bus - Given an mii_bus node, find the mii_bus. | ||
99 | * @mdio_np: Pointer to the mii_bus. | ||
100 | * | ||
101 | * Returns a pointer to the mii_bus, or NULL if none found. | ||
102 | * | ||
103 | * Because the association of a device_node and mii_bus is made via | ||
104 | * of_mdiobus_register(), the mii_bus cannot be found before it is | ||
105 | * registered with of_mdiobus_register(). | ||
106 | * | ||
107 | */ | ||
108 | struct mii_bus *of_mdio_find_bus(struct device_node *mdio_bus_np) | ||
109 | { | ||
110 | struct device *d; | ||
111 | |||
112 | if (!mdio_bus_np) | ||
113 | return NULL; | ||
114 | |||
115 | d = class_find_device(&mdio_bus_class, NULL, mdio_bus_np, | ||
116 | of_mdio_bus_match); | ||
117 | |||
118 | return d ? to_mii_bus(d) : NULL; | ||
119 | } | ||
120 | EXPORT_SYMBOL(of_mdio_find_bus); | ||
121 | #endif | ||
122 | |||
91 | /** | 123 | /** |
92 | * mdiobus_register - bring up all the PHYs on a given bus and attach them to bus | 124 | * mdiobus_register - bring up all the PHYs on a given bus and attach them to bus |
93 | * @bus: target mii_bus | 125 | * @bus: target mii_bus |