Commit 2f5059a7 authored by Leon Romanovsky's avatar Leon Romanovsky Committed by Doug Ledford

RDMA/cm: Abort loop in case of CM dequeue

In case CM work list is empty, the work pointer will be NULL,
so instead of kernel crash it is better to abort processing
of works.
Signed-off-by: default avatarLeon Romanovsky <leonro@mellanox.com>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent cd13a399
...@@ -1707,7 +1707,9 @@ static void cm_process_work(struct cm_id_private *cm_id_priv, ...@@ -1707,7 +1707,9 @@ static void cm_process_work(struct cm_id_private *cm_id_priv,
spin_lock_irq(&cm_id_priv->lock); spin_lock_irq(&cm_id_priv->lock);
work = cm_dequeue_work(cm_id_priv); work = cm_dequeue_work(cm_id_priv);
spin_unlock_irq(&cm_id_priv->lock); spin_unlock_irq(&cm_id_priv->lock);
BUG_ON(!work); if (!work)
return;
ret = cm_id_priv->id.cm_handler(&cm_id_priv->id, ret = cm_id_priv->id.cm_handler(&cm_id_priv->id,
&work->cm_event); &work->cm_event);
cm_free_work(work); cm_free_work(work);
......
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