mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-12 16:19:53 +00:00
switchdev: bridge: Offload multicast disabled
Offload multicast disabled flag, for more accurate mc flood behavior: When it is on, the mdb should be ignored. When it is off, unregistered mc packets should be flooded to mc router ports. Signed-off-by: Nogah Frankel <nogahf@mellanox.com> Signed-off-by: Yotam Gigi <yotamg@mellanox.com> Signed-off-by: Jiri Pirko <jiri@mellanox.com> Acked-by: Ivan Vecera <ivecera@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
94134bf89a
commit
147c1e9b90
@ -48,6 +48,7 @@ enum switchdev_attr_id {
|
||||
SWITCHDEV_ATTR_ID_PORT_BRIDGE_FLAGS,
|
||||
SWITCHDEV_ATTR_ID_BRIDGE_AGEING_TIME,
|
||||
SWITCHDEV_ATTR_ID_BRIDGE_VLAN_FILTERING,
|
||||
SWITCHDEV_ATTR_ID_BRIDGE_MC_DISABLED,
|
||||
};
|
||||
|
||||
struct switchdev_attr {
|
||||
@ -62,6 +63,7 @@ struct switchdev_attr {
|
||||
unsigned long brport_flags; /* PORT_BRIDGE_FLAGS */
|
||||
clock_t ageing_time; /* BRIDGE_AGEING_TIME */
|
||||
bool vlan_filtering; /* BRIDGE_VLAN_FILTERING */
|
||||
bool mc_disabled; /* MC_DISABLED */
|
||||
} u;
|
||||
};
|
||||
|
||||
|
@ -27,6 +27,7 @@
|
||||
#include <linux/inetdevice.h>
|
||||
#include <linux/mroute.h>
|
||||
#include <net/ip.h>
|
||||
#include <net/switchdev.h>
|
||||
#if IS_ENABLED(CONFIG_IPV6)
|
||||
#include <net/ipv6.h>
|
||||
#include <net/mld.h>
|
||||
@ -1007,6 +1008,18 @@ static void br_ip6_multicast_port_query_expired(unsigned long data)
|
||||
}
|
||||
#endif
|
||||
|
||||
static void br_mc_disabled_update(struct net_device *dev, bool value)
|
||||
{
|
||||
struct switchdev_attr attr = {
|
||||
.orig_dev = dev,
|
||||
.id = SWITCHDEV_ATTR_ID_BRIDGE_MC_DISABLED,
|
||||
.flags = SWITCHDEV_F_DEFER,
|
||||
.u.mc_disabled = value,
|
||||
};
|
||||
|
||||
switchdev_port_attr_set(dev, &attr);
|
||||
}
|
||||
|
||||
int br_multicast_add_port(struct net_bridge_port *port)
|
||||
{
|
||||
port->multicast_router = MDB_RTR_TYPE_TEMP_QUERY;
|
||||
@ -1019,6 +1032,8 @@ int br_multicast_add_port(struct net_bridge_port *port)
|
||||
setup_timer(&port->ip6_own_query.timer,
|
||||
br_ip6_multicast_port_query_expired, (unsigned long)port);
|
||||
#endif
|
||||
br_mc_disabled_update(port->dev, port->br->multicast_disabled);
|
||||
|
||||
port->mcast_stats = netdev_alloc_pcpu_stats(struct bridge_mcast_stats);
|
||||
if (!port->mcast_stats)
|
||||
return -ENOMEM;
|
||||
@ -2121,6 +2136,7 @@ int br_multicast_toggle(struct net_bridge *br, unsigned long val)
|
||||
if (br->multicast_disabled == !val)
|
||||
goto unlock;
|
||||
|
||||
br_mc_disabled_update(br->dev, !val);
|
||||
br->multicast_disabled = !val;
|
||||
if (br->multicast_disabled)
|
||||
goto unlock;
|
||||
|
Loading…
x
Reference in New Issue
Block a user