net: stmmac: fix missing IFF_MULTICAST check in dwmac4_set_filter
authorVerma, Aashish <aashishx.verma@intel.com>
Fri, 7 Feb 2020 07:33:54 +0000 (15:33 +0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 7 Feb 2020 10:36:21 +0000 (11:36 +0100)
Without checking for IFF_MULTICAST flag, it is wrong to assume multicast
filtering is always enabled. By checking against IFF_MULTICAST, now
the driver behaves correctly when the multicast support is toggled by below
command:-
  ip link set <devname> multicast off|on

Fixes: 477286b53f55 ("stmmac: add GMAC4 core support")
Signed-off-by: Verma, Aashish <aashishx.verma@intel.com>
Tested-by: Tan, Tee Min <tee.min.tan@intel.com>
Signed-off-by: Ong Boon Leong <boon.leong.ong@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/stmicro/stmmac/dwmac4_core.c

index 4d8eef9ff137a730d9bcc65a2cf9be5821db2339..dc09d2131e40b06a06b222f142a1a0ee22feef59 100644 (file)
@@ -420,7 +420,7 @@ static void dwmac4_set_filter(struct mac_device_info *hw,
                value |= GMAC_PACKET_FILTER_PM;
                /* Set all the bits of the HASH tab */
                memset(mc_filter, 0xff, sizeof(mc_filter));
-       } else if (!netdev_mc_empty(dev)) {
+       } else if (!netdev_mc_empty(dev) && (dev->flags & IFF_MULTICAST)) {
                struct netdev_hw_addr *ha;
 
                /* Hash filter for multicast */