[NET]: merge dev_unicast_discard and dev_mc_discard into one
authorDenis Cheng <crquan@gmail.com>
Wed, 18 Jul 2007 09:12:03 +0000 (02:12 -0700)
committerDavid S. Miller <davem@davemloft.net>
Wed, 18 Jul 2007 09:12:03 +0000 (02:12 -0700)
this two functions could share the dev->_xmit_lock acquired context.

Signed-off-by: Denis Cheng <crquan@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/dev.c

index 3ba63aaa3001737adc66d7d9feba6317e5674aeb..17c9cbd77eb03ac4c9733e024125091afe88cf0b 100644 (file)
@@ -2777,23 +2777,16 @@ int dev_unicast_add(struct net_device *dev, void *addr, int alen)
 }
 EXPORT_SYMBOL(dev_unicast_add);
 
-static void dev_unicast_discard(struct net_device *dev)
+static void dev_addr_discard(struct net_device *dev)
 {
        netif_tx_lock_bh(dev);
+
        __dev_addr_discard(&dev->uc_list);
        dev->uc_count = 0;
-       netif_tx_unlock_bh(dev);
-}
 
-/*
- *     Discard multicast list when a device is downed
- */
-
-static void dev_mc_discard(struct net_device *dev)
-{
-       netif_tx_lock_bh(dev);
        __dev_addr_discard(&dev->mc_list);
        dev->mc_count = 0;
+
        netif_tx_unlock_bh(dev);
 }
 
@@ -3751,8 +3744,7 @@ void unregister_netdevice(struct net_device *dev)
        /*
         *      Flush the unicast and multicast chains
         */
-       dev_unicast_discard(dev);
-       dev_mc_discard(dev);
+       dev_addr_discard(dev);
 
        if (dev->uninit)
                dev->uninit(dev);