net: dsa: felix: accept VLAN config regardless of bridge VLAN awareness state
authorVladimir Oltean <vladimir.oltean@nxp.com>
Wed, 27 May 2020 16:45:38 +0000 (19:45 +0300)
committerDavid S. Miller <davem@davemloft.net>
Wed, 27 May 2020 18:39:58 +0000 (11:39 -0700)
The ocelot core library is written with the idea in mind that the VLAN
table is populated by the bridge. Otherwise, not even a sane default
pvid is provided: in standalone mode, the default pvid is 0, and the
core expects the bridge layer to change it to 1.

So without this patch, the VLAN table is completely empty at the end of
the commands below, and traffic is broken as a result:

ip link add dev br0 type bridge vlan_filtering 0 && ip link set dev br0 up
for eth in $(ls /sys/bus/pci/devices/0000\:00\:00.5/net/); do
ip link set dev $eth master br0
ip link set dev $eth up
done
ip link set dev br0 type bridge vlan_filtering 1

Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/ocelot/felix.c

index 18c23ffd6b4089120b51e8e88086dc8d9d863e59..a6e272d2110dbcec7f5d3ad0bfe8bb3066d7f393 100644 (file)
@@ -594,6 +594,7 @@ static int felix_setup(struct dsa_switch *ds)
                                 ANA_FLOODING, tc);
 
        ds->mtu_enforcement_ingress = true;
+       ds->configure_vlan_while_not_filtering = true;
        /* It looks like the MAC/PCS interrupt register - PM0_IEVENT (0x8040)
         * isn't instantiated for the Felix PF.
         * In-band AN may take a few ms to complete, so we need to poll.