diff options
author | Vladimir Oltean <vladimir.oltean@nxp.com> | 2022-02-15 00:36:46 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2022-02-15 15:37:28 +0100 |
commit | 5454f5c28eca6baba032f22e0df7df1c5e3f075f (patch) | |
tree | 0cd5f1e6ed81f88dedacfdbacb3be6fca37ce082 /net/bridge/br_vlan.c | |
parent | net: hso: Use GFP_KERNEL instead of GFP_ATOMIC when possible (diff) | |
download | linux-5454f5c28eca6baba032f22e0df7df1c5e3f075f.tar.xz linux-5454f5c28eca6baba032f22e0df7df1c5e3f075f.zip |
net: bridge: vlan: check for errors from __vlan_del in __vlan_flush
If the following call path returns an error from switchdev:
nbp_vlan_flush
-> __vlan_del
-> __vlan_vid_del
-> br_switchdev_port_vlan_del
-> __vlan_group_free
-> WARN_ON(!list_empty(&vg->vlan_list));
then the deletion of the net_bridge_vlan is silently halted, which will
trigger the WARN_ON from __vlan_group_free().
The WARN_ON is rather unhelpful, because nothing about the source of the
error is printed. Add a print to catch errors from __vlan_del.
Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/bridge/br_vlan.c')
-rw-r--r-- | net/bridge/br_vlan.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/net/bridge/br_vlan.c b/net/bridge/br_vlan.c index 1402d5ca242d..6315e43a7a3e 100644 --- a/net/bridge/br_vlan.c +++ b/net/bridge/br_vlan.c @@ -404,6 +404,7 @@ static void __vlan_flush(const struct net_bridge *br, { struct net_bridge_vlan *vlan, *tmp; u16 v_start = 0, v_end = 0; + int err; __vlan_delete_pvid(vg, vg->pvid); list_for_each_entry_safe(vlan, tmp, &vg->vlan_list, vlist) { @@ -417,7 +418,13 @@ static void __vlan_flush(const struct net_bridge *br, } v_end = vlan->vid; - __vlan_del(vlan); + err = __vlan_del(vlan); + if (err) { + br_err(br, + "port %u(%s) failed to delete vlan %d: %pe\n", + (unsigned int) p->port_no, p->dev->name, + vlan->vid, ERR_PTR(err)); + } } /* notify about the last/whole vlan range */ |