]> git.baikalelectronics.ru Git - kernel.git/commit
net/mlx5: Fix devlink objects and devlink device unregister sequence
authorParav Pandit <parav@mellanox.com>
Fri, 15 May 2020 07:44:06 +0000 (02:44 -0500)
committerSaeed Mahameed <saeedm@mellanox.com>
Thu, 11 Jun 2020 22:38:02 +0000 (15:38 -0700)
commit4d191b669cd6964720244f7e013870f80c5f5eba
tree5a8098cab5fbffc3deec76ad199f94d3aedc1e19
parent5df875fad55e01c108d199517c21c80f6075382f
net/mlx5: Fix devlink objects and devlink device unregister sequence

Current below problems exists.

1. devlink device is registered by mlx5_load_one(). But it is
not unregistered by mlx5_unload_one(). This is incorrect.

2. Above issue leads to,
When mlx5 PCI device is removed, currently devlink device is
unregistered before devlink ports are unregistered in below ladder
diagram.

remove_one()
  mlx5_devlink_unregister()
    [..]
    devlink_unregister() <- ports are still registered!
  mlx5_unload_one()
    mlx5_unregister_device()
      mlx5_remove_device()
        mlx5e_remove()
          mlx5e_devlink_port_unregister()
            devlink_port_unregister()

3. Condition checking for registering and unregister device are not
symmetric either in these routines.

Hence, fix the sequence by having load and unload routines symmetric
and in right order.
i.e.
(a) register devlink device followed by registering devlink ports
(b) unregister devlink ports followed by devlink device

Do this based on boot and cleanup flags instead of different
conditions.

Fixes: 24bb74c80f05 ("net/mlx5e: Add support for devlink-port in non-representors mode")
Fixes: 1e1be2d4d366 ("net/mlx5e: Register devlink ports for physical link, PCI PF, VFs")
Signed-off-by: Parav Pandit <parav@mellanox.com>
Reviewed-by: Moshe Shemesh <moshe@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
drivers/net/ethernet/mellanox/mlx5/core/main.c