Commit 238b1862 authored by Sebastian Sanchez's avatar Sebastian Sanchez Committed by Doug Ledford

IB/qib: Use standard refcount wrapper for QPs

Use the standard driver wrapper for QP reference counters.
This makes the code more maintainable.

Fixes: Commit 4d6f85c3 ("IB/rdmavt, IB/qib, IB/hfi1: Use new QP put get routines")
Reviewed-by: default avatarMike Marciniszyn <mike.marciniszyn@intel.com>
Signed-off-by: default avatarSebastian Sanchez <sebastian.sanchez@intel.com>
Signed-off-by: default avatarDennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent f84dfa26
...@@ -420,8 +420,7 @@ static u32 qib_rcv_hdrerr(struct qib_ctxtdata *rcd, struct qib_pportdata *ppd, ...@@ -420,8 +420,7 @@ static u32 qib_rcv_hdrerr(struct qib_ctxtdata *rcd, struct qib_pportdata *ppd,
if (list_empty(&qp->rspwait)) { if (list_empty(&qp->rspwait)) {
qp->r_flags |= qp->r_flags |=
RVT_R_RSP_NAK; RVT_R_RSP_NAK;
atomic_inc( rvt_get_qp(qp);
&qp->refcount);
list_add_tail( list_add_tail(
&qp->rspwait, &qp->rspwait,
&rcd->qp_wait_list); &rcd->qp_wait_list);
......
...@@ -464,7 +464,7 @@ static void mem_timer(unsigned long data) ...@@ -464,7 +464,7 @@ static void mem_timer(unsigned long data)
priv = list_entry(list->next, struct qib_qp_priv, iowait); priv = list_entry(list->next, struct qib_qp_priv, iowait);
qp = priv->owner; qp = priv->owner;
list_del_init(&priv->iowait); list_del_init(&priv->iowait);
atomic_inc(&qp->refcount); rvt_get_qp(qp);
if (!list_empty(list)) if (!list_empty(list))
mod_timer(&dev->mem_timer, jiffies + 1); mod_timer(&dev->mem_timer, jiffies + 1);
} }
...@@ -477,8 +477,7 @@ static void mem_timer(unsigned long data) ...@@ -477,8 +477,7 @@ static void mem_timer(unsigned long data)
qib_schedule_send(qp); qib_schedule_send(qp);
} }
spin_unlock_irqrestore(&qp->s_lock, flags); spin_unlock_irqrestore(&qp->s_lock, flags);
if (atomic_dec_and_test(&qp->refcount)) rvt_put_qp(qp);
wake_up(&qp->wait);
} }
} }
...@@ -762,7 +761,7 @@ void qib_put_txreq(struct qib_verbs_txreq *tx) ...@@ -762,7 +761,7 @@ void qib_put_txreq(struct qib_verbs_txreq *tx)
iowait); iowait);
qp = priv->owner; qp = priv->owner;
list_del_init(&priv->iowait); list_del_init(&priv->iowait);
atomic_inc(&qp->refcount); rvt_get_qp(qp);
spin_unlock_irqrestore(&dev->rdi.pending_lock, flags); spin_unlock_irqrestore(&dev->rdi.pending_lock, flags);
spin_lock_irqsave(&qp->s_lock, flags); spin_lock_irqsave(&qp->s_lock, flags);
...@@ -772,8 +771,7 @@ void qib_put_txreq(struct qib_verbs_txreq *tx) ...@@ -772,8 +771,7 @@ void qib_put_txreq(struct qib_verbs_txreq *tx)
} }
spin_unlock_irqrestore(&qp->s_lock, flags); spin_unlock_irqrestore(&qp->s_lock, flags);
if (atomic_dec_and_test(&qp->refcount)) rvt_put_qp(qp);
wake_up(&qp->wait);
} else } else
spin_unlock_irqrestore(&dev->rdi.pending_lock, flags); spin_unlock_irqrestore(&dev->rdi.pending_lock, flags);
} }
...@@ -808,7 +806,7 @@ void qib_verbs_sdma_desc_avail(struct qib_pportdata *ppd, unsigned avail) ...@@ -808,7 +806,7 @@ void qib_verbs_sdma_desc_avail(struct qib_pportdata *ppd, unsigned avail)
break; break;
avail -= qpp->s_tx->txreq.sg_count; avail -= qpp->s_tx->txreq.sg_count;
list_del_init(&qpp->iowait); list_del_init(&qpp->iowait);
atomic_inc(&qp->refcount); rvt_get_qp(qp);
qps[n++] = qp; qps[n++] = qp;
} }
...@@ -822,8 +820,7 @@ void qib_verbs_sdma_desc_avail(struct qib_pportdata *ppd, unsigned avail) ...@@ -822,8 +820,7 @@ void qib_verbs_sdma_desc_avail(struct qib_pportdata *ppd, unsigned avail)
qib_schedule_send(qp); qib_schedule_send(qp);
} }
spin_unlock(&qp->s_lock); spin_unlock(&qp->s_lock);
if (atomic_dec_and_test(&qp->refcount)) rvt_put_qp(qp);
wake_up(&qp->wait);
} }
} }
...@@ -1288,7 +1285,7 @@ void qib_ib_piobufavail(struct qib_devdata *dd) ...@@ -1288,7 +1285,7 @@ void qib_ib_piobufavail(struct qib_devdata *dd)
priv = list_entry(list->next, struct qib_qp_priv, iowait); priv = list_entry(list->next, struct qib_qp_priv, iowait);
qp = priv->owner; qp = priv->owner;
list_del_init(&priv->iowait); list_del_init(&priv->iowait);
atomic_inc(&qp->refcount); rvt_get_qp(qp);
qps[n++] = qp; qps[n++] = qp;
} }
dd->f_wantpiobuf_intr(dd, 0); dd->f_wantpiobuf_intr(dd, 0);
...@@ -1306,8 +1303,7 @@ void qib_ib_piobufavail(struct qib_devdata *dd) ...@@ -1306,8 +1303,7 @@ void qib_ib_piobufavail(struct qib_devdata *dd)
spin_unlock_irqrestore(&qp->s_lock, flags); spin_unlock_irqrestore(&qp->s_lock, flags);
/* Notify qib_destroy_qp() if it is waiting. */ /* Notify qib_destroy_qp() if it is waiting. */
if (atomic_dec_and_test(&qp->refcount)) rvt_put_qp(qp);
wake_up(&qp->wait);
} }
} }
......
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