On 4/4/25 18:25, Joseph Huang wrote: > On 4/4/2025 6:29 AM, Nikolay Aleksandrov wrote: >> On 4/4/25 02:44, Joseph Huang wrote: >>> Notify user space on mdb offload failure if mdb_offload_fail_notification >>> is set. >>> >>> Signed-off-by: Joseph Huang <joseph.hu...@garmin.com> >>> --- >>> net/bridge/br_mdb.c | 26 +++++++++++++++++++++----- >>> net/bridge/br_private.h | 9 +++++++++ >>> net/bridge/br_switchdev.c | 4 ++++ >>> 3 files changed, 34 insertions(+), 5 deletions(-) >>> >> >> The patch looks good, but one question - it seems we'll mark mdb entries with >> "offload failed" when we get -EOPNOTSUPP as an error as well. Is that >> intended? >> >> That is, if the option is enabled and we have mixed bridge ports, we'll mark >> mdbs >> to the non-switch ports as offload failed, but it is not due to a switch >> offload >> error. > > Good catch. No, that was not intended. > > What if we short-circuit and just return like you'd suggested initially if > err == -EOPNOTSUPP? > >>> diff --git a/net/bridge/br_switchdev.c b/net/bridge/br_switchdev.c >>> index 40f0b16e4df8..9b5005d0742a 100644 >>> --- a/net/bridge/br_switchdev.c >>> +++ b/net/bridge/br_switchdev.c >>> @@ -504,6 +504,7 @@ static void br_switchdev_mdb_complete(struct net_device >>> *dev, int err, void *pri >>> struct net_bridge_mdb_entry *mp; >>> struct net_bridge_port *port = data->port; >>> struct net_bridge *br = port->br; >>> + u8 old_flags; >>> > > + if (err == -EOPNOTSUPP) > + goto notsupp; > >>> spin_lock_bh(&br->multicast_lock); >>> mp = br_mdb_ip_get(br, &data->ip); >>> @@ -514,7 +515,10 @@ static void br_switchdev_mdb_complete(struct >>> net_device *dev, int err, void *pri >>> if (p->key.port != port) >>> continue; >>> + old_flags = p->flags; >>> br_multicast_set_pg_offload_flags(p, !err); >>> + if (br_mdb_should_notify(br, old_flags ^ p->flags)) >>> + br_mdb_flag_change_notify(br->dev, mp, p); >>> } >>> out: >>> spin_unlock_bh(&br->multicast_lock); >> > > + notsupp: > kfree(priv);
Looks good to me. Thanks!