Commit d7cade51 authored by MichelleJin's avatar MichelleJin Committed by David S. Miller

net/mlx5e: check return value of rhashtable_init

When rhashtable_init() fails, it returns -EINVAL.
However, since error return value of rhashtable_init is not checked,
it can cause use of uninitialized pointers.
So, fix unhandled errors of rhashtable_init.
Signed-off-by: default avatarMichelleJin <shjy180909@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a17aafa3
...@@ -2127,12 +2127,20 @@ mlx5_tc_ct_init(struct mlx5e_priv *priv, struct mlx5_fs_chains *chains, ...@@ -2127,12 +2127,20 @@ mlx5_tc_ct_init(struct mlx5e_priv *priv, struct mlx5_fs_chains *chains,
ct_priv->post_act = post_act; ct_priv->post_act = post_act;
mutex_init(&ct_priv->control_lock); mutex_init(&ct_priv->control_lock);
rhashtable_init(&ct_priv->zone_ht, &zone_params); if (rhashtable_init(&ct_priv->zone_ht, &zone_params))
rhashtable_init(&ct_priv->ct_tuples_ht, &tuples_ht_params); goto err_ct_zone_ht;
rhashtable_init(&ct_priv->ct_tuples_nat_ht, &tuples_nat_ht_params); if (rhashtable_init(&ct_priv->ct_tuples_ht, &tuples_ht_params))
goto err_ct_tuples_ht;
if (rhashtable_init(&ct_priv->ct_tuples_nat_ht, &tuples_nat_ht_params))
goto err_ct_tuples_nat_ht;
return ct_priv; return ct_priv;
err_ct_tuples_nat_ht:
rhashtable_destroy(&ct_priv->ct_tuples_ht);
err_ct_tuples_ht:
rhashtable_destroy(&ct_priv->zone_ht);
err_ct_zone_ht:
err_ct_nat_tbl: err_ct_nat_tbl:
mlx5_chains_destroy_global_table(chains, ct_priv->ct); mlx5_chains_destroy_global_table(chains, ct_priv->ct);
err_ct_tbl: err_ct_tbl:
......
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