aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGiuseppe CAVALLARO <peppe.cavallaro@st.com>2010-01-06 18:07:12 -0500
committerDavid S. Miller <davem@davemloft.net>2010-01-07 20:06:06 -0500
commit609634799eba48bb9e80ce56dfd87930f17bf6fa (patch)
treec64fd4710ca8a2d612623c23d25e34c916b94e93
parent109cdd66485b639b2fbfcbf59ae7ef1286520705 (diff)
stmmac: convert unicast addr list to list_head
This patch converts unicast address list to standard list_head using previously introduced struct netdev_hw_addr. Note: this patch also removes a debug printk used for displaying the mac addresses. Indeed, it's is possible to dump the registers with ethtool. Signed-off-by: Giuseppe Cavallaro <peppe.cavallaro@st.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/stmmac/gmac.c24
1 files changed, 8 insertions, 16 deletions
diff --git a/drivers/net/stmmac/gmac.c b/drivers/net/stmmac/gmac.c
index 52586ee68953..982875646725 100644
--- a/drivers/net/stmmac/gmac.c
+++ b/drivers/net/stmmac/gmac.c
@@ -435,7 +435,7 @@ static void gmac_set_filter(struct net_device *dev)
435 unsigned int value = 0; 435 unsigned int value = 0;
436 436
437 DBG(KERN_INFO "%s: # mcasts %d, # unicast %d\n", 437 DBG(KERN_INFO "%s: # mcasts %d, # unicast %d\n",
438 __func__, dev->mc_count, dev->uc_count); 438 __func__, dev->mc_count, dev->uc.count);
439 439
440 if (dev->flags & IFF_PROMISC) 440 if (dev->flags & IFF_PROMISC)
441 value = GMAC_FRAME_FILTER_PR; 441 value = GMAC_FRAME_FILTER_PR;
@@ -469,25 +469,17 @@ static void gmac_set_filter(struct net_device *dev)
469 } 469 }
470 470
471 /* Handle multiple unicast addresses (perfect filtering)*/ 471 /* Handle multiple unicast addresses (perfect filtering)*/
472 if (dev->uc_count > GMAC_MAX_UNICAST_ADDRESSES) 472 if (dev->uc.count > GMAC_MAX_UNICAST_ADDRESSES)
473 /* Switch to promiscuous mode is more than 16 addrs 473 /* Switch to promiscuous mode is more than 16 addrs
474 are required */ 474 are required */
475 value |= GMAC_FRAME_FILTER_PR; 475 value |= GMAC_FRAME_FILTER_PR;
476 else { 476 else {
477 int i; 477 int reg = 1;
478 struct dev_addr_list *uc_ptr = dev->uc_list; 478 struct netdev_hw_addr *ha;
479 479
480 for (i = 0; i < dev->uc_count; i++) { 480 list_for_each_entry(ha, &dev->uc.list, list) {
481 gmac_set_umac_addr(ioaddr, uc_ptr->da_addr, 481 gmac_set_umac_addr(ioaddr, ha->addr, reg);
482 i + 1); 482 reg++;
483
484 DBG(KERN_INFO "\t%d "
485 "- Unicast addr %02x:%02x:%02x:%02x:%02x:"
486 "%02x\n", i + 1,
487 uc_ptr->da_addr[0], uc_ptr->da_addr[1],
488 uc_ptr->da_addr[2], uc_ptr->da_addr[3],
489 uc_ptr->da_addr[4], uc_ptr->da_addr[5]);
490 uc_ptr = uc_ptr->next;
491 } 483 }
492 } 484 }
493 485