Commit 747c519c authored by Leon Romanovsky's avatar Leon Romanovsky Committed by Jason Gunthorpe

RDMA/mlx5: Reduce amount of duplication in QP destroy

Delete both PD argument and checks if udata was provided, in favour
of unified destroy QP functions.

Link: https://lore.kernel.org/r/20200427154636.381474-30-leon@kernel.orgReviewed-by: default avatarMaor Gottlieb <maorg@mellanox.com>
Signed-off-by: default avatarLeon Romanovsky <leonro@mellanox.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@mellanox.com>
parent 98fc1126
...@@ -1038,25 +1038,36 @@ static int _create_user_qp(struct mlx5_ib_dev *dev, struct ib_pd *pd, ...@@ -1038,25 +1038,36 @@ static int _create_user_qp(struct mlx5_ib_dev *dev, struct ib_pd *pd,
return err; return err;
} }
static void destroy_qp_user(struct mlx5_ib_dev *dev, struct ib_pd *pd, static void destroy_qp(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
struct mlx5_ib_qp *qp, struct mlx5_ib_qp_base *base, struct mlx5_ib_qp_base *base, struct ib_udata *udata)
struct ib_udata *udata)
{ {
struct mlx5_ib_ucontext *context = struct mlx5_ib_ucontext *context = rdma_udata_to_drv_context(
rdma_udata_to_drv_context( udata, struct mlx5_ib_ucontext, ibucontext);
udata,
struct mlx5_ib_ucontext,
ibucontext);
mlx5_ib_db_unmap_user(context, &qp->db); if (udata) {
ib_umem_release(base->ubuffer.umem); /* User QP */
mlx5_ib_db_unmap_user(context, &qp->db);
ib_umem_release(base->ubuffer.umem);
/* /*
* Free only the BFREGs which are handled by the kernel. * Free only the BFREGs which are handled by the kernel.
* BFREGs of UARs allocated dynamically are handled by user. * BFREGs of UARs allocated dynamically are handled by user.
*/ */
if (qp->bfregn != MLX5_IB_INVALID_BFREG) if (qp->bfregn != MLX5_IB_INVALID_BFREG)
mlx5_ib_free_bfreg(dev, &context->bfregi, qp->bfregn); mlx5_ib_free_bfreg(dev, &context->bfregi, qp->bfregn);
return;
}
/* Kernel QP */
kvfree(qp->sq.wqe_head);
kvfree(qp->sq.w_list);
kvfree(qp->sq.wrid);
kvfree(qp->sq.wr_data);
kvfree(qp->rq.wrid);
if (qp->db.db)
mlx5_db_free(dev->mdev, &qp->db);
if (qp->buf.frags)
mlx5_frag_buf_free(dev->mdev, &qp->buf);
} }
/* get_sq_edge - Get the next nearby edge. /* get_sq_edge - Get the next nearby edge.
...@@ -1202,19 +1213,6 @@ static int _create_kernel_qp(struct mlx5_ib_dev *dev, ...@@ -1202,19 +1213,6 @@ static int _create_kernel_qp(struct mlx5_ib_dev *dev,
return err; return err;
} }
static void destroy_qp_kernel(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp)
{
kvfree(qp->sq.wqe_head);
kvfree(qp->sq.w_list);
kvfree(qp->sq.wrid);
kvfree(qp->sq.wr_data);
kvfree(qp->rq.wrid);
if (qp->db.db)
mlx5_db_free(dev->mdev, &qp->db);
if (qp->buf.frags)
mlx5_frag_buf_free(dev->mdev, &qp->buf);
}
static u32 get_rx_type(struct mlx5_ib_qp *qp, struct ib_qp_init_attr *attr) static u32 get_rx_type(struct mlx5_ib_qp *qp, struct ib_qp_init_attr *attr)
{ {
if (attr->srq || (qp->type == IB_QPT_XRC_TGT) || if (attr->srq || (qp->type == IB_QPT_XRC_TGT) ||
...@@ -1972,7 +1970,7 @@ static int create_xrc_tgt_qp(struct mlx5_ib_dev *dev, ...@@ -1972,7 +1970,7 @@ static int create_xrc_tgt_qp(struct mlx5_ib_dev *dev,
err = mlx5_core_create_qp(dev, &base->mqp, in, inlen); err = mlx5_core_create_qp(dev, &base->mqp, in, inlen);
kvfree(in); kvfree(in);
if (err) { if (err) {
destroy_qp_user(dev, NULL, qp, base, udata); destroy_qp(dev, qp, base, udata);
return err; return err;
} }
...@@ -2170,10 +2168,7 @@ static int create_user_qp(struct mlx5_ib_dev *dev, struct ib_pd *pd, ...@@ -2170,10 +2168,7 @@ static int create_user_qp(struct mlx5_ib_dev *dev, struct ib_pd *pd,
return 0; return 0;
err_create: err_create:
if (udata) destroy_qp(dev, qp, base, udata);
destroy_qp_user(dev, pd, qp, base, udata);
else
destroy_qp_kernel(dev, qp);
return err; return err;
} }
...@@ -2300,7 +2295,7 @@ static int create_kernel_qp(struct mlx5_ib_dev *dev, struct ib_pd *pd, ...@@ -2300,7 +2295,7 @@ static int create_kernel_qp(struct mlx5_ib_dev *dev, struct ib_pd *pd,
return 0; return 0;
err_create: err_create:
destroy_qp_kernel(dev, qp); destroy_qp(dev, qp, base, NULL);
return err; return err;
} }
...@@ -2470,10 +2465,7 @@ static void destroy_qp_common(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp, ...@@ -2470,10 +2465,7 @@ static void destroy_qp_common(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
base->mqp.qpn); base->mqp.qpn);
} }
if (udata) destroy_qp(dev, qp, base, udata);
destroy_qp_user(dev, &get_pd(qp)->ibpd, qp, base, udata);
else
destroy_qp_kernel(dev, qp);
} }
static int create_dct(struct ib_pd *pd, struct mlx5_ib_qp *qp, static int create_dct(struct ib_pd *pd, struct mlx5_ib_qp *qp,
......
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