OSDN Git Service

RDMA/core: Do not erase the type of ib_wq.uobject
authorJason Gunthorpe <jgg@mellanox.com>
Wed, 8 Jan 2020 17:22:01 +0000 (19:22 +0200)
committerJason Gunthorpe <jgg@mellanox.com>
Mon, 13 Jan 2020 20:20:16 +0000 (16:20 -0400)
This is a struct ib_uwq_object pointer, instead of using container_of()
all over the place just store it with its actual type.

Link: https://lore.kernel.org/r/1578504126-9400-10-git-send-email-yishaih@mellanox.com
Signed-off-by: Yishai Hadas <yishaih@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/core/uverbs_cmd.c
drivers/infiniband/core/uverbs_main.c
include/rdma/ib_verbs.h

index 8350e02..66f86b4 100644 (file)
@@ -2971,7 +2971,7 @@ static int ib_uverbs_ex_create_wq(struct uverbs_attr_bundle *attrs)
                goto err_put_cq;
        }
 
-       wq->uobject = &obj->uevent.uobject;
+       wq->uobject = obj;
        obj->uevent.uobject.object = wq;
        wq->wq_type = wq_init_attr.wq_type;
        wq->cq = cq;
@@ -2981,7 +2981,7 @@ static int ib_uverbs_ex_create_wq(struct uverbs_attr_bundle *attrs)
        atomic_set(&wq->usecnt, 0);
        atomic_inc(&pd->usecnt);
        atomic_inc(&cq->usecnt);
-       wq->uobject = &obj->uevent.uobject;
+       wq->uobject = obj;
        obj->uevent.uobject.object = wq;
 
        memset(&resp, 0, sizeof(resp));
@@ -3070,7 +3070,8 @@ static int ib_uverbs_ex_modify_wq(struct uverbs_attr_bundle *attrs)
        }
        ret = wq->device->ops.modify_wq(wq, &wq_attr, cmd.attr_mask,
                                        &attrs->driver_udata);
-       uobj_put_obj_read(wq);
+       rdma_lookup_put_uobject(&wq->uobject->uevent.uobject,
+                               UVERBS_LOOKUP_READ);
        return ret;
 }
 
@@ -3171,7 +3172,8 @@ static int ib_uverbs_ex_create_rwq_ind_table(struct uverbs_attr_bundle *attrs)
        kfree(wqs_handles);
 
        for (j = 0; j < num_read_wqs; j++)
-               uobj_put_obj_read(wqs[j]);
+               rdma_lookup_put_uobject(&wqs[j]->uobject->uevent.uobject,
+                                       UVERBS_LOOKUP_READ);
 
        rdma_alloc_commit_uobject(uobj, attrs);
        return 0;
@@ -3182,7 +3184,8 @@ err_uobj:
        uobj_alloc_abort(uobj, attrs);
 put_wqs:
        for (j = 0; j < num_read_wqs; j++)
-               uobj_put_obj_read(wqs[j]);
+               rdma_lookup_put_uobject(&wqs[j]->uobject->uevent.uobject,
+                                       UVERBS_LOOKUP_READ);
 err_free:
        kfree(wqs_handles);
        kfree(wqs);
index a501f76..87f7a94 100644 (file)
@@ -481,8 +481,7 @@ void ib_uverbs_qp_event_handler(struct ib_event *event, void *context_ptr)
 
 void ib_uverbs_wq_event_handler(struct ib_event *event, void *context_ptr)
 {
-       struct ib_uevent_object *uobj = container_of(event->element.wq->uobject,
-                                                 struct ib_uevent_object, uobject);
+       struct ib_uevent_object *uobj = &event->element.wq->uobject->uevent;
 
        ib_uverbs_async_handler(context_ptr, uobj->uobject.user_handle,
                                event->event, &uobj->event_list,
index 7990b55..d8031f6 100644 (file)
@@ -74,6 +74,7 @@
 struct ib_umem_odp;
 struct ib_uqp_object;
 struct ib_usrq_object;
+struct ib_uwq_object;
 
 extern struct workqueue_struct *ib_wq;
 extern struct workqueue_struct *ib_comp_wq;
@@ -1621,7 +1622,7 @@ enum ib_wq_state {
 
 struct ib_wq {
        struct ib_device       *device;
-       struct ib_uobject      *uobject;
+       struct ib_uwq_object   *uobject;
        void                *wq_context;
        void                (*event_handler)(struct ib_event *, void *);
        struct ib_pd           *pd;