aboutsummaryrefslogtreecommitdiffstats
path: root/net/core/dev.c
diff options
context:
space:
mode:
authorEric W. Biederman <ebiederm@xmission.com>2009-10-30 10:51:13 -0400
committerDavid S. Miller <davem@davemloft.net>2009-11-02 02:55:09 -0500
commit9fdce099bb72df534daa6193318feaec177998fc (patch)
tree3fc660ba2342e4e65a9d38b56a19a67a97fd6bba /net/core/dev.c
parent72c9528bab94cc052d00ce241b8e85f5d71e45f0 (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.c3
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 */