aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband/ulp/ipoib
diff options
context:
space:
mode:
authorEli Cohen <eli@mellanox.co.il>2006-06-05 09:51:36 -0700
committerRoland Dreier <rolandd@cisco.com>2006-06-05 09:51:36 -0700
commit959eb39297e8c82f61fbfc283ad4ff11c883bf1e (patch)
tree7539406ef0c36eb1ba6969fe8aeccd56fab97ea7 /drivers/infiniband/ulp/ipoib
parent672c6108a51bf559d19595d9f8193dfd81f0f752 (diff)
downloadkernel_samsung_smdk4412-959eb39297e8c82f61fbfc283ad4ff11c883bf1e.tar.gz
kernel_samsung_smdk4412-959eb39297e8c82f61fbfc283ad4ff11c883bf1e.tar.bz2
kernel_samsung_smdk4412-959eb39297e8c82f61fbfc283ad4ff11c883bf1e.zip
IPoIB: Fix AH leak at interface down
When ipoib_stop() is called it first calls netif_stop_queue() to stop the kernel from passing more packets to the network driver. However, the completion handler may call netif_wake_queue() re-enabling packet transfer. This might result in leaks (we see AH leaks which we think can be attributed to this bug) as new packets get posted while the interface is going down. Signed-off-by: Eli Cohen <eli@mellanox.co.il> Signed-off-by: Michael Tsirkin <mst@mellanox.co.il> Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband/ulp/ipoib')
-rw-r--r--drivers/infiniband/ulp/ipoib/ipoib_ib.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_ib.c b/drivers/infiniband/ulp/ipoib/ipoib_ib.c
index a54da42849a..8406839b91c 100644
--- a/drivers/infiniband/ulp/ipoib/ipoib_ib.c
+++ b/drivers/infiniband/ulp/ipoib/ipoib_ib.c
@@ -275,6 +275,7 @@ static void ipoib_ib_handle_wc(struct net_device *dev,
spin_lock_irqsave(&priv->tx_lock, flags);
++priv->tx_tail;
if (netif_queue_stopped(dev) &&
+ test_bit(IPOIB_FLAG_ADMIN_UP, &priv->flags) &&
priv->tx_head - priv->tx_tail <= ipoib_sendq_size >> 1)
netif_wake_queue(dev);
spin_unlock_irqrestore(&priv->tx_lock, flags);