---

I took a stab at impl. IFF_UNICAST_FLT as an exercise but I
didn't get around to test it. So I figured perhaps someone else
wants/need it so here is a start. With any luck it will work
as is. This is on 3.0 so it might not apply without tweaks.

 drivers/net/ethernet/freescale/ucc_geth.c | 22 ++++++++++++++++++++--
 1 file changed, 20 insertions(+), 2 deletions(-)

diff --git a/drivers/net/ethernet/freescale/ucc_geth.c 
b/drivers/net/ethernet/freescale/ucc_geth.c
index 3d92823..c6eac9b 100644
--- a/drivers/net/ethernet/freescale/ucc_geth.c
+++ b/drivers/net/ethernet/freescale/ucc_geth.c
@@ -2039,12 +2039,13 @@ static void ucc_geth_memclean(struct ucc_geth_private 
*ugeth)
        skb_queue_purge(&ugeth->rx_recycle);
 }
 
-static void ucc_geth_set_multi(struct net_device *dev)
+static void ucc_geth_set_rx_mode(struct net_device *dev)
 {
        struct ucc_geth_private *ugeth;
        struct netdev_hw_addr *ha;
        struct ucc_fast __iomem *uf_regs;
        struct ucc_geth_82xx_address_filtering_pram __iomem *p_82xx_addr_filt;
+       int i;
 
        ugeth = netdev_priv(dev);
 
@@ -2059,6 +2060,22 @@ static void ucc_geth_set_multi(struct net_device *dev)
                    (struct ucc_geth_82xx_address_filtering_pram __iomem *) 
ugeth->
                    p_rx_glbl_pram->addressfiltering;
 
+               /* Clear filter and add the addresses in the list.
+                */
+               out_be32(&p_82xx_addr_filt->iaddr_h, 0x0);
+               out_be32(&p_82xx_addr_filt->iaddr_l, 0x0);
+               i = 0;
+               netdev_for_each_uc_addr(ha, dev) {
+                       if ( i < NUM_OF_PADDRS )
+                               set_mac_addr(&p_82xx_addr_filt->paddr[i].h, 
ha->addr);
+                       else
+                               hw_add_addr_in_hash(ugeth, ha->addr);
+                       i++;
+               }
+               /* Pad remaining entries with station address */
+               for(; i < NUM_OF_PADDRS; i++)
+                       set_mac_addr(&p_82xx_addr_filt->paddr[i].h, 
dev->dev_addr);
+
                if (dev->flags & IFF_ALLMULTI) {
                        /* Catch all multicast addresses, so set the
                         * filter to all 1's.
@@ -3807,7 +3824,7 @@ static const struct net_device_ops ucc_geth_netdev_ops = {
        .ndo_validate_addr      = eth_validate_addr,
        .ndo_set_mac_address    = ucc_geth_set_mac_addr,
        .ndo_change_mtu         = eth_change_mtu,
-       .ndo_set_rx_mode        = ucc_geth_set_multi,
+       .ndo_set_rx_mode        = ucc_geth_set_rx_mode,
        .ndo_tx_timeout         = ucc_geth_timeout,
        .ndo_do_ioctl           = ucc_geth_ioctl,
 #ifdef CONFIG_NET_POLL_CONTROLLER
@@ -4017,6 +4034,7 @@ static int ucc_geth_probe(struct platform_device* ofdev)
        ugeth->msg_enable = netif_msg_init(debug.msg_enable, UGETH_MSG_DEFAULT);
        ugeth->phy_interface = phy_interface;
        ugeth->max_speed = max_speed;
+       dev->priv_flags |= IFF_UNICAST_FLT;
 
        err = register_netdev(dev);
        if (err) {
-- 
1.8.1.5

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to