Skip to content

Commit 8f83828

Browse files
zonquedavem330
authored andcommitted
net: of_mdio: factor out code to parse a phy's 'reg' property
Factor out some logic into of_mdio_parse_addr() so it can be reused later. While at it, use of_property_read_u32() rather than open-coding the same logic again. Signed-off-by: Daniel Mack <zonque@gmail.com> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 6623b41 commit 8f83828

File tree

1 file changed

+23
-12
lines changed

1 file changed

+23
-12
lines changed

drivers/of/of_mdio.c

Lines changed: 23 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -88,6 +88,27 @@ static int of_mdiobus_register_phy(struct mii_bus *mdio, struct device_node *chi
8888
return 0;
8989
}
9090

91+
static int of_mdio_parse_addr(struct device *dev, const struct device_node *np)
92+
{
93+
u32 addr;
94+
int ret;
95+
96+
ret = of_property_read_u32(np, "reg", &addr);
97+
if (ret < 0) {
98+
dev_err(dev, "%s has invalid PHY address\n", np->full_name);
99+
return ret;
100+
}
101+
102+
/* A PHY must have a reg property in the range [0-31] */
103+
if (addr >= PHY_MAX_ADDR) {
104+
dev_err(dev, "%s PHY address %i is too large\n",
105+
np->full_name, addr);
106+
return -EINVAL;
107+
}
108+
109+
return addr;
110+
}
111+
91112
/**
92113
* of_mdiobus_register - Register mii_bus and create PHYs from the device tree
93114
* @mdio: pointer to mii_bus structure
@@ -122,19 +143,9 @@ int of_mdiobus_register(struct mii_bus *mdio, struct device_node *np)
122143

123144
/* Loop over the child nodes and register a phy_device for each one */
124145
for_each_available_child_of_node(np, child) {
125-
/* A PHY must have a reg property in the range [0-31] */
126-
paddr = of_get_property(child, "reg", &len);
127-
if (!paddr || len < sizeof(*paddr)) {
146+
addr = of_mdio_parse_addr(&mdio->dev, child);
147+
if (addr < 0) {
128148
scanphys = true;
129-
dev_err(&mdio->dev, "%s has invalid PHY address\n",
130-
child->full_name);
131-
continue;
132-
}
133-
134-
addr = be32_to_cpup(paddr);
135-
if (addr >= PHY_MAX_ADDR) {
136-
dev_err(&mdio->dev, "%s PHY address %i is too large\n",
137-
child->full_name, addr);
138149
continue;
139150
}
140151

0 commit comments

Comments
 (0)