summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPatrick Marchand Latifi <patrick.latifi@qlogic.com>2008-02-20 19:08:10 -0800
committerRoland Dreier <rolandd@cisco.com>2008-03-11 14:04:35 -0700
commit450bb3875f5f5ab3679823c941d6045d16967370 (patch)
tree8e92a0d4caf8a625ef5ab37a417897f88a5ee420
parent2a049e514b890c8b70b965bbd9f4e3c963af69c9 (diff)
downloadlinux-stable-450bb3875f5f5ab3679823c941d6045d16967370.tar.gz
linux-stable-450bb3875f5f5ab3679823c941d6045d16967370.tar.bz2
linux-stable-450bb3875f5f5ab3679823c941d6045d16967370.zip
IB/ipath: Reset the retry counter for RDMA_READ_RESPONSE_MIDDLE packets
Reset the retry counter when we get a good RDMA_READ_RESPONSE_MIDDLE packet. This fix will prevent the requester from reporting a retry exceeded error too early. Signed-off-by: Patrick Marchand Latifi <patrick.latifi@qlogic.com>
-rw-r--r--drivers/infiniband/hw/ipath/ipath_rc.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/infiniband/hw/ipath/ipath_rc.c b/drivers/infiniband/hw/ipath/ipath_rc.c
index 459e46e2c016..40f3e37d7adc 100644
--- a/drivers/infiniband/hw/ipath/ipath_rc.c
+++ b/drivers/infiniband/hw/ipath/ipath_rc.c
@@ -1196,6 +1196,10 @@ static inline void ipath_rc_rcv_resp(struct ipath_ibdev *dev,
list_move_tail(&qp->timerwait,
&dev->pending[dev->pending_index]);
spin_unlock(&dev->pending_lock);
+
+ if (opcode == OP(RDMA_READ_RESPONSE_MIDDLE))
+ qp->s_retry = qp->s_retry_cnt;
+
/*
* Update the RDMA receive state but do the copy w/o
* holding the locks and blocking interrupts.