aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband
diff options
context:
space:
mode:
authorRalph Campbell <ralph.campbell@qlogic.com>2007-06-18 17:24:43 -0400
committerRoland Dreier <rolandd@cisco.com>2007-07-09 23:12:26 -0400
commitdb5518cd09c21f0fa70af0a4ca38badd90622c9e (patch)
treec8183dc863a03411bdb2f8737870ea3ed743d8c8 /drivers/infiniband
parent06ee109002672ac875558ec699b53cf08a865bd3 (diff)
IB/ipath: Wait for PIO available interrupt
The send function is called when posting new send work requests. There is no point in trying to send a packet if the QP is already waiting for a HW send buffer so don't clear the busy bit until the buffer available interrupt happens. Signed-off-by: Ralph Campbell <ralph.campbell@qlogic.com> Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r--drivers/infiniband/hw/ipath/ipath_ruc.c6
-rw-r--r--drivers/infiniband/hw/ipath/ipath_verbs.c1
2 files changed, 3 insertions, 4 deletions
diff --git a/drivers/infiniband/hw/ipath/ipath_ruc.c b/drivers/infiniband/hw/ipath/ipath_ruc.c
index 8c5d20a4b5f3..837118676cc7 100644
--- a/drivers/infiniband/hw/ipath/ipath_ruc.c
+++ b/drivers/infiniband/hw/ipath/ipath_ruc.c
@@ -503,11 +503,9 @@ void ipath_no_bufs_available(struct ipath_qp *qp, struct ipath_ibdev *dev)
503 * could be called. If we are still in the tasklet function, 503 * could be called. If we are still in the tasklet function,
504 * tasklet_hi_schedule() will not call us until the next time 504 * tasklet_hi_schedule() will not call us until the next time
505 * tasklet_hi_schedule() is called. 505 * tasklet_hi_schedule() is called.
506 * We clear the tasklet flag now since we are committing to return 506 * We leave the busy flag set so that another post send doesn't
507 * from the tasklet function. 507 * try to put the same QP on the piowait list again.
508 */ 508 */
509 clear_bit(IPATH_S_BUSY, &qp->s_busy);
510 tasklet_unlock(&qp->s_task);
511 want_buffer(dev->dd); 509 want_buffer(dev->dd);
512 dev->n_piowait++; 510 dev->n_piowait++;
513} 511}
diff --git a/drivers/infiniband/hw/ipath/ipath_verbs.c b/drivers/infiniband/hw/ipath/ipath_verbs.c
index 04294ca0a81f..cd79a8ca5104 100644
--- a/drivers/infiniband/hw/ipath/ipath_verbs.c
+++ b/drivers/infiniband/hw/ipath/ipath_verbs.c
@@ -948,6 +948,7 @@ int ipath_ib_piobufavail(struct ipath_ibdev *dev)
948 qp = list_entry(dev->piowait.next, struct ipath_qp, 948 qp = list_entry(dev->piowait.next, struct ipath_qp,
949 piowait); 949 piowait);
950 list_del_init(&qp->piowait); 950 list_del_init(&qp->piowait);
951 clear_bit(IPATH_S_BUSY, &qp->s_busy);
951 tasklet_hi_schedule(&qp->s_task); 952 tasklet_hi_schedule(&qp->s_task);
952 } 953 }
953 spin_unlock_irqrestore(&dev->pending_lock, flags); 954 spin_unlock_irqrestore(&dev->pending_lock, flags);