diff options
author | Krzysztof Halasa <khc@pm.waw.pl> | 2008-12-17 00:24:13 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-12-17 00:24:13 -0800 |
commit | e8e5752dc0a56a01527055b0c37510b1d6b6b861 (patch) | |
tree | 65066b89fe67651445f25d586db615c3fbbcf81c | |
parent | 9a3de25544dadab1971847f28f33b1cd0d1770a6 (diff) | |
download | kernel_samsung_smdk4412-e8e5752dc0a56a01527055b0c37510b1d6b6b861.zip kernel_samsung_smdk4412-e8e5752dc0a56a01527055b0c37510b1d6b6b861.tar.gz kernel_samsung_smdk4412-e8e5752dc0a56a01527055b0c37510b1d6b6b861.tar.bz2 |
net: kernel BUG at drivers/net/phy/mdio_bus.c:165!
kernel BUG at drivers/net/phy/mdio_bus.c:165!
Unable to handle kernel NULL pointer dereference at virtual address 00000000
How?
mdiobus_alloc() sets bus->state = MDIOBUS_ALLOCATED.
mdiobus_register() sets bus->state = MDIOBUS_REGISTERED but then can
fail (mdiobus_scan()) returning an error to the caller.
The caller aborts correctly with mdiobus_free() which does:
if (bus->state == MDIOBUS_ALLOCATED) {
kfree(bus);
return;
}
BUG_ON(bus->state != MDIOBUS_UNREGISTERED);
Signed-off-by: Krzysztof Halasa <khc@pm.waw.pl>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/phy/mdio_bus.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/net/phy/mdio_bus.c b/drivers/net/phy/mdio_bus.c index 536bda1..289fc26 100644 --- a/drivers/net/phy/mdio_bus.c +++ b/drivers/net/phy/mdio_bus.c @@ -105,8 +105,6 @@ int mdiobus_register(struct mii_bus *bus) return -EINVAL; } - bus->state = MDIOBUS_REGISTERED; - mutex_init(&bus->mdio_lock); if (bus->reset) @@ -123,6 +121,9 @@ int mdiobus_register(struct mii_bus *bus) } } + if (!err) + bus->state = MDIOBUS_REGISTERED; + pr_info("%s: probed\n", bus->name); return err; |