RDMA/vmw_pvrdma: Clarify QP and CQ is_kernel logic
authorBryan Tan <bryantan@vmware.com>
Wed, 20 Dec 2017 19:24:33 +0000 (11:24 -0800)
committerJason Gunthorpe <jgg@mellanox.com>
Thu, 28 Dec 2017 04:37:26 +0000 (21:37 -0700)
Be more consistent in setting and checking is_kernel
flag for QPs and CQs.

Reviewed-by: Adit Ranadive <aditr@vmware.com>
Reviewed-by: Aditya Sarwade <asarwade@vmware.com>
Reviewed-by: Jorgen Hansen <jhansen@vmware.com>
Signed-off-by: Bryan Tan <bryantan@vmware.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/hw/vmw_pvrdma/pvrdma_cq.c
drivers/infiniband/hw/vmw_pvrdma/pvrdma_qp.c

index e529622cefad6a501492dc165458b738636842b3..cc46161249837a9205cba362b3e4364be627057c 100644 (file)
@@ -132,8 +132,9 @@ struct ib_cq *pvrdma_create_cq(struct ib_device *ibdev,
        }
 
        cq->ibcq.cqe = entries;
+       cq->is_kernel = !context;
 
-       if (context) {
+       if (!cq->is_kernel) {
                if (ib_copy_from_udata(&ucmd, udata, sizeof(ucmd))) {
                        ret = -EFAULT;
                        goto err_cq;
@@ -148,8 +149,6 @@ struct ib_cq *pvrdma_create_cq(struct ib_device *ibdev,
 
                npages = ib_umem_page_count(cq->umem);
        } else {
-               cq->is_kernel = true;
-
                /* One extra page for shared ring state */
                npages = 1 + (entries * sizeof(struct pvrdma_cqe) +
                              PAGE_SIZE - 1) / PAGE_SIZE;
@@ -202,7 +201,7 @@ struct ib_cq *pvrdma_create_cq(struct ib_device *ibdev,
        dev->cq_tbl[cq->cq_handle % dev->dsr->caps.max_cq] = cq;
        spin_unlock_irqrestore(&dev->cq_tbl_lock, flags);
 
-       if (context) {
+       if (!cq->is_kernel) {
                cq->uar = &(to_vucontext(context)->uar);
 
                /* Copy udata back. */
@@ -219,7 +218,7 @@ struct ib_cq *pvrdma_create_cq(struct ib_device *ibdev,
 err_page_dir:
        pvrdma_page_dir_cleanup(dev, &cq->pdir);
 err_umem:
-       if (context)
+       if (!cq->is_kernel)
                ib_umem_release(cq->umem);
 err_cq:
        atomic_dec(&dev->num_cqs);
index 4059308e1454a5bfda72a31d9931afaa50d39441..9dd556a7afe3de300814c60478e59be783c2d75e 100644 (file)
@@ -249,8 +249,9 @@ struct ib_qp *pvrdma_create_qp(struct ib_pd *pd,
                init_completion(&qp->free);
 
                qp->state = IB_QPS_RESET;
+               qp->is_kernel = !(pd->uobject && udata);
 
-               if (pd->uobject && udata) {
+               if (!qp->is_kernel) {
                        dev_dbg(&dev->pdev->dev,
                                "create queuepair from user space\n");
 
@@ -291,8 +292,6 @@ struct ib_qp *pvrdma_create_qp(struct ib_pd *pd,
                                qp->npages_recv = 0;
                        qp->npages = qp->npages_send + qp->npages_recv;
                } else {
-                       qp->is_kernel = true;
-
                        ret = pvrdma_set_sq_size(to_vdev(pd->device),
                                                 &init_attr->cap, qp);
                        if (ret)
@@ -394,7 +393,7 @@ struct ib_qp *pvrdma_create_qp(struct ib_pd *pd,
 err_pdir:
        pvrdma_page_dir_cleanup(dev, &qp->pdir);
 err_umem:
-       if (pd->uobject && udata) {
+       if (!qp->is_kernel) {
                if (qp->rumem)
                        ib_umem_release(qp->rumem);
                if (qp->sumem)