Commit 04c41bf3 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Doug Ledford

IB/core: refactor ib_create_qp

Split the XRC magic into a separate function, and return early on failure
to make the initialization code readable.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Tested-by: default avatarSteve Wise <swise@opengridcomputing.com>
Reviewed-by: default avatarBart Van Assche <bart.vanassche@sandisk.com>
Reviewed-by: default avatarSagi Grimberg <sagi@grimberg.me>
Reviewed-by: default avatarSteve Wise <swise@opengridcomputing.com>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent 002516ed
...@@ -723,62 +723,67 @@ struct ib_qp *ib_open_qp(struct ib_xrcd *xrcd, ...@@ -723,62 +723,67 @@ struct ib_qp *ib_open_qp(struct ib_xrcd *xrcd,
} }
EXPORT_SYMBOL(ib_open_qp); EXPORT_SYMBOL(ib_open_qp);
static struct ib_qp *ib_create_xrc_qp(struct ib_qp *qp,
struct ib_qp_init_attr *qp_init_attr)
{
struct ib_qp *real_qp = qp;
qp->event_handler = __ib_shared_qp_event_handler;
qp->qp_context = qp;
qp->pd = NULL;
qp->send_cq = qp->recv_cq = NULL;
qp->srq = NULL;
qp->xrcd = qp_init_attr->xrcd;
atomic_inc(&qp_init_attr->xrcd->usecnt);
INIT_LIST_HEAD(&qp->open_list);
qp = __ib_open_qp(real_qp, qp_init_attr->event_handler,
qp_init_attr->qp_context);
if (!IS_ERR(qp))
__ib_insert_xrcd_qp(qp_init_attr->xrcd, real_qp);
else
real_qp->device->destroy_qp(real_qp);
return qp;
}
struct ib_qp *ib_create_qp(struct ib_pd *pd, struct ib_qp *ib_create_qp(struct ib_pd *pd,
struct ib_qp_init_attr *qp_init_attr) struct ib_qp_init_attr *qp_init_attr)
{ {
struct ib_qp *qp, *real_qp; struct ib_device *device = pd ? pd->device : qp_init_attr->xrcd->device;
struct ib_device *device; struct ib_qp *qp;
device = pd ? pd->device : qp_init_attr->xrcd->device;
qp = device->create_qp(pd, qp_init_attr, NULL); qp = device->create_qp(pd, qp_init_attr, NULL);
if (IS_ERR(qp))
if (!IS_ERR(qp)) { return qp;
qp->device = device;
qp->real_qp = qp; qp->device = device;
qp->uobject = NULL; qp->real_qp = qp;
qp->qp_type = qp_init_attr->qp_type; qp->uobject = NULL;
qp->qp_type = qp_init_attr->qp_type;
atomic_set(&qp->usecnt, 0);
if (qp_init_attr->qp_type == IB_QPT_XRC_TGT) { atomic_set(&qp->usecnt, 0);
qp->event_handler = __ib_shared_qp_event_handler; if (qp_init_attr->qp_type == IB_QPT_XRC_TGT)
qp->qp_context = qp; return ib_create_xrc_qp(qp, qp_init_attr);
qp->pd = NULL;
qp->send_cq = qp->recv_cq = NULL; qp->event_handler = qp_init_attr->event_handler;
qp->srq = NULL; qp->qp_context = qp_init_attr->qp_context;
qp->xrcd = qp_init_attr->xrcd; if (qp_init_attr->qp_type == IB_QPT_XRC_INI) {
atomic_inc(&qp_init_attr->xrcd->usecnt); qp->recv_cq = NULL;
INIT_LIST_HEAD(&qp->open_list); qp->srq = NULL;
} else {
real_qp = qp; qp->recv_cq = qp_init_attr->recv_cq;
qp = __ib_open_qp(real_qp, qp_init_attr->event_handler, atomic_inc(&qp_init_attr->recv_cq->usecnt);
qp_init_attr->qp_context); qp->srq = qp_init_attr->srq;
if (!IS_ERR(qp)) if (qp->srq)
__ib_insert_xrcd_qp(qp_init_attr->xrcd, real_qp); atomic_inc(&qp_init_attr->srq->usecnt);
else
real_qp->device->destroy_qp(real_qp);
} else {
qp->event_handler = qp_init_attr->event_handler;
qp->qp_context = qp_init_attr->qp_context;
if (qp_init_attr->qp_type == IB_QPT_XRC_INI) {
qp->recv_cq = NULL;
qp->srq = NULL;
} else {
qp->recv_cq = qp_init_attr->recv_cq;
atomic_inc(&qp_init_attr->recv_cq->usecnt);
qp->srq = qp_init_attr->srq;
if (qp->srq)
atomic_inc(&qp_init_attr->srq->usecnt);
}
qp->pd = pd;
qp->send_cq = qp_init_attr->send_cq;
qp->xrcd = NULL;
atomic_inc(&pd->usecnt);
atomic_inc(&qp_init_attr->send_cq->usecnt);
}
} }
qp->pd = pd;
qp->send_cq = qp_init_attr->send_cq;
qp->xrcd = NULL;
atomic_inc(&pd->usecnt);
atomic_inc(&qp_init_attr->send_cq->usecnt);
return qp; return qp;
} }
EXPORT_SYMBOL(ib_create_qp); EXPORT_SYMBOL(ib_create_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