mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-02-05 20:55:13 +07:00
mlxsw: spectrum_switchdev: Flood all mc packets to mrouter ports
When mc is enabled, whenever a mc packet doesn't hit any mdb entry it is being flood to the ports marked as mrouters. However, all mc packets should be flooded to them even if they match an entry in the mdb. This patch adds the mrouter ports to every mdb entry that is being written to the HW. Signed-off-by: Nogah Frankel <nogahf@mellanox.com> Signed-off-by: Jiri Pirko <jiri@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
bb5355b27c
commit
3fba877cb6
@ -1288,10 +1288,55 @@ mlxsw_sp_mid *__mlxsw_sp_mc_get(struct mlxsw_sp_bridge_device *bridge_device,
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
mlxsw_sp_bridge_port_get_ports_bitmap(struct mlxsw_sp *mlxsw_sp,
|
||||
struct mlxsw_sp_bridge_port *bridge_port,
|
||||
unsigned long *ports_bitmap)
|
||||
{
|
||||
struct mlxsw_sp_port *mlxsw_sp_port;
|
||||
u64 max_lag_members, i;
|
||||
int lag_id;
|
||||
|
||||
if (!bridge_port->lagged) {
|
||||
set_bit(bridge_port->system_port, ports_bitmap);
|
||||
} else {
|
||||
max_lag_members = MLXSW_CORE_RES_GET(mlxsw_sp->core,
|
||||
MAX_LAG_MEMBERS);
|
||||
lag_id = bridge_port->lag_id;
|
||||
for (i = 0; i < max_lag_members; i++) {
|
||||
mlxsw_sp_port = mlxsw_sp_port_lagged_get(mlxsw_sp,
|
||||
lag_id, i);
|
||||
if (mlxsw_sp_port)
|
||||
set_bit(mlxsw_sp_port->local_port,
|
||||
ports_bitmap);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
mlxsw_sp_mc_get_mrouters_bitmap(unsigned long *flood_bitmap,
|
||||
struct mlxsw_sp_bridge_device *bridge_device,
|
||||
struct mlxsw_sp *mlxsw_sp)
|
||||
{
|
||||
struct mlxsw_sp_bridge_port *bridge_port;
|
||||
|
||||
list_for_each_entry(bridge_port, &bridge_device->ports_list, list) {
|
||||
if (bridge_port->mrouter) {
|
||||
mlxsw_sp_bridge_port_get_ports_bitmap(mlxsw_sp,
|
||||
bridge_port,
|
||||
flood_bitmap);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static bool
|
||||
mlxsw_sp_mc_write_mdb_entry(struct mlxsw_sp *mlxsw_sp,
|
||||
struct mlxsw_sp_mid *mid)
|
||||
struct mlxsw_sp_mid *mid,
|
||||
struct mlxsw_sp_bridge_device *bridge_device)
|
||||
{
|
||||
long *flood_bitmap;
|
||||
int num_of_ports;
|
||||
int alloc_size;
|
||||
u16 mid_idx;
|
||||
int err;
|
||||
|
||||
@ -1300,9 +1345,18 @@ mlxsw_sp_mc_write_mdb_entry(struct mlxsw_sp *mlxsw_sp,
|
||||
if (mid_idx == MLXSW_SP_MID_MAX)
|
||||
return false;
|
||||
|
||||
num_of_ports = mlxsw_core_max_ports(mlxsw_sp->core);
|
||||
alloc_size = sizeof(long) * BITS_TO_LONGS(num_of_ports);
|
||||
flood_bitmap = kzalloc(alloc_size, GFP_KERNEL);
|
||||
if (!flood_bitmap)
|
||||
return false;
|
||||
|
||||
bitmap_copy(flood_bitmap, mid->ports_in_mid, num_of_ports);
|
||||
mlxsw_sp_mc_get_mrouters_bitmap(flood_bitmap, bridge_device, mlxsw_sp);
|
||||
|
||||
mid->mid = mid_idx;
|
||||
err = mlxsw_sp_port_smid_full_entry(mlxsw_sp, mid_idx,
|
||||
mid->ports_in_mid);
|
||||
err = mlxsw_sp_port_smid_full_entry(mlxsw_sp, mid_idx, flood_bitmap);
|
||||
kfree(flood_bitmap);
|
||||
if (err)
|
||||
return false;
|
||||
|
||||
@ -1355,7 +1409,7 @@ mlxsw_sp_mid *__mlxsw_sp_mc_alloc(struct mlxsw_sp *mlxsw_sp,
|
||||
if (!bridge_device->multicast_enabled)
|
||||
goto out;
|
||||
|
||||
if (!mlxsw_sp_mc_write_mdb_entry(mlxsw_sp, mid))
|
||||
if (!mlxsw_sp_mc_write_mdb_entry(mlxsw_sp, mid, bridge_device))
|
||||
goto err_write_mdb_entry;
|
||||
|
||||
out:
|
||||
@ -1456,7 +1510,8 @@ mlxsw_sp_bridge_mdb_mc_enable_sync(struct mlxsw_sp_port *mlxsw_sp_port,
|
||||
|
||||
list_for_each_entry(mid, &bridge_device->mids_list, list) {
|
||||
if (mc_enabled)
|
||||
mlxsw_sp_mc_write_mdb_entry(mlxsw_sp, mid);
|
||||
mlxsw_sp_mc_write_mdb_entry(mlxsw_sp, mid,
|
||||
bridge_device);
|
||||
else
|
||||
mlxsw_sp_mc_remove_mdb_entry(mlxsw_sp, mid);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user