mlxsw: spectrum_switchdev: Allow port enslavement to a VLAN-unaware bridge
Up until now we only allowed VLAN devices to be put in a VLAN-unaware bridge, but some users need the ability to enslave physical ports as well. This is achieved by mapping the port and VID 1 to the bridge's vFID, instead of the port and the VID used by the VLAN device. The above is valid because as long as the port is not enslaved to a bridge, VID 1 is guaranteed to be configured as PVID and egress untagged. Signed-off-by: Ido Schimmel <idosch@mellanox.com> Signed-off-by: Jiri Pirko <jiri@mellanox.com> Tested-by: David Ahern <dsahern@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
ba6056a41c
commit
65b53bfd49
@ -1882,14 +1882,10 @@ mlxsw_sp_bridge_8021d_port_join(struct mlxsw_sp_bridge_device *bridge_device,
|
|||||||
struct netlink_ext_ack *extack)
|
struct netlink_ext_ack *extack)
|
||||||
{
|
{
|
||||||
struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
|
struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
|
||||||
|
struct net_device *dev = bridge_port->dev;
|
||||||
u16 vid;
|
u16 vid;
|
||||||
|
|
||||||
if (!is_vlan_dev(bridge_port->dev)) {
|
vid = is_vlan_dev(dev) ? vlan_dev_vlan_id(dev) : 1;
|
||||||
NL_SET_ERR_MSG_MOD(extack, "Only VLAN devices can be enslaved to a VLAN-unaware bridge");
|
|
||||||
return -EINVAL;
|
|
||||||
}
|
|
||||||
vid = vlan_dev_vlan_id(bridge_port->dev);
|
|
||||||
|
|
||||||
mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_vid(mlxsw_sp_port, vid);
|
mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_vid(mlxsw_sp_port, vid);
|
||||||
if (WARN_ON(!mlxsw_sp_port_vlan))
|
if (WARN_ON(!mlxsw_sp_port_vlan))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -1912,8 +1908,10 @@ mlxsw_sp_bridge_8021d_port_leave(struct mlxsw_sp_bridge_device *bridge_device,
|
|||||||
struct mlxsw_sp_port *mlxsw_sp_port)
|
struct mlxsw_sp_port *mlxsw_sp_port)
|
||||||
{
|
{
|
||||||
struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
|
struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
|
||||||
u16 vid = vlan_dev_vlan_id(bridge_port->dev);
|
struct net_device *dev = bridge_port->dev;
|
||||||
|
u16 vid;
|
||||||
|
|
||||||
|
vid = is_vlan_dev(dev) ? vlan_dev_vlan_id(dev) : 1;
|
||||||
mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_vid(mlxsw_sp_port, vid);
|
mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_vid(mlxsw_sp_port, vid);
|
||||||
if (WARN_ON(!mlxsw_sp_port_vlan))
|
if (WARN_ON(!mlxsw_sp_port_vlan))
|
||||||
return;
|
return;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user