aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/infiniband/hw/mlx5/main.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/infiniband/hw/mlx5/main.c b/drivers/infiniband/hw/mlx5/main.c
index f509dcb85665..f82336699c3e 100644
--- a/drivers/infiniband/hw/mlx5/main.c
+++ b/drivers/infiniband/hw/mlx5/main.c
@@ -845,6 +845,9 @@ static struct ib_ucontext *mlx5_ib_alloc_ucontext(struct ib_device *ibdev,
845 if (!dev->ib_active) 845 if (!dev->ib_active)
846 return ERR_PTR(-EAGAIN); 846 return ERR_PTR(-EAGAIN);
847 847
848 if (udata->inlen < sizeof(struct ib_uverbs_cmd_hdr))
849 return ERR_PTR(-EINVAL);
850
848 reqlen = udata->inlen - sizeof(struct ib_uverbs_cmd_hdr); 851 reqlen = udata->inlen - sizeof(struct ib_uverbs_cmd_hdr);
849 if (reqlen == sizeof(struct mlx5_ib_alloc_ucontext_req)) 852 if (reqlen == sizeof(struct mlx5_ib_alloc_ucontext_req))
850 ver = 0; 853 ver = 0;
@@ -871,7 +874,7 @@ static struct ib_ucontext *mlx5_ib_alloc_ucontext(struct ib_device *ibdev,
871 874
872 if (reqlen > sizeof(req) && 875 if (reqlen > sizeof(req) &&
873 !ib_is_udata_cleared(udata, sizeof(req), 876 !ib_is_udata_cleared(udata, sizeof(req),
874 udata->inlen - sizeof(req))) 877 reqlen - sizeof(req)))
875 return ERR_PTR(-EOPNOTSUPP); 878 return ERR_PTR(-EOPNOTSUPP);
876 879
877 req.total_num_uuars = ALIGN(req.total_num_uuars, 880 req.total_num_uuars = ALIGN(req.total_num_uuars,