macvlan: Fix memleak on device removal/crash on module removal
As noticed by Ben Greear, macvlan crashes the kernel when unloading the module. The reason is that it tries to clean up the macvlan_port pointer on the macvlan device itself instead of the underlying device. A non-NULL pointer is taken as indication that the macvlan_handle_frame_hook is valid, when receiving the next packet on the underlying device it tries to call the NULL hook and crashes. Clean up the macvlan_port on the correct device to fix this. Signed-off-by; Patrick McHardy <kaber@trash.net> Tested-by: Ben Greear <greearb@candelatech.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
c67fa02799
commit
7312096454
|
@ -450,7 +450,7 @@ static void macvlan_dellink(struct net_device *dev)
|
||||||
unregister_netdevice(dev);
|
unregister_netdevice(dev);
|
||||||
|
|
||||||
if (list_empty(&port->vlans))
|
if (list_empty(&port->vlans))
|
||||||
macvlan_port_destroy(dev);
|
macvlan_port_destroy(port->dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct rtnl_link_ops macvlan_link_ops __read_mostly = {
|
static struct rtnl_link_ops macvlan_link_ops __read_mostly = {
|
||||||
|
|
Loading…
Reference in New Issue