• Vladimir Oltean's avatar
    net: dsa: felix: send VLANs on CPU port as egress-tagged · 183be6f9
    Vladimir Oltean authored
    As explained in other commits before (b9cd75e6 and 87b0f983),
    ocelot switches have a single egress-untagged VLAN per port, and the
    driver would deny adding a second one while an egress-untagged VLAN
    already exists.
    
    But on the CPU port (where the VLAN configuration is implicit, because
    there is no net device for the bridge to control), the DSA core attempts
    to add a VLAN using the same flags as were used for the front-panel
    port. This would make adding any untagged VLAN fail due to the CPU port
    rejecting the configuration:
    
    bridge vlan add dev swp0 vid 100 pvid untagged
    [ 1865.854253] mscc_felix 0000:00:00.5: Port already has a native VLAN: 1
    [ 1865.860824] mscc_felix 0000:00:00.5: Failed to add VLAN 100 to port 5: -16
    
    (note that port 5 is the CPU port and not the front-panel swp0).
    
    So this hardware will send all VLANs as tagged towards the CPU.
    
    Fixes: 56051948 ("net: dsa: ocelot: add driver for Felix switch family")
    Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
    Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    183be6f9
felix.c 21.8 KB