net: dsa: mv88e6xxx: do not flood CPU with unknown multicast
authorVivien Didelot <vivien.didelot@gmail.com>
Wed, 12 Jun 2019 22:33:44 +0000 (18:33 -0400)
committerDavid S. Miller <davem@davemloft.net>
Sat, 15 Jun 2019 20:25:36 +0000 (13:25 -0700)
The DSA ports must flood unknown unicast and multicast, but the switch
must not flood the CPU ports with unknown multicast, as this results
in a lot of undesirable traffic that the network stack needs to filter
in software.

Signed-off-by: Vivien Didelot <vivien.didelot@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/mv88e6xxx/chip.c

index 6691120bd28310ee00c2d8ec90a70e915e218300..9b3d6091d300cab5f3dc9d5c270aeeb07d1fe661 100644 (file)
@@ -2058,15 +2058,13 @@ static int mv88e6xxx_setup_message_port(struct mv88e6xxx_chip *chip, int port)
 static int mv88e6xxx_setup_egress_floods(struct mv88e6xxx_chip *chip, int port)
 {
        struct dsa_switch *ds = chip->ds;
-       bool flood;
+       bool uc = dsa_is_dsa_port(ds, port) || dsa_is_cpu_port(ds, port);
+       bool mc = dsa_is_dsa_port(ds, port);
 
-       /* Upstream ports flood frames with unknown unicast or multicast DA */
-       flood = dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port);
-       if (chip->info->ops->port_set_egress_floods)
-               return chip->info->ops->port_set_egress_floods(chip, port,
-                                                              flood, flood);
+       if (!chip->info->ops->port_set_egress_floods)
+               return 0;
 
-       return 0;
+       return chip->info->ops->port_set_egress_floods(chip, port, uc, mc);
 }
 
 static int mv88e6xxx_serdes_power(struct mv88e6xxx_chip *chip, int port,