aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/yellowfin.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/yellowfin.c')
-rw-r--r--drivers/net/yellowfin.c13
1 files changed, 6 insertions, 7 deletions
diff --git a/drivers/net/yellowfin.c b/drivers/net/yellowfin.c
index ede5b2436f22..4eb67aed68dd 100644
--- a/drivers/net/yellowfin.c
+++ b/drivers/net/yellowfin.c
@@ -564,7 +564,6 @@ static void mdio_write(void __iomem *ioaddr, int phy_id, int location, int value
564 for (i = 10000; i >= 0; i--) 564 for (i = 10000; i >= 0; i--)
565 if ((ioread16(ioaddr + MII_Status) & 1) == 0) 565 if ((ioread16(ioaddr + MII_Status) & 1) == 0)
566 break; 566 break;
567 return;
568} 567}
569 568
570 569
@@ -1299,25 +1298,25 @@ static void set_rx_mode(struct net_device *dev)
1299 /* Too many to filter well, or accept all multicasts. */ 1298 /* Too many to filter well, or accept all multicasts. */
1300 iowrite16(0x000B, ioaddr + AddrMode); 1299 iowrite16(0x000B, ioaddr + AddrMode);
1301 } else if (!netdev_mc_empty(dev)) { /* Must use the multicast hash table. */ 1300 } else if (!netdev_mc_empty(dev)) { /* Must use the multicast hash table. */
1302 struct dev_mc_list *mclist; 1301 struct netdev_hw_addr *ha;
1303 u16 hash_table[4]; 1302 u16 hash_table[4];
1304 int i; 1303 int i;
1305 1304
1306 memset(hash_table, 0, sizeof(hash_table)); 1305 memset(hash_table, 0, sizeof(hash_table));
1307 netdev_for_each_mc_addr(mclist, dev) { 1306 netdev_for_each_mc_addr(ha, dev) {
1308 unsigned int bit; 1307 unsigned int bit;
1309 1308
1310 /* Due to a bug in the early chip versions, multiple filter 1309 /* Due to a bug in the early chip versions, multiple filter
1311 slots must be set for each address. */ 1310 slots must be set for each address. */
1312 if (yp->drv_flags & HasMulticastBug) { 1311 if (yp->drv_flags & HasMulticastBug) {
1313 bit = (ether_crc_le(3, mclist->dmi_addr) >> 3) & 0x3f; 1312 bit = (ether_crc_le(3, ha->addr) >> 3) & 0x3f;
1314 hash_table[bit >> 4] |= (1 << bit); 1313 hash_table[bit >> 4] |= (1 << bit);
1315 bit = (ether_crc_le(4, mclist->dmi_addr) >> 3) & 0x3f; 1314 bit = (ether_crc_le(4, ha->addr) >> 3) & 0x3f;
1316 hash_table[bit >> 4] |= (1 << bit); 1315 hash_table[bit >> 4] |= (1 << bit);
1317 bit = (ether_crc_le(5, mclist->dmi_addr) >> 3) & 0x3f; 1316 bit = (ether_crc_le(5, ha->addr) >> 3) & 0x3f;
1318 hash_table[bit >> 4] |= (1 << bit); 1317 hash_table[bit >> 4] |= (1 << bit);
1319 } 1318 }
1320 bit = (ether_crc_le(6, mclist->dmi_addr) >> 3) & 0x3f; 1319 bit = (ether_crc_le(6, ha->addr) >> 3) & 0x3f;
1321 hash_table[bit >> 4] |= (1 << bit); 1320 hash_table[bit >> 4] |= (1 << bit);
1322 } 1321 }
1323 /* Copy the hash table to the chip. */ 1322 /* Copy the hash table to the chip. */