Commit 7e85bcda authored by Jason Gunthorpe's avatar Jason Gunthorpe

RDMA/cma: Combine cma_ndev_work with cma_work

These are the same thing, except that cma_ndev_work doesn't have a state
transition. Signal no state transition by setting old_state and new_state
== 0.

In all cases the handler function should not be called once
rdma_destroy_id() has progressed passed setting the state.

Link: https://lore.kernel.org/r/20200902081122.745412-6-leon@kernel.orgSigned-off-by: default avatarLeon Romanovsky <leonro@nvidia.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@nvidia.com>
parent 5cfbf929
...@@ -363,12 +363,6 @@ struct cma_work { ...@@ -363,12 +363,6 @@ struct cma_work {
struct rdma_cm_event event; struct rdma_cm_event event;
}; };
struct cma_ndev_work {
struct work_struct work;
struct rdma_id_private *id;
struct rdma_cm_event event;
};
struct iboe_mcast_work { struct iboe_mcast_work {
struct work_struct work; struct work_struct work;
struct rdma_id_private *id; struct rdma_id_private *id;
...@@ -2647,32 +2641,14 @@ static void cma_work_handler(struct work_struct *_work) ...@@ -2647,32 +2641,14 @@ static void cma_work_handler(struct work_struct *_work)
struct rdma_id_private *id_priv = work->id; struct rdma_id_private *id_priv = work->id;
mutex_lock(&id_priv->handler_mutex); mutex_lock(&id_priv->handler_mutex);
if (!cma_comp_exch(id_priv, work->old_state, work->new_state)) if (READ_ONCE(id_priv->state) == RDMA_CM_DESTROYING ||
READ_ONCE(id_priv->state) == RDMA_CM_DEVICE_REMOVAL)
goto out_unlock; goto out_unlock;
if (work->old_state != 0 || work->new_state != 0) {
if (cma_cm_event_handler(id_priv, &work->event)) { if (!cma_comp_exch(id_priv, work->old_state, work->new_state))
cma_id_put(id_priv); goto out_unlock;
destroy_id_handler_unlock(id_priv);
goto out_free;
} }
out_unlock:
mutex_unlock(&id_priv->handler_mutex);
cma_id_put(id_priv);
out_free:
kfree(work);
}
static void cma_ndev_work_handler(struct work_struct *_work)
{
struct cma_ndev_work *work = container_of(_work, struct cma_ndev_work, work);
struct rdma_id_private *id_priv = work->id;
mutex_lock(&id_priv->handler_mutex);
if (id_priv->state == RDMA_CM_DESTROYING ||
id_priv->state == RDMA_CM_DEVICE_REMOVAL)
goto out_unlock;
if (cma_cm_event_handler(id_priv, &work->event)) { if (cma_cm_event_handler(id_priv, &work->event)) {
cma_id_put(id_priv); cma_id_put(id_priv);
destroy_id_handler_unlock(id_priv); destroy_id_handler_unlock(id_priv);
...@@ -4698,7 +4674,7 @@ EXPORT_SYMBOL(rdma_leave_multicast); ...@@ -4698,7 +4674,7 @@ EXPORT_SYMBOL(rdma_leave_multicast);
static int cma_netdev_change(struct net_device *ndev, struct rdma_id_private *id_priv) static int cma_netdev_change(struct net_device *ndev, struct rdma_id_private *id_priv)
{ {
struct rdma_dev_addr *dev_addr; struct rdma_dev_addr *dev_addr;
struct cma_ndev_work *work; struct cma_work *work;
dev_addr = &id_priv->id.route.addr.dev_addr; dev_addr = &id_priv->id.route.addr.dev_addr;
...@@ -4711,7 +4687,7 @@ static int cma_netdev_change(struct net_device *ndev, struct rdma_id_private *id ...@@ -4711,7 +4687,7 @@ static int cma_netdev_change(struct net_device *ndev, struct rdma_id_private *id
if (!work) if (!work)
return -ENOMEM; return -ENOMEM;
INIT_WORK(&work->work, cma_ndev_work_handler); INIT_WORK(&work->work, cma_work_handler);
work->id = id_priv; work->id = id_priv;
work->event.event = RDMA_CM_EVENT_ADDR_CHANGE; work->event.event = RDMA_CM_EVENT_ADDR_CHANGE;
cma_id_get(id_priv); cma_id_get(id_priv);
......
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