diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/smsc911x.c | 27 |
1 files changed, 9 insertions, 18 deletions
diff --git a/drivers/net/smsc911x.c b/drivers/net/smsc911x.c index 13c0b76dec41..4fd1d8b38788 100644 --- a/drivers/net/smsc911x.c +++ b/drivers/net/smsc911x.c | |||
@@ -1383,29 +1383,20 @@ static void smsc911x_set_multicast_list(struct net_device *dev) | |||
1383 | /* Enabling specific multicast addresses */ | 1383 | /* Enabling specific multicast addresses */ |
1384 | unsigned int hash_high = 0; | 1384 | unsigned int hash_high = 0; |
1385 | unsigned int hash_low = 0; | 1385 | unsigned int hash_low = 0; |
1386 | unsigned int count = 0; | 1386 | struct dev_mc_list *mc_list; |
1387 | struct dev_mc_list *mc_list = dev->mc_list; | ||
1388 | 1387 | ||
1389 | pdata->set_bits_mask = MAC_CR_HPFILT_; | 1388 | pdata->set_bits_mask = MAC_CR_HPFILT_; |
1390 | pdata->clear_bits_mask = (MAC_CR_PRMS_ | MAC_CR_MCPAS_); | 1389 | pdata->clear_bits_mask = (MAC_CR_PRMS_ | MAC_CR_MCPAS_); |
1391 | 1390 | ||
1392 | while (mc_list) { | 1391 | netdev_for_each_mc_addr(mc_list, dev) { |
1393 | count++; | 1392 | unsigned int bitnum = smsc911x_hash(mc_list->dmi_addr); |
1394 | if ((mc_list->dmi_addrlen) == ETH_ALEN) { | 1393 | unsigned int mask = 0x01 << (bitnum & 0x1F); |
1395 | unsigned int bitnum = | 1394 | |
1396 | smsc911x_hash(mc_list->dmi_addr); | 1395 | if (bitnum & 0x20) |
1397 | unsigned int mask = 0x01 << (bitnum & 0x1F); | 1396 | hash_high |= mask; |
1398 | if (bitnum & 0x20) | 1397 | else |
1399 | hash_high |= mask; | 1398 | hash_low |= mask; |
1400 | else | ||
1401 | hash_low |= mask; | ||
1402 | } else { | ||
1403 | SMSC_WARNING(DRV, "dmi_addrlen != 6"); | ||
1404 | } | ||
1405 | mc_list = mc_list->next; | ||
1406 | } | 1399 | } |
1407 | if (count != (unsigned int)netdev_mc_count(dev)) | ||
1408 | SMSC_WARNING(DRV, "mc_count != dev->mc_count"); | ||
1409 | 1400 | ||
1410 | pdata->hashhi = hash_high; | 1401 | pdata->hashhi = hash_high; |
1411 | pdata->hashlo = hash_low; | 1402 | pdata->hashlo = hash_low; |