]> Pileus Git - ~andy/linux/commitdiff
net: depca: Omit check for multicast bit in netdev_for_each_mc_addr
authorTobias Klauser <tklauser@distanz.ch>
Wed, 29 Jun 2011 02:15:15 +0000 (02:15 +0000)
committerDavid S. Miller <davem@davemloft.net>
Fri, 1 Jul 2011 05:13:38 +0000 (22:13 -0700)
There is no need to check for the address being a multicast address in
the netdev_for_each_mc_addr loop, so remove it.

Signed-off-by: Tobias Klauser <tklauser@distanz.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/depca.c

index d54a0e93ba931c5bad50cbb493325c9ef1908764..a7ccaa67c7d421bc6b34f09a4c258c52cb7146e1 100644 (file)
@@ -1270,7 +1270,6 @@ static void SetMulticastFilter(struct net_device *dev)
 {
        struct depca_private *lp = netdev_priv(dev);
        struct netdev_hw_addr *ha;
-       char *addrs;
        int i, j, bit, byte;
        u16 hashcode;
        u32 crc;
@@ -1285,19 +1284,15 @@ static void SetMulticastFilter(struct net_device *dev)
                }
                /* Add multicast addresses */
                netdev_for_each_mc_addr(ha, dev) {
-                       addrs = ha->addr;
-                       if ((*addrs & 0x01) == 1) {     /* multicast address? */
-                               crc = ether_crc(ETH_ALEN, addrs);
-                               hashcode = (crc & 1);   /* hashcode is 6 LSb of CRC ... */
-                               for (j = 0; j < 5; j++) {       /* ... in reverse order. */
-                                       hashcode = (hashcode << 1) | ((crc >>= 1) & 1);
-                               }
-
-
-                               byte = hashcode >> 3;   /* bit[3-5] -> byte in filter */
-                               bit = 1 << (hashcode & 0x07);   /* bit[0-2] -> bit in byte */
-                               lp->init_block.mcast_table[byte] |= bit;
+                       crc = ether_crc(ETH_ALEN, ha->addr);
+                       hashcode = (crc & 1);   /* hashcode is 6 LSb of CRC ... */
+                       for (j = 0; j < 5; j++) {       /* ... in reverse order. */
+                               hashcode = (hashcode << 1) | ((crc >>= 1) & 1);
                        }
+
+                       byte = hashcode >> 3;   /* bit[3-5] -> byte in filter */
+                       bit = 1 << (hashcode & 0x07);   /* bit[0-2] -> bit in byte */
+                       lp->init_block.mcast_table[byte] |= bit;
                }
        }
 }