提交 20e5a59b 编写于 作者: G Guy Levi 提交者: Jason Gunthorpe

IB/mlx5: Use fragmented SRQ's buffer for in-kernel users

The current implementation of create SRQ requires contiguous memory, such
a requirement is problematic once the memory is fragmented or the system
is low in memory, it causes failures in dma_zalloc_coherent().

This patch takes the advantage of the new mlx5_core API which allocates a
fragmented buffer, and makes the SRQ creation much more resilient to
memory fragmentation. Data-path code was adapted to the fact that WQEs can
cross buffers.
Signed-off-by: NGuy Levi <guyle@mellanox.com>
Reviewed-by: NMajd Dibbiny <majd@mellanox.com>
Reviewed-by: NYishai Hadas <yishaih@mellanox.com>
Signed-off-by: NLeon Romanovsky <leonro@mellanox.com>
Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
上级 b024dd0e
...@@ -523,6 +523,7 @@ struct mlx5_ib_srq { ...@@ -523,6 +523,7 @@ struct mlx5_ib_srq {
struct mlx5_core_srq msrq; struct mlx5_core_srq msrq;
struct mlx5_frag_buf buf; struct mlx5_frag_buf buf;
struct mlx5_db db; struct mlx5_db db;
struct mlx5_frag_buf_ctrl fbc;
u64 *wrid; u64 *wrid;
/* protect SRQ hanlding /* protect SRQ hanlding
*/ */
......
...@@ -44,7 +44,7 @@ static int srq_signature; ...@@ -44,7 +44,7 @@ static int srq_signature;
static void *get_wqe(struct mlx5_ib_srq *srq, int n) static void *get_wqe(struct mlx5_ib_srq *srq, int n)
{ {
return mlx5_buf_offset(&srq->buf, n << srq->msrq.wqe_shift); return mlx5_frag_buf_get_wqe(&srq->fbc, n);
} }
static void mlx5_ib_srq_event(struct mlx5_core_srq *srq, enum mlx5_event type) static void mlx5_ib_srq_event(struct mlx5_core_srq *srq, enum mlx5_event type)
...@@ -173,12 +173,16 @@ static int create_srq_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_srq *srq, ...@@ -173,12 +173,16 @@ static int create_srq_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_srq *srq,
return err; return err;
} }
if (mlx5_buf_alloc(dev->mdev, buf_size, &srq->buf)) { if (mlx5_frag_buf_alloc_node(dev->mdev, buf_size, &srq->buf,
dev->mdev->priv.numa_node)) {
mlx5_ib_dbg(dev, "buf alloc failed\n"); mlx5_ib_dbg(dev, "buf alloc failed\n");
err = -ENOMEM; err = -ENOMEM;
goto err_db; goto err_db;
} }
mlx5_init_fbc(srq->buf.frags, srq->msrq.wqe_shift, ilog2(srq->msrq.max),
&srq->fbc);
srq->head = 0; srq->head = 0;
srq->tail = srq->msrq.max - 1; srq->tail = srq->msrq.max - 1;
srq->wqe_ctr = 0; srq->wqe_ctr = 0;
...@@ -195,7 +199,7 @@ static int create_srq_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_srq *srq, ...@@ -195,7 +199,7 @@ static int create_srq_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_srq *srq,
err = -ENOMEM; err = -ENOMEM;
goto err_buf; goto err_buf;
} }
mlx5_fill_page_array(&srq->buf, in->pas); mlx5_fill_page_frag_array(&srq->buf, in->pas);
srq->wrid = kvmalloc_array(srq->msrq.max, sizeof(u64), GFP_KERNEL); srq->wrid = kvmalloc_array(srq->msrq.max, sizeof(u64), GFP_KERNEL);
if (!srq->wrid) { if (!srq->wrid) {
...@@ -215,7 +219,7 @@ static int create_srq_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_srq *srq, ...@@ -215,7 +219,7 @@ static int create_srq_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_srq *srq,
kvfree(in->pas); kvfree(in->pas);
err_buf: err_buf:
mlx5_buf_free(dev->mdev, &srq->buf); mlx5_frag_buf_free(dev->mdev, &srq->buf);
err_db: err_db:
mlx5_db_free(dev->mdev, &srq->db); mlx5_db_free(dev->mdev, &srq->db);
...@@ -232,7 +236,7 @@ static void destroy_srq_user(struct ib_pd *pd, struct mlx5_ib_srq *srq) ...@@ -232,7 +236,7 @@ static void destroy_srq_user(struct ib_pd *pd, struct mlx5_ib_srq *srq)
static void destroy_srq_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_srq *srq) static void destroy_srq_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_srq *srq)
{ {
kvfree(srq->wrid); kvfree(srq->wrid);
mlx5_buf_free(dev->mdev, &srq->buf); mlx5_frag_buf_free(dev->mdev, &srq->buf);
mlx5_db_free(dev->mdev, &srq->db); mlx5_db_free(dev->mdev, &srq->db);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册