• Parav Pandit's avatar
    net/mlx5: Fix devlink objects and devlink device unregister sequence · 98f91c45
    Parav Pandit authored
    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: c6acd629 ("net/mlx5e: Add support for devlink-port in non-representors mode")
    Fixes: f60f315d ("net/mlx5e: Register devlink ports for physical link, PCI PF, VFs")
    Signed-off-by: default avatarParav Pandit <parav@mellanox.com>
    Reviewed-by: default avatarMoshe Shemesh <moshe@mellanox.com>
    Signed-off-by: default avatarSaeed Mahameed <saeedm@mellanox.com>
    98f91c45
main.c 40.6 KB