]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
RDMA/cma: Use a helper function to enqueue resolve work items
authorParav Pandit <parav@mellanox.com>
Sun, 26 Jan 2020 14:26:47 +0000 (16:26 +0200)
committerJason Gunthorpe <jgg@mellanox.com>
Tue, 11 Feb 2020 17:55:13 +0000 (13:55 -0400)
To avoid errors, with attaching ownership of work item and its cm_id
refcount which is decremented in work handler, tie them up in single
helper function. Also avoid code duplication.

Link: https://lore.kernel.org/r/20200126142652.104803-3-leon@kernel.org
Signed-off-by: Parav Pandit <parav@mellanox.com>
Signed-off-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/core/cma.c

index 72f032160c4bd92ff54561463438d5b27dd4ee51..8f16ebb413c228f7d83ab6e56795daf0df3c8afc 100644 (file)
@@ -2687,14 +2687,18 @@ static void cma_init_resolve_route_work(struct cma_work *work,
        work->event.event = RDMA_CM_EVENT_ROUTE_RESOLVED;
 }
 
-static void cma_init_resolve_addr_work(struct cma_work *work,
-                                      struct rdma_id_private *id_priv)
+static void enqueue_resolve_addr_work(struct cma_work *work,
+                                     struct rdma_id_private *id_priv)
 {
+       atomic_inc(&id_priv->refcount);
+
        work->id = id_priv;
        INIT_WORK(&work->work, cma_work_handler);
        work->old_state = RDMA_CM_ADDR_QUERY;
        work->new_state = RDMA_CM_ADDR_RESOLVED;
        work->event.event = RDMA_CM_EVENT_ADDR_RESOLVED;
+
+       queue_work(cma_wq, &work->work);
 }
 
 static int cma_resolve_ib_route(struct rdma_id_private *id_priv,
@@ -3148,9 +3152,7 @@ static int cma_resolve_loopback(struct rdma_id_private *id_priv)
        rdma_addr_get_sgid(&id_priv->id.route.addr.dev_addr, &gid);
        rdma_addr_set_dgid(&id_priv->id.route.addr.dev_addr, &gid);
 
-       atomic_inc(&id_priv->refcount);
-       cma_init_resolve_addr_work(work, id_priv);
-       queue_work(cma_wq, &work->work);
+       enqueue_resolve_addr_work(work, id_priv);
        return 0;
 err:
        kfree(work);
@@ -3175,9 +3177,7 @@ static int cma_resolve_ib_addr(struct rdma_id_private *id_priv)
        rdma_addr_set_dgid(&id_priv->id.route.addr.dev_addr, (union ib_gid *)
                &(((struct sockaddr_ib *) &id_priv->id.route.addr.dst_addr)->sib_addr));
 
-       atomic_inc(&id_priv->refcount);
-       cma_init_resolve_addr_work(work, id_priv);
-       queue_work(cma_wq, &work->work);
+       enqueue_resolve_addr_work(work, id_priv);
        return 0;
 err:
        kfree(work);