Commit 9cb7e94a authored by Moshe Shemesh's avatar Moshe Shemesh Committed by Jakub Kicinski

net/mlx4: Use devl_ API for devlink region create / destroy

Use devl_ API to call devl_region_create() and devl_region_destroy()
instead of devlink_region_create() and devlink_region_destroy().
Add devlink instance lock in mlx4 driver paths to these functions.

This will be used by the downstream patch to invoke mlx4 devlink reload
callbacks with devlink lock held.
Signed-off-by: default avatarMoshe Shemesh <moshe@nvidia.com>
Reviewed-by: default avatarTariq Toukan <tariqt@nvidia.com>
Reviewed-by: default avatarJiri Pirko <jiri@nvidia.com>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 84a433a4
...@@ -226,10 +226,10 @@ int mlx4_crdump_init(struct mlx4_dev *dev) ...@@ -226,10 +226,10 @@ int mlx4_crdump_init(struct mlx4_dev *dev)
/* Create cr-space region */ /* Create cr-space region */
crdump->region_crspace = crdump->region_crspace =
devlink_region_create(devlink, devl_region_create(devlink,
&region_cr_space_ops, &region_cr_space_ops,
MAX_NUM_OF_DUMPS_TO_STORE, MAX_NUM_OF_DUMPS_TO_STORE,
pci_resource_len(pdev, 0)); pci_resource_len(pdev, 0));
if (IS_ERR(crdump->region_crspace)) if (IS_ERR(crdump->region_crspace))
mlx4_warn(dev, "crdump: create devlink region %s err %ld\n", mlx4_warn(dev, "crdump: create devlink region %s err %ld\n",
region_cr_space_str, region_cr_space_str,
...@@ -237,10 +237,10 @@ int mlx4_crdump_init(struct mlx4_dev *dev) ...@@ -237,10 +237,10 @@ int mlx4_crdump_init(struct mlx4_dev *dev)
/* Create fw-health region */ /* Create fw-health region */
crdump->region_fw_health = crdump->region_fw_health =
devlink_region_create(devlink, devl_region_create(devlink,
&region_fw_health_ops, &region_fw_health_ops,
MAX_NUM_OF_DUMPS_TO_STORE, MAX_NUM_OF_DUMPS_TO_STORE,
HEALTH_BUFFER_SIZE); HEALTH_BUFFER_SIZE);
if (IS_ERR(crdump->region_fw_health)) if (IS_ERR(crdump->region_fw_health))
mlx4_warn(dev, "crdump: create devlink region %s err %ld\n", mlx4_warn(dev, "crdump: create devlink region %s err %ld\n",
region_fw_health_str, region_fw_health_str,
...@@ -253,6 +253,6 @@ void mlx4_crdump_end(struct mlx4_dev *dev) ...@@ -253,6 +253,6 @@ void mlx4_crdump_end(struct mlx4_dev *dev)
{ {
struct mlx4_fw_crdump *crdump = &dev->persist->crdump; struct mlx4_fw_crdump *crdump = &dev->persist->crdump;
devlink_region_destroy(crdump->region_fw_health); devl_region_destroy(crdump->region_fw_health);
devlink_region_destroy(crdump->region_crspace); devl_region_destroy(crdump->region_crspace);
} }
...@@ -3732,6 +3732,7 @@ static int __mlx4_init_one(struct pci_dev *pdev, int pci_dev_data, ...@@ -3732,6 +3732,7 @@ static int __mlx4_init_one(struct pci_dev *pdev, int pci_dev_data,
int prb_vf[MLX4_MAX_PORTS + 1] = {0, 0, 0}; int prb_vf[MLX4_MAX_PORTS + 1] = {0, 0, 0};
const int param_map[MLX4_MAX_PORTS + 1][MLX4_MAX_PORTS + 1] = { const int param_map[MLX4_MAX_PORTS + 1][MLX4_MAX_PORTS + 1] = {
{2, 0, 0}, {0, 1, 2}, {0, 1, 2} }; {2, 0, 0}, {0, 1, 2}, {0, 1, 2} };
struct devlink *devlink = priv_to_devlink(priv);
unsigned total_vfs = 0; unsigned total_vfs = 0;
unsigned int i; unsigned int i;
...@@ -3844,7 +3845,9 @@ static int __mlx4_init_one(struct pci_dev *pdev, int pci_dev_data, ...@@ -3844,7 +3845,9 @@ static int __mlx4_init_one(struct pci_dev *pdev, int pci_dev_data,
} }
} }
devl_lock(devlink);
err = mlx4_crdump_init(&priv->dev); err = mlx4_crdump_init(&priv->dev);
devl_unlock(devlink);
if (err) if (err)
goto err_release_regions; goto err_release_regions;
...@@ -3862,7 +3865,9 @@ static int __mlx4_init_one(struct pci_dev *pdev, int pci_dev_data, ...@@ -3862,7 +3865,9 @@ static int __mlx4_init_one(struct pci_dev *pdev, int pci_dev_data,
mlx4_catas_end(&priv->dev); mlx4_catas_end(&priv->dev);
err_crdump: err_crdump:
devl_lock(devlink);
mlx4_crdump_end(&priv->dev); mlx4_crdump_end(&priv->dev);
devl_unlock(devlink);
err_release_regions: err_release_regions:
pci_release_regions(pdev); pci_release_regions(pdev);
...@@ -4161,7 +4166,9 @@ static void mlx4_remove_one(struct pci_dev *pdev) ...@@ -4161,7 +4166,9 @@ static void mlx4_remove_one(struct pci_dev *pdev)
else else
mlx4_info(dev, "%s: interface is down\n", __func__); mlx4_info(dev, "%s: interface is down\n", __func__);
mlx4_catas_end(dev); mlx4_catas_end(dev);
devl_lock(devlink);
mlx4_crdump_end(dev); mlx4_crdump_end(dev);
devl_unlock(devlink);
if (dev->flags & MLX4_FLAG_SRIOV && !active_vfs) { if (dev->flags & MLX4_FLAG_SRIOV && !active_vfs) {
mlx4_warn(dev, "Disabling SR-IOV\n"); mlx4_warn(dev, "Disabling SR-IOV\n");
pci_disable_sriov(pdev); pci_disable_sriov(pdev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment