RDMA/mlx4: Prevent shift wrapping in set_user_sq_size()
[ Upstream commit d50b3c73f1ac20dabc53dc6e9d64ce9c79a331eb ] The ucmd->log_sq_bb_count variable is controlled by the user so this shift can wrap. Fix it by using check_shl_overflow() in the same way that it was done in commit515f60004e
("RDMA/hns: Prevent undefined behavior in hns_roce_set_user_sq_size()"). Fixes:839041329f
("IB/mlx4: Sanity check userspace send queue sizes") Signed-off-by: Dan Carpenter <error27@gmail.com> Link: https://lore.kernel.org/r/a8dfbd1d-c019-4556-930b-bab1ded73b10@kili.mountain Signed-off-by: Leon Romanovsky <leon@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
5f5876ae29
commit
3ce0df3493
@ -412,9 +412,13 @@ static int set_user_sq_size(struct mlx4_ib_dev *dev,
|
|||||||
struct mlx4_ib_qp *qp,
|
struct mlx4_ib_qp *qp,
|
||||||
struct mlx4_ib_create_qp *ucmd)
|
struct mlx4_ib_create_qp *ucmd)
|
||||||
{
|
{
|
||||||
|
u32 cnt;
|
||||||
|
|
||||||
/* Sanity check SQ size before proceeding */
|
/* Sanity check SQ size before proceeding */
|
||||||
if ((1 << ucmd->log_sq_bb_count) > dev->dev->caps.max_wqes ||
|
if (check_shl_overflow(1, ucmd->log_sq_bb_count, &cnt) ||
|
||||||
ucmd->log_sq_stride >
|
cnt > dev->dev->caps.max_wqes)
|
||||||
|
return -EINVAL;
|
||||||
|
if (ucmd->log_sq_stride >
|
||||||
ilog2(roundup_pow_of_two(dev->dev->caps.max_sq_desc_sz)) ||
|
ilog2(roundup_pow_of_two(dev->dev->caps.max_sq_desc_sz)) ||
|
||||||
ucmd->log_sq_stride < MLX4_IB_MIN_SQ_STRIDE)
|
ucmd->log_sq_stride < MLX4_IB_MIN_SQ_STRIDE)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
Loading…
Reference in New Issue
Block a user