diff options
author | Ioana Ciornei <ioana.ciornei@nxp.com> | 2019-05-30 00:42:30 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2019-05-31 00:47:14 +0300 |
commit | d34d2baa9173f6e0c0f22d005d18e83d1cb54d8d (patch) | |
tree | 6faa3f16bcf1c7b9d598f3345fde3da5d11555dc /include/linux/pci.h | |
parent | 21808437214637952b61beaba6034d97880fbeb3 (diff) | |
download | linux-d34d2baa9173f6e0c0f22d005d18e83d1cb54d8d.tar.xz |
net: dsa: tag_8021q: Change order of rx_vid setup
The 802.1Q tagging performs an unbalanced setup in terms of RX VIDs on
the CPU port. For the ingress path of a 802.1Q switch to work, the RX
VID of a port needs to be seen as tagged egress on the CPU port.
While configuring the other front-panel ports to be part of this VID,
for bridge scenarios, the untagged flag is applied even on the CPU port
in dsa_switch_vlan_add. This happens because DSA applies the same flags
on the CPU port as on the (bridge-controlled) slave ports, and the
effect in this case is that the CPU port tagged settings get deleted.
Instead of fixing DSA by introducing a way to control VLAN flags on the
CPU port (and hence stop inheriting from the slave ports) - a hard,
perhaps intractable problem - avoid this situation by moving the setup
part of the RX VID on the CPU port after all the other front-panel ports
have been added to the VID.
Fixes: f9bbe4477c30 ("net: dsa: Optional VLAN-based port separation for switches without tagging")
Signed-off-by: Ioana Ciornei <ioana.ciornei@nxp.com>
Signed-off-by: Vladimir Oltean <olteanv@gmail.com>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux/pci.h')
0 files changed, 0 insertions, 0 deletions