mlxsw: spectrum_switchdev: Use tracker helpers to hold & put netdevices
authorPetr Machata <petrm@nvidia.com>
Thu, 27 Jul 2023 15:59:21 +0000 (17:59 +0200)
committerJakub Kicinski <kuba@kernel.org>
Fri, 28 Jul 2023 20:38:45 +0000 (13:38 -0700)
Using the tracking helpers makes it easier to debug netdevice refcount
imbalances when CONFIG_NET_DEV_REFCNT_TRACKER is enabled.

Convert dev_hold() / dev_put() to netdev_hold() / netdev_put() in the
switchdev module.

Signed-off-by: Petr Machata <petrm@nvidia.com>
Reviewed-by: Ido Schimmel <idosch@nvidia.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Link: https://lore.kernel.org/r/774c3d7b5b0231f1435df2ec9dd660192e382756.1690471774.git.petrm@nvidia.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/mellanox/mlxsw/spectrum_switchdev.c

index dffb67c1038e2ba4160a6c912dc260121fb648d7..5376d4af5f912ab786224804f6af6fd87f1cac3a 100644 (file)
@@ -3380,6 +3380,7 @@ out:
 
 struct mlxsw_sp_switchdev_event_work {
        struct work_struct work;
+       netdevice_tracker dev_tracker;
        union {
                struct switchdev_notifier_fdb_info fdb_info;
                struct switchdev_notifier_vxlan_fdb_info vxlan_fdb_info;
@@ -3536,8 +3537,8 @@ static void mlxsw_sp_switchdev_bridge_fdb_event_work(struct work_struct *work)
 out:
        rtnl_unlock();
        kfree(switchdev_work->fdb_info.addr);
+       netdev_put(dev, &switchdev_work->dev_tracker);
        kfree(switchdev_work);
-       dev_put(dev);
 }
 
 static void
@@ -3692,8 +3693,8 @@ static void mlxsw_sp_switchdev_vxlan_fdb_event_work(struct work_struct *work)
 
 out:
        rtnl_unlock();
+       netdev_put(dev, &switchdev_work->dev_tracker);
        kfree(switchdev_work);
-       dev_put(dev);
 }
 
 static int
@@ -3793,7 +3794,7 @@ static int mlxsw_sp_switchdev_event(struct notifier_block *unused,
                 * upper device containig mlxsw_sp_port or just a
                 * mlxsw_sp_port
                 */
-               dev_hold(dev);
+               netdev_hold(dev, &switchdev_work->dev_tracker, GFP_ATOMIC);
                break;
        case SWITCHDEV_VXLAN_FDB_ADD_TO_DEVICE:
        case SWITCHDEV_VXLAN_FDB_DEL_TO_DEVICE:
@@ -3803,7 +3804,7 @@ static int mlxsw_sp_switchdev_event(struct notifier_block *unused,
                                                            info);
                if (err)
                        goto err_vxlan_work_prepare;
-               dev_hold(dev);
+               netdev_hold(dev, &switchdev_work->dev_tracker, GFP_ATOMIC);
                break;
        default:
                kfree(switchdev_work);