Skip to content

Commit aa4ac90

Browse files
Tariq Toukankuba-moo
authored andcommitted
net/mlx5: SD, Handle possible devcom ERR_PTR
Check if devcom holds an error pointer and return immediately. This fixes Smatch static checker warning: drivers/net/ethernet/mellanox/mlx5/core/lib/sd.c:221 sd_register() error: 'devcom' dereferencing possible ERR_PTR() Enhance mlx5_devcom_register_component() so it stops returning NULL, making it easier for its callers. Fixes: d3d0576 ("net/mlx5: SD, Implement devcom communication and primary election") Reported-by: Dan Carpenter <[email protected]> Link: https://lore.kernel.org/all/[email protected]/T/ Signed-off-by: Tariq Toukan <[email protected]> Reviewed-by: Gal Pressman <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Jakub Kicinski <[email protected]>
1 parent 37cc10d commit aa4ac90

File tree

5 files changed

+7
-7
lines changed

5 files changed

+7
-7
lines changed

drivers/net/ethernet/mellanox/mlx5/core/en_main.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -209,8 +209,8 @@ static int mlx5e_devcom_init_mpv(struct mlx5e_priv *priv, u64 *data)
209209
*data,
210210
mlx5e_devcom_event_mpv,
211211
priv);
212-
if (IS_ERR_OR_NULL(priv->devcom))
213-
return -EOPNOTSUPP;
212+
if (IS_ERR(priv->devcom))
213+
return PTR_ERR(priv->devcom);
214214

215215
if (mlx5_core_is_mp_master(priv->mdev)) {
216216
mlx5_devcom_send_event(priv->devcom, MPV_DEVCOM_MASTER_UP,

drivers/net/ethernet/mellanox/mlx5/core/eswitch_offloads.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3060,7 +3060,7 @@ void mlx5_esw_offloads_devcom_init(struct mlx5_eswitch *esw, u64 key)
30603060
key,
30613061
mlx5_esw_offloads_devcom_event,
30623062
esw);
3063-
if (IS_ERR_OR_NULL(esw->devcom))
3063+
if (IS_ERR(esw->devcom))
30643064
return;
30653065

30663066
mlx5_devcom_send_event(esw->devcom,

drivers/net/ethernet/mellanox/mlx5/core/lib/devcom.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -220,7 +220,7 @@ mlx5_devcom_register_component(struct mlx5_devcom_dev *devc,
220220
struct mlx5_devcom_comp *comp;
221221

222222
if (IS_ERR_OR_NULL(devc))
223-
return NULL;
223+
return ERR_PTR(-EINVAL);
224224

225225
mutex_lock(&comp_list_lock);
226226
comp = devcom_component_get(devc, id, key, handler);

drivers/net/ethernet/mellanox/mlx5/core/lib/sd.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -213,8 +213,8 @@ static int sd_register(struct mlx5_core_dev *dev)
213213
sd = mlx5_get_sd(dev);
214214
devcom = mlx5_devcom_register_component(dev->priv.devc, MLX5_DEVCOM_SD_GROUP,
215215
sd->group_id, NULL, dev);
216-
if (!devcom)
217-
return -ENOMEM;
216+
if (IS_ERR(devcom))
217+
return PTR_ERR(devcom);
218218

219219
sd->devcom = devcom;
220220

drivers/net/ethernet/mellanox/mlx5/core/main.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -956,7 +956,7 @@ static void mlx5_register_hca_devcom_comp(struct mlx5_core_dev *dev)
956956
mlx5_devcom_register_component(dev->priv.devc, MLX5_DEVCOM_HCA_PORTS,
957957
mlx5_query_nic_system_image_guid(dev),
958958
NULL, dev);
959-
if (IS_ERR_OR_NULL(dev->priv.hca_devcom_comp))
959+
if (IS_ERR(dev->priv.hca_devcom_comp))
960960
mlx5_core_err(dev, "Failed to register devcom HCA component\n");
961961
}
962962

0 commit comments

Comments
 (0)