aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorAndy Grover <andy.grover@oracle.com>2010-03-03 22:25:21 -0500
committerAndy Grover <andy.grover@oracle.com>2010-09-08 21:12:09 -0400
commite32b4a70495aac6a612e13f4c21db09dd756ff2c (patch)
tree2f0a7187e5ddb8a79d5bec0cefade198b99ea138 /net
parentff3d7d36134ef7138803734fdbf91cc986ea7976 (diff)
RDS/IB: Do not wait for send ring to be empty on conn shutdown
Now that we are signaling send completions much less, we are likely to have dirty entries in the send queue when the connection is shut down (on rmmod, for example.) These are cleaned up a little further down in conn_shutdown, but if we wait on the ring_empty_wait for them, it'll never happen, and we hand on unload. Signed-off-by: Andy Grover <andy.grover@oracle.com>
Diffstat (limited to 'net')
-rw-r--r--net/rds/ib_cm.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/net/rds/ib_cm.c b/net/rds/ib_cm.c
index b5b5ebbc0bb6..1a91af75f4c7 100644
--- a/net/rds/ib_cm.c
+++ b/net/rds/ib_cm.c
@@ -620,8 +620,11 @@ void rds_ib_conn_shutdown(struct rds_connection *conn)
620 ic->i_cm_id, err); 620 ic->i_cm_id, err);
621 } 621 }
622 622
623 /*
624 * Don't wait for the send ring to be empty -- there may be completed
625 * non-signaled entries sitting on there. We unmap these below.
626 */
623 wait_event(rds_ib_ring_empty_wait, 627 wait_event(rds_ib_ring_empty_wait,
624 rds_ib_ring_empty(&ic->i_send_ring) &&
625 rds_ib_ring_empty(&ic->i_recv_ring)); 628 rds_ib_ring_empty(&ic->i_recv_ring));
626 629
627 if (ic->i_send_hdrs) 630 if (ic->i_send_hdrs)