struct mlx4_dev_cap *dev_cap = NULL;
        int existing_vfs = 0;
 
+       devl_assert_locked(devlink);
        dev = &priv->dev;
 
        INIT_LIST_HEAD(&priv->ctx_list);
                }
        }
 
-       devl_lock(devlink);
        for (port = 1; port <= dev->caps.num_ports; port++) {
                err = mlx4_init_port_info(dev, port);
                if (err)
        if (err)
                goto err_port;
 
-       devl_unlock(devlink);
        mlx4_request_modules(dev);
 
        mlx4_sense_init(dev);
 err_port:
        for (--port; port >= 1; --port)
                mlx4_cleanup_port_info(&priv->port[port]);
-       devl_unlock(devlink);
 
        mlx4_cleanup_default_counters(dev);
        if (!mlx4_is_slave(dev))
        int prb_vf[MLX4_MAX_PORTS + 1] = {0, 0, 0};
        const int param_map[MLX4_MAX_PORTS + 1][MLX4_MAX_PORTS + 1] = {
                {2, 0, 0}, {0, 1, 2}, {0, 1, 2} };
-       struct devlink *devlink = priv_to_devlink(priv);
        unsigned total_vfs = 0;
        unsigned int i;
 
                }
        }
 
-       devl_lock(devlink);
        err = mlx4_crdump_init(&priv->dev);
-       devl_unlock(devlink);
        if (err)
                goto err_release_regions;
 
        mlx4_catas_end(&priv->dev);
 
 err_crdump:
-       devl_lock(devlink);
        mlx4_crdump_end(&priv->dev);
-       devl_unlock(devlink);
 
 err_release_regions:
        pci_release_regions(pdev);
                NL_SET_ERR_MSG_MOD(extack, "Namespace change is not supported");
                return -EOPNOTSUPP;
        }
+       devl_lock(devlink);
        if (persist->num_vfs)
                mlx4_warn(persist->dev, "Reload performed on PF, will cause reset on operating Virtual Functions\n");
        mlx4_restart_one_down(persist->pdev);
+       devl_unlock(devlink);
        return 0;
 }
 
        struct mlx4_dev_persistent *persist = dev->persist;
        int err;
 
+       devl_lock(devlink);
        *actions_performed = BIT(DEVLINK_RELOAD_ACTION_DRIVER_REINIT);
        err = mlx4_restart_one_up(persist->pdev, true, devlink);
+       devl_unlock(devlink);
        if (err)
                mlx4_err(persist->dev, "mlx4_restart_one_up failed, ret=%d\n",
                         err);
        devlink = devlink_alloc(&mlx4_devlink_ops, sizeof(*priv), &pdev->dev);
        if (!devlink)
                return -ENOMEM;
+       devl_lock(devlink);
        priv = devlink_priv(devlink);
 
        dev       = &priv->dev;
 
        pci_save_state(pdev);
        devlink_set_features(devlink, DEVLINK_F_RELOAD);
+       devl_unlock(devlink);
        devlink_register(devlink);
        return 0;
 
 err_devlink_unregister:
        kfree(dev->persist);
 err_devlink_free:
+       devl_unlock(devlink);
        devlink_free(devlink);
        return ret;
 }
        int p, i;
 
        devlink = priv_to_devlink(priv);
+       devl_assert_locked(devlink);
        if (priv->removed)
                return;
 
        mlx4_stop_sense(dev);
        mlx4_unregister_device(dev);
 
-       devl_lock(devlink);
        for (p = 1; p <= dev->caps.num_ports; p++) {
                mlx4_cleanup_port_info(&priv->port[p]);
                mlx4_CLOSE_PORT(dev, p);
        }
-       devl_unlock(devlink);
 
        if (mlx4_is_master(dev))
                mlx4_free_resource_tracker(dev,
 
        devlink_unregister(devlink);
 
+       devl_lock(devlink);
        if (mlx4_is_slave(dev))
                persist->interface_state |= MLX4_INTERFACE_STATE_NOWAIT;
 
        else
                mlx4_info(dev, "%s: interface is down\n", __func__);
        mlx4_catas_end(dev);
-       devl_lock(devlink);
        mlx4_crdump_end(dev);
-       devl_unlock(devlink);
        if (dev->flags & MLX4_FLAG_SRIOV && !active_vfs) {
                mlx4_warn(dev, "Disabling SR-IOV\n");
                pci_disable_sriov(pdev);
        devlink_params_unregister(devlink, mlx4_devlink_params,
                                  ARRAY_SIZE(mlx4_devlink_params));
        kfree(dev->persist);
+       devl_unlock(devlink);
        devlink_free(devlink);
 }
 
                                              pci_channel_state_t state)
 {
        struct mlx4_dev_persistent *persist = pci_get_drvdata(pdev);
+       struct mlx4_dev *dev = persist->dev;
+       struct devlink *devlink;
 
        mlx4_err(persist->dev, "mlx4_pci_err_detected was called\n");
        mlx4_enter_error_state(persist);
 
+       devlink = priv_to_devlink(mlx4_priv(dev));
+       devl_lock(devlink);
        mutex_lock(&persist->interface_state_mutex);
        if (persist->interface_state & MLX4_INTERFACE_STATE_UP)
                mlx4_unload_one(pdev);
 
        mutex_unlock(&persist->interface_state_mutex);
+       devl_unlock(devlink);
        if (state == pci_channel_io_perm_failure)
                return PCI_ERS_RESULT_DISCONNECT;
 
        struct mlx4_dev  *dev  = persist->dev;
        struct mlx4_priv *priv = mlx4_priv(dev);
        int nvfs[MLX4_MAX_PORTS + 1] = {0, 0, 0};
+       struct devlink *devlink;
        int total_vfs;
        int err;
 
        total_vfs = dev->persist->num_vfs;
        memcpy(nvfs, dev->persist->nvfs, sizeof(dev->persist->nvfs));
 
+       devlink = priv_to_devlink(priv);
+       devl_lock(devlink);
        mutex_lock(&persist->interface_state_mutex);
        if (!(persist->interface_state & MLX4_INTERFACE_STATE_UP)) {
                err = mlx4_load_one(pdev, priv->pci_dev_data, total_vfs, nvfs,
        }
 end:
        mutex_unlock(&persist->interface_state_mutex);
-
+       devl_unlock(devlink);
 }
 
 static void mlx4_shutdown(struct pci_dev *pdev)
 {
        struct mlx4_dev_persistent *persist = pci_get_drvdata(pdev);
        struct mlx4_dev *dev = persist->dev;
+       struct devlink *devlink;
 
        mlx4_info(persist->dev, "mlx4_shutdown was called\n");
+       devlink = priv_to_devlink(mlx4_priv(dev));
+       devl_lock(devlink);
        mutex_lock(&persist->interface_state_mutex);
        if (persist->interface_state & MLX4_INTERFACE_STATE_UP)
                mlx4_unload_one(pdev);
        mutex_unlock(&persist->interface_state_mutex);
+       devl_unlock(devlink);
        mlx4_pci_disable_device(dev);
 }
 
        struct pci_dev *pdev = to_pci_dev(dev_d);
        struct mlx4_dev_persistent *persist = pci_get_drvdata(pdev);
        struct mlx4_dev *dev = persist->dev;
+       struct devlink *devlink;
 
        mlx4_err(dev, "suspend was called\n");
+       devlink = priv_to_devlink(mlx4_priv(dev));
+       devl_lock(devlink);
        mutex_lock(&persist->interface_state_mutex);
        if (persist->interface_state & MLX4_INTERFACE_STATE_UP)
                mlx4_unload_one(pdev);
        mutex_unlock(&persist->interface_state_mutex);
+       devl_unlock(devlink);
 
        return 0;
 }
        struct mlx4_dev *dev = persist->dev;
        struct mlx4_priv *priv = mlx4_priv(dev);
        int nvfs[MLX4_MAX_PORTS + 1] = {0, 0, 0};
+       struct devlink *devlink;
        int total_vfs;
        int ret = 0;
 
        total_vfs = dev->persist->num_vfs;
        memcpy(nvfs, dev->persist->nvfs, sizeof(dev->persist->nvfs));
 
+       devlink = priv_to_devlink(priv);
+       devl_lock(devlink);
        mutex_lock(&persist->interface_state_mutex);
        if (!(persist->interface_state & MLX4_INTERFACE_STATE_UP)) {
                ret = mlx4_load_one(pdev, priv->pci_dev_data, total_vfs,
                }
        }
        mutex_unlock(&persist->interface_state_mutex);
+       devl_unlock(devlink);
 
        return ret;
 }