diff mbox series

[v2,net-next] net: ethernet: ti: cpsw: unsync mcast entries while switch promisc mode

Message ID 20181022185136.8215-1-ivan.khoronzhuk@linaro.org
State New
Headers show
Series [v2,net-next] net: ethernet: ti: cpsw: unsync mcast entries while switch promisc mode | expand

Commit Message

Ivan Khoronzhuk Oct. 22, 2018, 6:51 p.m. UTC
After flushing all mcast entries from the table, the ones contained in
mc list of ndev are not restored when promisc mode is toggled off,
because they are considered as synched with ALE, thus, in order to
restore them after promisc mode - reset syncing info. This fix
touches only switch mode devices, including single port boards
like Beagle Bone.

Fixes: commit 5da1948969bc
("net: ethernet: ti: cpsw: fix lost of mcast packets while rx_mode update")

Signed-off-by: Ivan Khoronzhuk <ivan.khoronzhuk@linaro.org>

---

Based on net-next/master

 drivers/net/ethernet/ti/cpsw.c | 1 +
 1 file changed, 1 insertion(+)

-- 
2.17.1

Comments

Grygorii Strashko Oct. 22, 2018, 7:02 p.m. UTC | #1
On 10/22/18 1:51 PM, Ivan Khoronzhuk wrote:
> After flushing all mcast entries from the table, the ones contained in

> mc list of ndev are not restored when promisc mode is toggled off,

> because they are considered as synched with ALE, thus, in order to

> restore them after promisc mode - reset syncing info. This fix

> touches only switch mode devices, including single port boards

> like Beagle Bone.

> 

> Fixes: commit 5da1948969bc

> ("net: ethernet: ti: cpsw: fix lost of mcast packets while rx_mode update")

> 

> Signed-off-by: Ivan Khoronzhuk <ivan.khoronzhuk@linaro.org>

> ---

> 

> Based on net-next/master



Thank you.
Reviewed-by: Grygorii Strashko <grygorii.strashko@ti.com>


-- 
regards,
-grygorii
diff mbox series

Patch

diff --git a/drivers/net/ethernet/ti/cpsw.c b/drivers/net/ethernet/ti/cpsw.c
index 226be2a56c1f..f7753b240ced 100644
--- a/drivers/net/ethernet/ti/cpsw.c
+++ b/drivers/net/ethernet/ti/cpsw.c
@@ -640,6 +640,7 @@  static void cpsw_set_promiscious(struct net_device *ndev, bool enable)
 
 			/* Clear all mcast from ALE */
 			cpsw_ale_flush_multicast(ale, ALE_ALL_PORTS, -1);
+			__dev_mc_unsync(ndev, NULL);
 
 			/* Flood All Unicast Packets to Host port */
 			cpsw_ale_control_set(ale, 0, ALE_P0_UNI_FLOOD, 1);