Commit e9105cde authored by Li Dongyang's avatar Li Dongyang Committed by Doug Ledford

IB/mlx4: use kvmalloc_array to allocate wrid

We could use kvmalloc_array instead of the
kmalloc and __vmalloc combination.
After this we don't need to include linux/vmalloc.h
Signed-off-by: default avatarLi Dongyang <dongyang.li@anu.edu.au>
Reviewed-by: default avatarLeon Romanovsky <leonro@mellanox.com>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent b5883008
...@@ -36,7 +36,6 @@ ...@@ -36,7 +36,6 @@
#include <net/ip.h> #include <net/ip.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/netdevice.h> #include <linux/netdevice.h>
#include <linux/vmalloc.h>
#include <rdma/ib_cache.h> #include <rdma/ib_cache.h>
#include <rdma/ib_pack.h> #include <rdma/ib_pack.h>
...@@ -1174,16 +1173,10 @@ static int create_qp_common(struct mlx4_ib_dev *dev, struct ib_pd *pd, ...@@ -1174,16 +1173,10 @@ static int create_qp_common(struct mlx4_ib_dev *dev, struct ib_pd *pd,
if (err) if (err)
goto err_mtt; goto err_mtt;
qp->sq.wrid = kmalloc_array(qp->sq.wqe_cnt, sizeof(u64), qp->sq.wrid = kvmalloc_array(qp->sq.wqe_cnt,
GFP_KERNEL | __GFP_NOWARN); sizeof(u64), GFP_KERNEL);
if (!qp->sq.wrid) qp->rq.wrid = kvmalloc_array(qp->rq.wqe_cnt,
qp->sq.wrid = __vmalloc(qp->sq.wqe_cnt * sizeof(u64), sizeof(u64), GFP_KERNEL);
GFP_KERNEL, PAGE_KERNEL);
qp->rq.wrid = kmalloc_array(qp->rq.wqe_cnt, sizeof(u64),
GFP_KERNEL | __GFP_NOWARN);
if (!qp->rq.wrid)
qp->rq.wrid = __vmalloc(qp->rq.wqe_cnt * sizeof(u64),
GFP_KERNEL, PAGE_KERNEL);
if (!qp->sq.wrid || !qp->rq.wrid) { if (!qp->sq.wrid || !qp->rq.wrid) {
err = -ENOMEM; err = -ENOMEM;
goto err_wrid; goto err_wrid;
......
...@@ -34,7 +34,6 @@ ...@@ -34,7 +34,6 @@
#include <linux/mlx4/qp.h> #include <linux/mlx4/qp.h>
#include <linux/mlx4/srq.h> #include <linux/mlx4/srq.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/vmalloc.h>
#include "mlx4_ib.h" #include "mlx4_ib.h"
#include <rdma/mlx4-abi.h> #include <rdma/mlx4-abi.h>
...@@ -171,17 +170,13 @@ struct ib_srq *mlx4_ib_create_srq(struct ib_pd *pd, ...@@ -171,17 +170,13 @@ struct ib_srq *mlx4_ib_create_srq(struct ib_pd *pd,
if (err) if (err)
goto err_mtt; goto err_mtt;
srq->wrid = kmalloc_array(srq->msrq.max, sizeof(u64), srq->wrid = kvmalloc_array(srq->msrq.max,
GFP_KERNEL | __GFP_NOWARN); sizeof(u64), GFP_KERNEL);
if (!srq->wrid) {
srq->wrid = __vmalloc(srq->msrq.max * sizeof(u64),
GFP_KERNEL, PAGE_KERNEL);
if (!srq->wrid) { if (!srq->wrid) {
err = -ENOMEM; err = -ENOMEM;
goto err_mtt; goto err_mtt;
} }
} }
}
cqn = (init_attr->srq_type == IB_SRQT_XRC) ? cqn = (init_attr->srq_type == IB_SRQT_XRC) ?
to_mcq(init_attr->ext.xrc.cq)->mcq.cqn : 0; to_mcq(init_attr->ext.xrc.cq)->mcq.cqn : 0;
......
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