Re: [PATCH net-next v4] bridge: multicast to unicast

From: Stephen Hemminger
Date: Thu Jan 19 2017 - 14:13:02 EST


On Thu, 19 Jan 2017 03:45:10 +0100
Linus LÃssing <linus.luessing@xxxxxxxxx> wrote:

> From: Felix Fietkau <nbd@xxxxxxxx>
>
> Implements an optional, per bridge port flag and feature to deliver
> multicast packets to any host on the according port via unicast
> individually. This is done by copying the packet per host and
> changing the multicast destination MAC to a unicast one accordingly.
>
> multicast-to-unicast works on top of the multicast snooping feature of
> the bridge. Which means unicast copies are only delivered to hosts which
> are interested in it and signalized this via IGMP/MLD reports
> previously.
>
> This feature is intended for interface types which have a more reliable
> and/or efficient way to deliver unicast packets than broadcast ones
> (e.g. wifi).
>
> However, it should only be enabled on interfaces where no IGMPv2/MLDv1
> report suppression takes place. This feature is disabled by default.
>
> The initial patch and idea is from Felix Fietkau.
>
> Signed-off-by: Felix Fietkau <nbd@xxxxxxxx>
> [linus.luessing@xxxxxxxxx: various bug + style fixes, commit message]
> Signed-off-by: Linus LÃssing <linus.luessing@xxxxxxxxx>
>

In general this looks good.

One issue I see is how existing entries are handled when the bridge port flags
are changed dynamically. It might be better to always record the necessary data
in the bridge_port_group and not have a per-entry flag bit. In your current
patch the API changes the response to future IGMP but does not take instant
effect. Code would be simpler if there was less logic to handle per-entry flags.

Also, you might want to add sysfs interface for the attribute as well.