@@ -20,8 +20,10 @@ struct ib_mr *ib_mr_pool_get(struct ib_qp *qp, struct list_head *list)
spin_lock_irqsave(&qp->mr_lock, flags);
mr = list_first_entry_or_null(list, struct ib_mr, qp_entry);
- if (mr)
+ if (mr) {
+ list_del(&mr->qp_entry);
qp->mrs_used++;
+ }
spin_unlock_irqrestore(&qp->mr_lock, flags);
return mr;
@@ -384,10 +384,23 @@ int rdma_rw_init_mrs(struct ib_qp *qp, struct ib_qp_init_attr *attr)
dev->attrs.max_fast_reg_page_list_len);
}
+ if (attr->create_flags & IB_QP_CREATE_SIGNATURE_EN) {
+ ret = ib_mr_pool_init(qp, &qp->sig_mrs,
+ attr->cap.max_rdma_ctxs, IB_MR_TYPE_SIGNATURE,
+ 2);
+ if (ret)
+ goto out_free_rdma_mrs;
+ }
+
+ return 0;
+
+out_free_rdma_mrs:
+ ib_mr_pool_destroy(qp, &qp->rdma_mrs);
return ret;
}
void rdma_rw_cleanup_mrs(struct ib_qp *qp)
{
+ ib_mr_pool_destroy(qp, &qp->sig_mrs);
ib_mr_pool_destroy(qp, &qp->rdma_mrs);
}
@@ -776,6 +776,7 @@ struct ib_qp *ib_create_qp(struct ib_pd *pd,
qp->mrs_used = 0;
spin_lock_init(&qp->mr_lock);
INIT_LIST_HEAD(&qp->rdma_mrs);
+ INIT_LIST_HEAD(&qp->sig_mrs);
if (qp_init_attr->qp_type == IB_QPT_XRC_TGT)
return ib_create_xrc_qp(qp, qp_init_attr);
@@ -1422,6 +1422,7 @@ struct ib_qp {
spinlock_t mr_lock;
struct list_head rdma_mrs;
+ struct list_head sig_mrs;
int mrs_used;
/* count times opened, mcast attaches, flow attaches */
Signed-off-by: Christoph Hellwig <hch@lst.de> --- drivers/infiniband/core/mr_pool.c | 4 +++- drivers/infiniband/core/rw.c | 13 +++++++++++++ drivers/infiniband/core/verbs.c | 1 + include/rdma/ib_verbs.h | 1 + 4 files changed, 18 insertions(+), 1 deletion(-)