Johnny Hughes
2019-02-04 c1f36c28393a7bb126cbf436cd6a4077a5b5c313
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
From 251852630ac787021e7088933187948f27bae241 Mon Sep 17 00:00:00 2001
From: Mikulas Patocka <mpatocka@redhat.com>
Date: Sun, 11 Feb 2018 18:10:28 -0500
Subject: [PATCH 28/46] mvpp2: fix multicast address filter
 
IPv6 doesn't work on the MacchiatoBIN board. It is caused by broken
multicast address filter in the mvpp2 driver.
 
The driver loads doesn't load any multicast entries if "allmulti" is not
set. This condition should be reversed.
 
The condition !netdev_mc_empty(dev) is useless (because
netdev_for_each_mc_addr is nop if the list is empty).
 
This patch also fixes a possible overflow of the multicast list - if
mvpp2_prs_mac_da_accept fails, we set the allmulti flag and retry.
 
Signed-off-by: Mikulas Patocka <mpatocka@redhat.com>
Cc: stable@vger.kernel.org
Signed-off-by: David S. Miller <davem@davemloft.net>
(cherry picked from commit 7ac8ff95f48cbfa609a060fd6a1e361dd62feeb3)
Signed-off-by: Marcin Wojtas <mw@semihalf.com>
---
 drivers/net/ethernet/marvell/mvpp2.c | 11 ++++++++---
 1 file changed, 8 insertions(+), 3 deletions(-)
 
diff --git a/drivers/net/ethernet/marvell/mvpp2.c b/drivers/net/ethernet/marvell/mvpp2.c
index a1d7b88..5a1668c 100644
--- a/drivers/net/ethernet/marvell/mvpp2.c
+++ b/drivers/net/ethernet/marvell/mvpp2.c
@@ -7137,6 +7137,7 @@ static void mvpp2_set_rx_mode(struct net_device *dev)
     int id = port->id;
     bool allmulti = dev->flags & IFF_ALLMULTI;
 
+retry:
     mvpp2_prs_mac_promisc_set(priv, id, dev->flags & IFF_PROMISC);
     mvpp2_prs_mac_multi_set(priv, id, MVPP2_PE_MAC_MC_ALL, allmulti);
     mvpp2_prs_mac_multi_set(priv, id, MVPP2_PE_MAC_MC_IP6, allmulti);
@@ -7144,9 +7145,13 @@ static void mvpp2_set_rx_mode(struct net_device *dev)
     /* Remove all port->id's mcast enries */
     mvpp2_prs_mcast_del_all(priv, id);
 
-    if (allmulti && !netdev_mc_empty(dev)) {
-        netdev_for_each_mc_addr(ha, dev)
-            mvpp2_prs_mac_da_accept(priv, id, ha->addr, true);
+    if (!allmulti) {
+        netdev_for_each_mc_addr(ha, dev) {
+            if (mvpp2_prs_mac_da_accept(priv, id, ha->addr, true)) {
+                allmulti = true;
+                goto retry;
+            }
+        }
     }
 }
 
-- 
2.7.4