diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2009-10-30 10:51:13 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-11-02 02:55:09 -0500 |
commit | 9fdce099bb72df534daa6193318feaec177998fc (patch) | |
tree | 3fc660ba2342e4e65a9d38b56a19a67a97fd6bba /net/core/dev.c | |
parent | 72c9528bab94cc052d00ce241b8e85f5d71e45f0 (diff) |
veth: Fix unregister_netdevice_queue for veth
I tested the recent unregister many changes and got a weird,
nasty and seemingly unrelasted kernel oops. Changing
unregister_netdevice_queue to use list_move_tail fixes
the problem for me.
ip link add type veth
rmmod veth
ls /sys/class/net/
showed one of the veth devices still present.
A subsequent ip link oopsed the box.
Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
Acked-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/dev.c')
-rw-r--r-- | net/core/dev.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/net/core/dev.c b/net/core/dev.c index f54d8b8a434b..3c40d545a035 100644 --- a/net/core/dev.c +++ b/net/core/dev.c | |||
@@ -5258,6 +5258,7 @@ struct net_device *alloc_netdev_mq(int sizeof_priv, const char *name, | |||
5258 | netdev_init_queues(dev); | 5258 | netdev_init_queues(dev); |
5259 | 5259 | ||
5260 | INIT_LIST_HEAD(&dev->napi_list); | 5260 | INIT_LIST_HEAD(&dev->napi_list); |
5261 | INIT_LIST_HEAD(&dev->unreg_list); | ||
5261 | dev->priv_flags = IFF_XMIT_DST_RELEASE; | 5262 | dev->priv_flags = IFF_XMIT_DST_RELEASE; |
5262 | setup(dev); | 5263 | setup(dev); |
5263 | strcpy(dev->name, name); | 5264 | strcpy(dev->name, name); |
@@ -5339,7 +5340,7 @@ void unregister_netdevice_queue(struct net_device *dev, struct list_head *head) | |||
5339 | ASSERT_RTNL(); | 5340 | ASSERT_RTNL(); |
5340 | 5341 | ||
5341 | if (head) { | 5342 | if (head) { |
5342 | list_add_tail(&dev->unreg_list, head); | 5343 | list_move_tail(&dev->unreg_list, head); |
5343 | } else { | 5344 | } else { |
5344 | rollback_registered(dev); | 5345 | rollback_registered(dev); |
5345 | /* Finish processing unregister after unlock */ | 5346 | /* Finish processing unregister after unlock */ |