bridge: bad error handling when adding invalid ether address
authorStephen Hemminger <shemminger@vyatta.com>
Thu, 26 Mar 2009 04:01:47 +0000 (21:01 -0700)
committerDavid S. Miller <davem@davemloft.net>
Thu, 26 Mar 2009 04:01:47 +0000 (21:01 -0700)
This fixes an crash when empty bond device is added to a bridge.
If an interface with invalid ethernet address (all zero) is added
to a bridge, then bridge code detects it when setting up the forward
databas entry. But the error unwind is broken, the bridge port object
can get freed twice: once when ref count went to zeo, and once by kfree.
Since object is never really accessible, just free it.

Signed-off-by: Stephen Hemminger <shemminger@vyatta.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/bridge/br_if.c

index 727c5c510a602573b216ec66fb3ce1dbf274b0d5..8a96672e2c5c462fb3f575df3ba4d8c25a03727d 100644 (file)
@@ -426,7 +426,6 @@ err2:
 err1:
        kobject_del(&p->kobj);
 err0:
-       kobject_put(&p->kobj);
        dev_set_promiscuity(dev, -1);
 put_back:
        dev_put(dev);