mlx4: FIX error flow when initializing EQ table
If mlx4_create_eq() would fail for one of EQ's assigned for completion handling, the code would try to free the same EQ we failed to create. The crash was found by Christoph Lameter Signed-off-by: Yevgeny Petrilin <yevgenyp@mellanox.co.il> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
6f536f4039
commit
a5b19b635c
|
@ -623,8 +623,10 @@ int mlx4_init_eq_table(struct mlx4_dev *dev)
|
||||||
err = mlx4_create_eq(dev, dev->caps.num_cqs + MLX4_NUM_SPARE_EQE,
|
err = mlx4_create_eq(dev, dev->caps.num_cqs + MLX4_NUM_SPARE_EQE,
|
||||||
(dev->flags & MLX4_FLAG_MSI_X) ? i : 0,
|
(dev->flags & MLX4_FLAG_MSI_X) ? i : 0,
|
||||||
&priv->eq_table.eq[i]);
|
&priv->eq_table.eq[i]);
|
||||||
if (err)
|
if (err) {
|
||||||
|
--i;
|
||||||
goto err_out_unmap;
|
goto err_out_unmap;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
err = mlx4_create_eq(dev, MLX4_NUM_ASYNC_EQE + MLX4_NUM_SPARE_EQE,
|
err = mlx4_create_eq(dev, MLX4_NUM_ASYNC_EQE + MLX4_NUM_SPARE_EQE,
|
||||||
|
|
Loading…
Reference in New Issue