aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband
diff options
context:
space:
mode:
authorRoland Dreier <rolandd@cisco.com>2007-10-09 22:59:04 -0400
committerRoland Dreier <rolandd@cisco.com>2007-10-09 22:59:04 -0400
commitce423ef50ee1b6b7db63c748034423aa0afce224 (patch)
tree9504d23398a8c03ca99e4a2fecdaee45b540a077 /drivers/infiniband
parente54664c0958acf14ef3a65d1b78f4a54b437cdf7 (diff)
IPoIB: Make sure no receives are handled when stopping device
The current IPoIB code might process receive completions from ipoib_drain_cq() when bringing down the interface. This could cause packets to be passed up the stack without the device's poll method being called. Avoid this by setting the status of any successful completions to IB_WC_WR_FLUSH_ERR. Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r--drivers/infiniband/ulp/ipoib/ipoib_ib.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_ib.c b/drivers/infiniband/ulp/ipoib/ipoib_ib.c
index 10944888cffd..5a70e287f25d 100644
--- a/drivers/infiniband/ulp/ipoib/ipoib_ib.c
+++ b/drivers/infiniband/ulp/ipoib/ipoib_ib.c
@@ -558,6 +558,14 @@ void ipoib_drain_cq(struct net_device *dev)
558 do { 558 do {
559 n = ib_poll_cq(priv->cq, IPOIB_NUM_WC, priv->ibwc); 559 n = ib_poll_cq(priv->cq, IPOIB_NUM_WC, priv->ibwc);
560 for (i = 0; i < n; ++i) { 560 for (i = 0; i < n; ++i) {
561 /*
562 * Convert any successful completions to flush
563 * errors to avoid passing packets up the
564 * stack after bringing the device down.
565 */
566 if (priv->ibwc[i].status == IB_WC_SUCCESS)
567 priv->ibwc[i].status = IB_WC_WR_FLUSH_ERR;
568
561 if (priv->ibwc[i].wr_id & IPOIB_CM_OP_SRQ) 569 if (priv->ibwc[i].wr_id & IPOIB_CM_OP_SRQ)
562 ipoib_cm_handle_rx_wc(dev, priv->ibwc + i); 570 ipoib_cm_handle_rx_wc(dev, priv->ibwc + i);
563 else if (priv->ibwc[i].wr_id & IPOIB_OP_RECV) 571 else if (priv->ibwc[i].wr_id & IPOIB_OP_RECV)