net/mlx4: fix drop queue error handling
The function mlx4_drop_get() creates pointer to a struct mlx4_drop and
if needed allocates by rte_malloc.
If the allocation is failed the function goes to label “error”, and
there does dereference to a null pointer.
Skip resources cleaning when the memory allocation is failed.
Coverity issue: 146206
Coverity issue: 146146
Fixes: d3a7e09234
("net/mlx4: allocate drop flow resources on demand")
Cc: stable@dpdk.org
Signed-off-by: Michael Baum <michaelba@mellanox.com>
Acked-by: Matan Azrad <matan@mellanox.com>
This commit is contained in:
parent
c8f0abe7f8
commit
6f155c0b9d
@ -980,12 +980,13 @@ mlx4_drop_get(struct mlx4_priv *priv)
|
||||
priv->drop = drop;
|
||||
return drop;
|
||||
error:
|
||||
if (drop->qp)
|
||||
claim_zero(mlx4_glue->destroy_qp(drop->qp));
|
||||
if (drop->cq)
|
||||
claim_zero(mlx4_glue->destroy_cq(drop->cq));
|
||||
if (drop)
|
||||
if (drop) {
|
||||
if (drop->qp)
|
||||
claim_zero(mlx4_glue->destroy_qp(drop->qp));
|
||||
if (drop->cq)
|
||||
claim_zero(mlx4_glue->destroy_cq(drop->cq));
|
||||
rte_free(drop);
|
||||
}
|
||||
rte_errno = ENOMEM;
|
||||
return NULL;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user