IB: Pass uverbs_attr_bundle down uobject destroy path
authorShamir Rabinovitch <shamir.rabinovitch@oracle.com>
Sun, 31 Mar 2019 16:10:04 +0000 (19:10 +0300)
committerJason Gunthorpe <jgg@mellanox.com>
Mon, 1 Apr 2019 17:55:36 +0000 (14:55 -0300)
Pass uverbs_attr_bundle down the uobject destroy path. The next patch will
use this to eliminate the dependecy of the drivers in ib_x->uobject
pointers.

Signed-off-by: Shamir Rabinovitch <shamir.rabinovitch@oracle.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
14 files changed:
drivers/infiniband/core/rdma_core.c
drivers/infiniband/core/rdma_core.h
drivers/infiniband/core/uverbs_cmd.c
drivers/infiniband/core/uverbs_ioctl.c
drivers/infiniband/core/uverbs_std_types.c
drivers/infiniband/core/uverbs_std_types_counters.c
drivers/infiniband/core/uverbs_std_types_cq.c
drivers/infiniband/core/uverbs_std_types_dm.c
drivers/infiniband/core/uverbs_std_types_flow_action.c
drivers/infiniband/core/uverbs_std_types_mr.c
drivers/infiniband/hw/mlx5/devx.c
drivers/infiniband/hw/mlx5/flow.c
include/rdma/uverbs_std_types.h
include/rdma/uverbs_types.h

index 0d18fb0e975d398ccc7047896c7d30e585e93026..d0a6755c0562abf5483aedc8240bd4f7e925d16a 100644 (file)
@@ -125,7 +125,8 @@ static void assert_uverbs_usecnt(struct ib_uobject *uobj,
  * and consumes the kref on the uobj.
  */
 static int uverbs_destroy_uobject(struct ib_uobject *uobj,
-                                 enum rdma_remove_reason reason)
+                                 enum rdma_remove_reason reason,
+                                 struct uverbs_attr_bundle *attrs)
 {
        struct ib_uverbs_file *ufile = uobj->ufile;
        unsigned long flags;
@@ -135,7 +136,8 @@ static int uverbs_destroy_uobject(struct ib_uobject *uobj,
        assert_uverbs_usecnt(uobj, UVERBS_LOOKUP_WRITE);
 
        if (uobj->object) {
-               ret = uobj->uapi_object->type_class->destroy_hw(uobj, reason);
+               ret = uobj->uapi_object->type_class->destroy_hw(uobj, reason,
+                                                               attrs);
                if (ret) {
                        if (ib_is_destroy_retryable(ret, reason, uobj))
                                return ret;
@@ -196,7 +198,7 @@ static int uverbs_destroy_uobject(struct ib_uobject *uobj,
  * version requires the caller to have already obtained an
  * LOOKUP_DESTROY uobject kref.
  */
-int uobj_destroy(struct ib_uobject *uobj)
+int uobj_destroy(struct ib_uobject *uobj, struct uverbs_attr_bundle *attrs)
 {
        struct ib_uverbs_file *ufile = uobj->ufile;
        int ret;
@@ -207,7 +209,7 @@ int uobj_destroy(struct ib_uobject *uobj)
        if (ret)
                goto out_unlock;
 
-       ret = uverbs_destroy_uobject(uobj, RDMA_REMOVE_DESTROY);
+       ret = uverbs_destroy_uobject(uobj, RDMA_REMOVE_DESTROY, attrs);
        if (ret) {
                atomic_set(&uobj->usecnt, 0);
                goto out_unlock;
@@ -234,7 +236,7 @@ struct ib_uobject *__uobj_get_destroy(const struct uverbs_api_object *obj,
        if (IS_ERR(uobj))
                return uobj;
 
-       ret = uobj_destroy(uobj);
+       ret = uobj_destroy(uobj, attrs);
        if (ret) {
                rdma_lookup_put_uobject(uobj, UVERBS_LOOKUP_DESTROY);
                return ERR_PTR(ret);
@@ -533,12 +535,13 @@ static void alloc_abort_idr_uobject(struct ib_uobject *uobj)
 }
 
 static int __must_check destroy_hw_idr_uobject(struct ib_uobject *uobj,
-                                              enum rdma_remove_reason why)
+                                              enum rdma_remove_reason why,
+                                              struct uverbs_attr_bundle *attrs)
 {
        const struct uverbs_obj_idr_type *idr_type =
                container_of(uobj->uapi_object->type_attrs,
                             struct uverbs_obj_idr_type, type);
-       int ret = idr_type->destroy_object(uobj, why);
+       int ret = idr_type->destroy_object(uobj, why, attrs);
 
        /*
         * We can only fail gracefully if the user requested to destroy the
@@ -572,7 +575,8 @@ static void alloc_abort_fd_uobject(struct ib_uobject *uobj)
 }
 
 static int __must_check destroy_hw_fd_uobject(struct ib_uobject *uobj,
-                                             enum rdma_remove_reason why)
+                                             enum rdma_remove_reason why,
+                                             struct uverbs_attr_bundle *attrs)
 {
        const struct uverbs_obj_fd_type *fd_type = container_of(
                uobj->uapi_object->type_attrs, struct uverbs_obj_fd_type, type);
@@ -648,7 +652,8 @@ static int alloc_commit_fd_uobject(struct ib_uobject *uobj)
  * caller can no longer assume uobj is valid. If this function fails it
  * destroys the uboject, including the attached HW object.
  */
-int __must_check rdma_alloc_commit_uobject(struct ib_uobject *uobj)
+int __must_check rdma_alloc_commit_uobject(struct ib_uobject *uobj,
+                                          struct uverbs_attr_bundle *attrs)
 {
        struct ib_uverbs_file *ufile = uobj->ufile;
        int ret;
@@ -656,7 +661,7 @@ int __must_check rdma_alloc_commit_uobject(struct ib_uobject *uobj)
        /* alloc_commit consumes the uobj kref */
        ret = uobj->uapi_object->type_class->alloc_commit(uobj);
        if (ret) {
-               uverbs_destroy_uobject(uobj, RDMA_REMOVE_ABORT);
+               uverbs_destroy_uobject(uobj, RDMA_REMOVE_ABORT, attrs);
                up_read(&ufile->hw_destroy_rwsem);
                return ret;
        }
@@ -680,12 +685,13 @@ int __must_check rdma_alloc_commit_uobject(struct ib_uobject *uobj)
  * This consumes the kref for uobj. It is up to the caller to unwind the HW
  * object and anything else connected to uobj before calling this.
  */
-void rdma_alloc_abort_uobject(struct ib_uobject *uobj)
+void rdma_alloc_abort_uobject(struct ib_uobject *uobj,
+                             struct uverbs_attr_bundle *attrs)
 {
        struct ib_uverbs_file *ufile = uobj->ufile;
 
        uobj->object = NULL;
-       uverbs_destroy_uobject(uobj, RDMA_REMOVE_ABORT);
+       uverbs_destroy_uobject(uobj, RDMA_REMOVE_ABORT, attrs);
 
        /* Matches the down_read in rdma_alloc_begin_uobject */
        up_read(&ufile->hw_destroy_rwsem);
@@ -787,6 +793,10 @@ void uverbs_close_fd(struct file *f)
 {
        struct ib_uobject *uobj = f->private_data;
        struct ib_uverbs_file *ufile = uobj->ufile;
+       struct uverbs_attr_bundle attrs = {
+               .context = uobj->context,
+               .ufile = ufile,
+       };
 
        if (down_read_trylock(&ufile->hw_destroy_rwsem)) {
                /*
@@ -796,7 +806,7 @@ void uverbs_close_fd(struct file *f)
                 * write lock here, or we have a kernel bug.
                 */
                WARN_ON(uverbs_try_lock_object(uobj, UVERBS_LOOKUP_WRITE));
-               uverbs_destroy_uobject(uobj, RDMA_REMOVE_CLOSE);
+               uverbs_destroy_uobject(uobj, RDMA_REMOVE_CLOSE, &attrs);
                up_read(&ufile->hw_destroy_rwsem);
        }
 
@@ -845,6 +855,7 @@ static int __uverbs_cleanup_ufile(struct ib_uverbs_file *ufile,
 {
        struct ib_uobject *obj, *next_obj;
        int ret = -EINVAL;
+       struct uverbs_attr_bundle attrs = { .ufile = ufile };
 
        /*
         * This shouldn't run while executing other commands on this
@@ -856,12 +867,13 @@ static int __uverbs_cleanup_ufile(struct ib_uverbs_file *ufile,
         * other threads (which might still use the FDs) chance to run.
         */
        list_for_each_entry_safe(obj, next_obj, &ufile->uobjects, list) {
+               attrs.context = obj->context;
                /*
                 * if we hit this WARN_ON, that means we are
                 * racing with a lookup_get.
                 */
                WARN_ON(uverbs_try_lock_object(obj, UVERBS_LOOKUP_WRITE));
-               if (!uverbs_destroy_uobject(obj, reason))
+               if (!uverbs_destroy_uobject(obj, reason, &attrs))
                        ret = 0;
                else
                        atomic_set(&obj->usecnt, 0);
@@ -966,8 +978,8 @@ uverbs_get_uobject_from_file(u16 object_id, enum uverbs_obj_access access,
 }
 
 int uverbs_finalize_object(struct ib_uobject *uobj,
-                          enum uverbs_obj_access access,
-                          bool commit)
+                          enum uverbs_obj_access access, bool commit,
+                          struct uverbs_attr_bundle *attrs)
 {
        int ret = 0;
 
@@ -990,9 +1002,9 @@ int uverbs_finalize_object(struct ib_uobject *uobj,
                break;
        case UVERBS_ACCESS_NEW:
                if (commit)
-                       ret = rdma_alloc_commit_uobject(uobj);
+                       ret = rdma_alloc_commit_uobject(uobj, attrs);
                else
-                       rdma_alloc_abort_uobject(uobj);
+                       rdma_alloc_abort_uobject(uobj, attrs);
                break;
        default:
                WARN_ON(true);
index d91d44f4fa89d4b6dc4654fcc0fd5cf7096a32c9..5445323629b5b5f73bfdfc1b3b94de6f27a1e44a 100644 (file)
@@ -48,7 +48,7 @@ struct ib_uverbs_device;
 void uverbs_destroy_ufile_hw(struct ib_uverbs_file *ufile,
                             enum rdma_remove_reason reason);
 
-int uobj_destroy(struct ib_uobject *uobj);
+int uobj_destroy(struct ib_uobject *uobj, struct uverbs_attr_bundle *attrs);
 
 /*
  * uverbs_uobject_get is called in order to increase the reference count on
@@ -102,8 +102,8 @@ uverbs_get_uobject_from_file(u16 object_id, enum uverbs_obj_access access,
  * object.
  */
 int uverbs_finalize_object(struct ib_uobject *uobj,
-                          enum uverbs_obj_access access,
-                          bool commit);
+                          enum uverbs_obj_access access, bool commit,
+                          struct uverbs_attr_bundle *attrs);
 
 int uverbs_output_written(const struct uverbs_attr_bundle *bundle, size_t idx);
 
index 5115a050f31333935543ecbf90c726d6c046026b..726275288887911643eb97ea6c456ed448112789 100644 (file)
@@ -436,7 +436,7 @@ static int ib_uverbs_alloc_pd(struct uverbs_attr_bundle *attrs)
        if (ret)
                goto err_copy;
 
-       return uobj_alloc_commit(uobj);
+       return uobj_alloc_commit(uobj, attrs);
 
 err_copy:
        ib_dealloc_pd(pd);
@@ -444,7 +444,7 @@ err_copy:
 err_alloc:
        kfree(pd);
 err:
-       uobj_alloc_abort(uobj);
+       uobj_alloc_abort(uobj, attrs);
        return ret;
 }
 
@@ -633,7 +633,7 @@ static int ib_uverbs_open_xrcd(struct uverbs_attr_bundle *attrs)
 
        mutex_unlock(&ibudev->xrcd_tree_mutex);
 
-       return uobj_alloc_commit(&obj->uobject);
+       return uobj_alloc_commit(&obj->uobject, attrs);
 
 err_copy:
        if (inode) {
@@ -646,7 +646,7 @@ err_dealloc_xrcd:
        ib_dealloc_xrcd(xrcd);
 
 err:
-       uobj_alloc_abort(&obj->uobject);
+       uobj_alloc_abort(&obj->uobject, attrs);
 
 err_tree_mutex_unlock:
        if (f.file)
@@ -763,7 +763,7 @@ static int ib_uverbs_reg_mr(struct uverbs_attr_bundle *attrs)
 
        uobj_put_obj_read(pd);
 
-       return uobj_alloc_commit(uobj);
+       return uobj_alloc_commit(uobj, attrs);
 
 err_copy:
        ib_dereg_mr(mr);
@@ -772,7 +772,7 @@ err_put:
        uobj_put_obj_read(pd);
 
 err_free:
-       uobj_alloc_abort(uobj);
+       uobj_alloc_abort(uobj, attrs);
        return ret;
 }
 
@@ -917,14 +917,14 @@ static int ib_uverbs_alloc_mw(struct uverbs_attr_bundle *attrs)
                goto err_copy;
 
        uobj_put_obj_read(pd);
-       return uobj_alloc_commit(uobj);
+       return uobj_alloc_commit(uobj, attrs);
 
 err_copy:
        uverbs_dealloc_mw(mw);
 err_put:
        uobj_put_obj_read(pd);
 err_free:
-       uobj_alloc_abort(uobj);
+       uobj_alloc_abort(uobj, attrs);
        return ret;
 }
 
@@ -965,11 +965,11 @@ static int ib_uverbs_create_comp_channel(struct uverbs_attr_bundle *attrs)
 
        ret = uverbs_response(attrs, &resp, sizeof(resp));
        if (ret) {
-               uobj_alloc_abort(uobj);
+               uobj_alloc_abort(uobj, attrs);
                return ret;
        }
 
-       return uobj_alloc_commit(uobj);
+       return uobj_alloc_commit(uobj, attrs);
 }
 
 static struct ib_ucq_object *create_cq(struct uverbs_attr_bundle *attrs,
@@ -1036,7 +1036,7 @@ static struct ib_ucq_object *create_cq(struct uverbs_attr_bundle *attrs,
        if (ret)
                goto err_cb;
 
-       ret = uobj_alloc_commit(&obj->uobject);
+       ret = uobj_alloc_commit(&obj->uobject, attrs);
        if (ret)
                return ERR_PTR(ret);
        return obj;
@@ -1049,7 +1049,7 @@ err_file:
                ib_uverbs_release_ucq(attrs->ufile, ev_file, obj);
 
 err:
-       uobj_alloc_abort(&obj->uobject);
+       uobj_alloc_abort(&obj->uobject, attrs);
 
        return ERR_PTR(ret);
 }
@@ -1477,7 +1477,7 @@ static int create_qp(struct uverbs_attr_bundle *attrs,
        if (ind_tbl)
                uobj_put_obj_read(ind_tbl);
 
-       return uobj_alloc_commit(&obj->uevent.uobject);
+       return uobj_alloc_commit(&obj->uevent.uobject, attrs);
 err_cb:
        ib_destroy_qp(qp);
 
@@ -1495,7 +1495,7 @@ err_put:
        if (ind_tbl)
                uobj_put_obj_read(ind_tbl);
 
-       uobj_alloc_abort(&obj->uevent.uobject);
+       uobj_alloc_abort(&obj->uevent.uobject, attrs);
        return ret;
 }
 
@@ -1609,14 +1609,14 @@ static int ib_uverbs_open_qp(struct uverbs_attr_bundle *attrs)
        qp->uobject = &obj->uevent.uobject;
        uobj_put_read(xrcd_uobj);
 
-       return uobj_alloc_commit(&obj->uevent.uobject);
+       return uobj_alloc_commit(&obj->uevent.uobject, attrs);
 
 err_destroy:
        ib_destroy_qp(qp);
 err_xrcd:
        uobj_put_read(xrcd_uobj);
 err_put:
-       uobj_alloc_abort(&obj->uevent.uobject);
+       uobj_alloc_abort(&obj->uevent.uobject, attrs);
        return ret;
 }
 
@@ -2451,7 +2451,7 @@ static int ib_uverbs_create_ah(struct uverbs_attr_bundle *attrs)
                goto err_copy;
 
        uobj_put_obj_read(pd);
-       return uobj_alloc_commit(uobj);
+       return uobj_alloc_commit(uobj, attrs);
 
 err_copy:
        rdma_destroy_ah(ah, RDMA_DESTROY_AH_SLEEPABLE);
@@ -2460,7 +2460,7 @@ err_put:
        uobj_put_obj_read(pd);
 
 err:
-       uobj_alloc_abort(uobj);
+       uobj_alloc_abort(uobj, attrs);
        return ret;
 }
 
@@ -2962,7 +2962,7 @@ static int ib_uverbs_ex_create_wq(struct uverbs_attr_bundle *attrs)
 
        uobj_put_obj_read(pd);
        uobj_put_obj_read(cq);
-       return uobj_alloc_commit(&obj->uevent.uobject);
+       return uobj_alloc_commit(&obj->uevent.uobject, attrs);
 
 err_copy:
        ib_destroy_wq(wq);
@@ -2971,7 +2971,7 @@ err_put_cq:
 err_put_pd:
        uobj_put_obj_read(pd);
 err_uobj:
-       uobj_alloc_abort(&obj->uevent.uobject);
+       uobj_alloc_abort(&obj->uevent.uobject, attrs);
 
        return err;
 }
@@ -3136,12 +3136,12 @@ static int ib_uverbs_ex_create_rwq_ind_table(struct uverbs_attr_bundle *attrs)
        for (j = 0; j < num_read_wqs; j++)
                uobj_put_obj_read(wqs[j]);
 
-       return uobj_alloc_commit(uobj);
+       return uobj_alloc_commit(uobj, attrs);
 
 err_copy:
        ib_destroy_rwq_ind_table(rwq_ind_tbl);
 err_uobj:
-       uobj_alloc_abort(uobj);
+       uobj_alloc_abort(uobj, attrs);
 put_wqs:
        for (j = 0; j < num_read_wqs; j++)
                uobj_put_obj_read(wqs[j]);
@@ -3314,7 +3314,7 @@ static int ib_uverbs_ex_create_flow(struct uverbs_attr_bundle *attrs)
        kfree(flow_attr);
        if (cmd.flow_attr.num_of_specs)
                kfree(kern_flow_attr);
-       return uobj_alloc_commit(uobj);
+       return uobj_alloc_commit(uobj, attrs);
 err_copy:
        if (!qp->device->ops.destroy_flow(flow_id))
                atomic_dec(&qp->usecnt);
@@ -3325,7 +3325,7 @@ err_free_flow_attr:
 err_put:
        uobj_put_obj_read(qp);
 err_uobj:
-       uobj_alloc_abort(uobj);
+       uobj_alloc_abort(uobj, attrs);
 err_free_attr:
        if (cmd.flow_attr.num_of_specs)
                kfree(kern_flow_attr);
@@ -3458,7 +3458,7 @@ static int __uverbs_create_xsrq(struct uverbs_attr_bundle *attrs,
                uobj_put_obj_read(attr.ext.cq);
 
        uobj_put_obj_read(pd);
-       return uobj_alloc_commit(&obj->uevent.uobject);
+       return uobj_alloc_commit(&obj->uevent.uobject, attrs);
 
 err_copy:
        ib_destroy_srq(srq);
@@ -3477,7 +3477,7 @@ err_put_xrcd:
        }
 
 err:
-       uobj_alloc_abort(&obj->uevent.uobject);
+       uobj_alloc_abort(&obj->uevent.uobject, attrs);
        return ret;
 }
 
index 5255e00b91cc7aa78786fb271988b4cf4bfabb25..cfbef25b3a73af498356910f96ad1691a7e9d0e7 100644 (file)
@@ -222,7 +222,7 @@ static int uverbs_process_idrs_array(struct bundle_priv *pbundle,
 
 static int uverbs_free_idrs_array(const struct uverbs_api_attr *attr_uapi,
                                  struct uverbs_objs_arr_attr *attr,
-                                 bool commit)
+                                 bool commit, struct uverbs_attr_bundle *attrs)
 {
        const struct uverbs_attr_spec *spec = &attr_uapi->spec;
        int current_ret;
@@ -230,8 +230,9 @@ static int uverbs_free_idrs_array(const struct uverbs_api_attr *attr_uapi,
        size_t i;
 
        for (i = 0; i != attr->len; i++) {
-               current_ret = uverbs_finalize_object(
-                       attr->uobjects[i], spec->u2.objs_arr.access, commit);
+               current_ret = uverbs_finalize_object(attr->uobjects[i],
+                                                    spec->u2.objs_arr.access,
+                                                    commit, attrs);
                if (!ret)
                        ret = current_ret;
        }
@@ -457,7 +458,7 @@ static int ib_uverbs_run_method(struct bundle_priv *pbundle,
                struct uverbs_obj_attr *destroy_attr =
                        &pbundle->bundle.attrs[destroy_bkey].obj_attr;
 
-               ret = uobj_destroy(destroy_attr->uobject);
+               ret = uobj_destroy(destroy_attr->uobject, &pbundle->bundle);
                if (ret)
                        return ret;
                __clear_bit(destroy_bkey, pbundle->uobj_finalize);
@@ -508,7 +509,8 @@ static int bundle_destroy(struct bundle_priv *pbundle, bool commit)
 
                current_ret = uverbs_finalize_object(
                        attr->obj_attr.uobject,
-                       attr->obj_attr.attr_elm->spec.u.obj.access, commit);
+                       attr->obj_attr.attr_elm->spec.u.obj.access, commit,
+                       &pbundle->bundle);
                if (!ret)
                        ret = current_ret;
        }
@@ -531,7 +533,8 @@ static int bundle_destroy(struct bundle_priv *pbundle, bool commit)
 
                if (attr_uapi->spec.type == UVERBS_ATTR_TYPE_IDRS_ARRAY) {
                        current_ret = uverbs_free_idrs_array(
-                               attr_uapi, &attr->objs_arr_attr, commit);
+                               attr_uapi, &attr->objs_arr_attr, commit,
+                               &pbundle->bundle);
                        if (!ret)
                                ret = current_ret;
                }
index f224cb7272249bdd313d01016bfead6c698860c1..a1b22fca057ea3ad3795591615e70b80f89f65dc 100644 (file)
 #include "uverbs.h"
 
 static int uverbs_free_ah(struct ib_uobject *uobject,
-                         enum rdma_remove_reason why)
+                         enum rdma_remove_reason why,
+                         struct uverbs_attr_bundle *attrs)
 {
        return rdma_destroy_ah((struct ib_ah *)uobject->object,
                               RDMA_DESTROY_AH_SLEEPABLE);
 }
 
 static int uverbs_free_flow(struct ib_uobject *uobject,
-                           enum rdma_remove_reason why)
+                           enum rdma_remove_reason why,
+                           struct uverbs_attr_bundle *attrs)
 {
        struct ib_flow *flow = (struct ib_flow *)uobject->object;
        struct ib_uflow_object *uflow =
@@ -66,13 +68,15 @@ static int uverbs_free_flow(struct ib_uobject *uobject,
 }
 
 static int uverbs_free_mw(struct ib_uobject *uobject,
-                         enum rdma_remove_reason why)
+                         enum rdma_remove_reason why,
+                         struct uverbs_attr_bundle *attrs)
 {
        return uverbs_dealloc_mw((struct ib_mw *)uobject->object);
 }
 
 static int uverbs_free_qp(struct ib_uobject *uobject,
-                         enum rdma_remove_reason why)
+                         enum rdma_remove_reason why,
+                         struct uverbs_attr_bundle *attrs)
 {
        struct ib_qp *qp = uobject->object;
        struct ib_uqp_object *uqp =
@@ -105,7 +109,8 @@ static int uverbs_free_qp(struct ib_uobject *uobject,
 }
 
 static int uverbs_free_rwq_ind_tbl(struct ib_uobject *uobject,
-                                  enum rdma_remove_reason why)
+                                  enum rdma_remove_reason why,
+                                  struct uverbs_attr_bundle *attrs)
 {
        struct ib_rwq_ind_table *rwq_ind_tbl = uobject->object;
        struct ib_wq **ind_tbl = rwq_ind_tbl->ind_tbl;
@@ -120,7 +125,8 @@ static int uverbs_free_rwq_ind_tbl(struct ib_uobject *uobject,
 }
 
 static int uverbs_free_wq(struct ib_uobject *uobject,
-                         enum rdma_remove_reason why)
+                         enum rdma_remove_reason why,
+                         struct uverbs_attr_bundle *attrs)
 {
        struct ib_wq *wq = uobject->object;
        struct ib_uwq_object *uwq =
@@ -136,7 +142,8 @@ static int uverbs_free_wq(struct ib_uobject *uobject,
 }
 
 static int uverbs_free_srq(struct ib_uobject *uobject,
-                          enum rdma_remove_reason why)
+                          enum rdma_remove_reason why,
+                          struct uverbs_attr_bundle *attrs)
 {
        struct ib_srq *srq = uobject->object;
        struct ib_uevent_object *uevent =
@@ -160,7 +167,8 @@ static int uverbs_free_srq(struct ib_uobject *uobject,
 }
 
 static int uverbs_free_xrcd(struct ib_uobject *uobject,
-                           enum rdma_remove_reason why)
+                           enum rdma_remove_reason why,
+                           struct uverbs_attr_bundle *attrs)
 {
        struct ib_xrcd *xrcd = uobject->object;
        struct ib_uxrcd_object *uxrcd =
@@ -179,7 +187,8 @@ static int uverbs_free_xrcd(struct ib_uobject *uobject,
 }
 
 static int uverbs_free_pd(struct ib_uobject *uobject,
-                         enum rdma_remove_reason why)
+                         enum rdma_remove_reason why,
+                         struct uverbs_attr_bundle *attrs)
 {
        struct ib_pd *pd = uobject->object;
        int ret;
index 7880d50165ed6b48cd16c31f97a9bb7f553694ad..87aaf91072e3fe6c84f51d1f032f2e9757a4585f 100644 (file)
@@ -36,7 +36,8 @@
 #include <rdma/uverbs_std_types.h>
 
 static int uverbs_free_counters(struct ib_uobject *uobject,
-                               enum rdma_remove_reason why)
+                               enum rdma_remove_reason why,
+                               struct uverbs_attr_bundle *attrs)
 {
        struct ib_counters *counters = uobject->object;
        int ret;
index a59ea89e3f2b062a8e55f34c00727450cb86ddb0..5664a8f48527fb4e5efa80ddd586404986c913c3 100644 (file)
@@ -35,7 +35,8 @@
 #include "uverbs.h"
 
 static int uverbs_free_cq(struct ib_uobject *uobject,
-                         enum rdma_remove_reason why)
+                         enum rdma_remove_reason why,
+                         struct uverbs_attr_bundle *attrs)
 {
        struct ib_cq *cq = uobject->object;
        struct ib_uverbs_event_queue *ev_queue = cq->cq_context;
index de3f04a4398c0534d5cf6ad47e7b7f7599a899e3..50d71522e1cdc2dafd0ef478dcbd2ace082bb821 100644 (file)
@@ -35,7 +35,8 @@
 #include <rdma/uverbs_std_types.h>
 
 static int uverbs_free_dm(struct ib_uobject *uobject,
-                         enum rdma_remove_reason why)
+                         enum rdma_remove_reason why,
+                         struct uverbs_attr_bundle *attrs)
 {
        struct ib_dm *dm = uobject->object;
        int ret;
index 3a87b16a93b3350ad091e24d6a28f47de0abf155..d6dbc1d580e5e7976fadbb539b183ab9dc399a39 100644 (file)
@@ -35,7 +35,8 @@
 #include <rdma/uverbs_std_types.h>
 
 static int uverbs_free_flow_action(struct ib_uobject *uobject,
-                                  enum rdma_remove_reason why)
+                                  enum rdma_remove_reason why,
+                                  struct uverbs_attr_bundle *attrs)
 {
        struct ib_flow_action *action = uobject->object;
        int ret;
index 3b4bf6370333c3dd7a29a419da7a182590252889..a74b73f684d463845fb5fb3101aa79d52ce8cc27 100644 (file)
@@ -35,7 +35,8 @@
 #include <rdma/uverbs_std_types.h>
 
 static int uverbs_free_mr(struct ib_uobject *uobject,
-                         enum rdma_remove_reason why)
+                         enum rdma_remove_reason why,
+                         struct uverbs_attr_bundle *attrs)
 {
        return ib_dereg_mr((struct ib_mr *)uobject->object);
 }
index fa8d2a9229fac9c3ac455250c874f4cebcdbb345..0770dcc74add45e4b3efd1386477de892329d0bf 100644 (file)
@@ -1117,7 +1117,8 @@ static void devx_cleanup_mkey(struct devx_obj *obj)
 }
 
 static int devx_obj_cleanup(struct ib_uobject *uobject,
-                           enum rdma_remove_reason why)
+                           enum rdma_remove_reason why,
+                           struct uverbs_attr_bundle *attrs)
 {
        u32 out[MLX5_ST_SZ_DW(general_obj_out_cmd_hdr)];
        struct devx_obj *obj = uobject->object;
@@ -1599,7 +1600,8 @@ err_obj_free:
 }
 
 static int devx_umem_cleanup(struct ib_uobject *uobject,
-                            enum rdma_remove_reason why)
+                            enum rdma_remove_reason why,
+                            struct uverbs_attr_bundle *attrs)
 {
        struct devx_umem *obj = uobject->object;
        u32 out[MLX5_ST_SZ_DW(general_obj_out_cmd_hdr)];
index 798591a184848590a91c540f70acf8618d29a31f..e8c3847a1a1044b7d4c917da43cacf93a1751329 100644 (file)
@@ -189,7 +189,8 @@ err_out:
 }
 
 static int flow_matcher_cleanup(struct ib_uobject *uobject,
-                               enum rdma_remove_reason why)
+                               enum rdma_remove_reason why,
+                               struct uverbs_attr_bundle *attrs)
 {
        struct mlx5_ib_flow_matcher *obj = uobject->object;
        int ret;
index 2d0e6287e43a160873514a1128b1f9aa94af3201..b9226a5cdfd79420856d69a5db282efb69b2af1c 100644 (file)
@@ -104,18 +104,20 @@ static inline void uobj_put_write(struct ib_uobject *uobj)
        rdma_lookup_put_uobject(uobj, UVERBS_LOOKUP_WRITE);
 }
 
-static inline int __must_check uobj_alloc_commit(struct ib_uobject *uobj)
+static inline int __must_check
+uobj_alloc_commit(struct ib_uobject *uobj, struct uverbs_attr_bundle *attrs)
 {
-       int ret = rdma_alloc_commit_uobject(uobj);
+       int ret = rdma_alloc_commit_uobject(uobj, attrs);
 
        if (ret)
                return ret;
        return 0;
 }
 
-static inline void uobj_alloc_abort(struct ib_uobject *uobj)
+static inline void uobj_alloc_abort(struct ib_uobject *uobj,
+                                   struct uverbs_attr_bundle *attrs)
 {
-       rdma_alloc_abort_uobject(uobj);
+       rdma_alloc_abort_uobject(uobj, attrs);
 }
 
 static inline struct ib_uobject *
index b68f1b92c25d96eaf14da406cc99ae14ddac6679..d57a5ba00c743e0222e5062393c691127e727f4d 100644 (file)
@@ -95,7 +95,8 @@ struct uverbs_obj_type_class {
        void (*lookup_put)(struct ib_uobject *uobj, enum rdma_lookup_mode mode);
        /* This does not consume the kref on uobj */
        int __must_check (*destroy_hw)(struct ib_uobject *uobj,
-                                      enum rdma_remove_reason why);
+                                      enum rdma_remove_reason why,
+                                      struct uverbs_attr_bundle *attrs);
        void (*remove_handle)(struct ib_uobject *uobj);
        u8    needs_kfree_rcu;
 };
@@ -126,7 +127,8 @@ struct uverbs_obj_idr_type {
         * completely unchanged.
         */
        int __must_check (*destroy_object)(struct ib_uobject *uobj,
-                                          enum rdma_remove_reason why);
+                                          enum rdma_remove_reason why,
+                                          struct uverbs_attr_bundle *attrs);
 };
 
 struct ib_uobject *rdma_lookup_get_uobject(const struct uverbs_api_object *obj,
@@ -138,8 +140,10 @@ void rdma_lookup_put_uobject(struct ib_uobject *uobj,
 struct ib_uobject *rdma_alloc_begin_uobject(const struct uverbs_api_object *obj,
                                            struct ib_uverbs_file *ufile,
                                            struct uverbs_attr_bundle *attrs);
-void rdma_alloc_abort_uobject(struct ib_uobject *uobj);
-int __must_check rdma_alloc_commit_uobject(struct ib_uobject *uobj);
+void rdma_alloc_abort_uobject(struct ib_uobject *uobj,
+                             struct uverbs_attr_bundle *attrs);
+int __must_check rdma_alloc_commit_uobject(struct ib_uobject *uobj,
+                                          struct uverbs_attr_bundle *attrs);
 
 struct uverbs_obj_fd_type {
        /*