[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <39385134-e499-2444-aa0d-48b0315e1002@nvidia.com>
Date: Thu, 1 Jul 2021 16:49:44 +0300
From: Nikolay Aleksandrov <nikolay@...dia.com>
To: Wolfgang Bumiller <w.bumiller@...xmox.com>, netdev@...r.kernel.org
Cc: bridge@...ts.linux-foundation.org,
Jakub Kicinski <kuba@...nel.org>,
"David S. Miller" <davem@...emloft.net>,
Roopa Prabhu <roopa@...dia.com>,
Vlad Yasevich <vyasevic@...hat.com>,
Thomas Lamprecht <t.lamprecht@...xmox.com>
Subject: Re: [PATCH 1/1] net: bridge: sync fdb to new unicast-filtering ports
On 01/07/2021 15:28, Wolfgang Bumiller wrote:
> Since commit 2796d0c648c9 ("bridge: Automatically manage
> port promiscuous mode.")
> bridges with `vlan_filtering 1` and only 1 auto-port don't
> set IFF_PROMISC for unicast-filtering-capable ports.
>
> Normally on port changes `br_manage_promisc` is called to
> update the promisc flags and unicast filters if necessary,
> but it cannot distinguish between *new* ports and ones
> losing their promisc flag, and new ports end up not
> receiving the MAC address list.
>
> Fix this by calling `br_fdb_sync_static` in `br_add_if`
> after the port promisc flags are updated and the unicast
> filter was supposed to have been filled.
>
> Signed-off-by: Wolfgang Bumiller <w.bumiller@...xmox.com>
> ---
> net/bridge/br_if.c | 12 ++++++++++++
> 1 file changed, 12 insertions(+)
>
> diff --git a/net/bridge/br_if.c b/net/bridge/br_if.c
> index f7d2f472ae24..183e72e7b65e 100644
> --- a/net/bridge/br_if.c
> +++ b/net/bridge/br_if.c
> @@ -652,6 +652,18 @@ int br_add_if(struct net_bridge *br, struct net_device *dev,
> list_add_rcu(&p->list, &br->port_list);
>
> nbp_update_port_count(br);
> + if (!br_promisc_port(p) && (p->dev->priv_flags & IFF_UNICAST_FLT)) {
> + /* When updating the port count we also update all ports'
> + * promiscuous mode.
> + * A port leaving promiscuous mode normally gets the bridge's
> + * fdb synced to the unicast filter (if supported), however,
> + * `br_port_clear_promisc` does not distinguish between
> + * non-promiscuous ports and *new* ports, so we need to
> + * sync explicitly here.
> + */
> + if (br_fdb_sync_static(br, p))
> + netdev_err(dev, "failed to sync bridge addresses to this port\n");
> + }
>
> netdev_update_features(br->dev);
>
>
Hi,
The patch is wrong because br_add_if() can fail after you sync these entries and
then nothing will unsync them. Out of curiousity what's the use case of a bridge with a
single port only ? Because, as you've also noted, this will be an issue only if there is
a single port and sounds like a corner case, maybe there's a better way to handle it.
To be honest this promisc management has caused us headaches with scale setups with thousands
of permanent and static entries where we don't need to sync uc lists, we've actually thought
about flags to disable this altogether.
Thanks,
Nik
Powered by blists - more mailing lists