diff options
author | Andy Grover <andy.grover@oracle.com> | 2010-03-11 13:49:59 +0000 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-03-16 21:16:55 -0700 |
commit | 2e7b3b994529d4760231a45a6b88950187bda877 (patch) | |
tree | d073317ace5a9ef948a826aed32e8b35f21e2193 /net/rds/cong.c | |
parent | 8e82376e5f72bb576504c8c6117685e56c1b97db (diff) | |
download | kernel_samsung_smdk4412-2e7b3b994529d4760231a45a6b88950187bda877.zip kernel_samsung_smdk4412-2e7b3b994529d4760231a45a6b88950187bda877.tar.gz kernel_samsung_smdk4412-2e7b3b994529d4760231a45a6b88950187bda877.tar.bz2 |
RDS: Fix congestion issues for loopback
We have two kinds of loopback: software (via loop transport)
and hardware (via IB). sw is used for 127.0.0.1, and doesn't
support rdma ops. hw is used for sends to local device IPs,
and supports rdma. Both are used in different cases.
For both of these, when there is a congestion map update, we
want to call rds_cong_map_updated() but not actually send
anything -- since loopback local and foreign congestion maps
point to the same spot, they're already in sync.
The old code never called sw loop's xmit_cong_map(),so
rds_cong_map_updated() wasn't being called for it. sw loop
ports would not work right with the congestion monitor.
Fixing that meant that hw loopback now would send congestion maps
to itself. This is also undesirable (racy), so we check for this
case in the ib-specific xmit code.
Signed-off-by: Andy Grover <andy.grover@oracle.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/rds/cong.c')
-rw-r--r-- | net/rds/cong.c | 2 |
1 files changed, 0 insertions, 2 deletions
diff --git a/net/rds/cong.c b/net/rds/cong.c index 6d06cac..dd2711d 100644 --- a/net/rds/cong.c +++ b/net/rds/cong.c @@ -218,8 +218,6 @@ void rds_cong_queue_updates(struct rds_cong_map *map) spin_lock_irqsave(&rds_cong_lock, flags); list_for_each_entry(conn, &map->m_conn_list, c_map_item) { - if (conn->c_loopback) - continue; if (!test_and_set_bit(0, &conn->c_map_queued)) { rds_stats_inc(s_cong_update_queued); queue_delayed_work(rds_wq, &conn->c_send_w, 0); |