aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorDavid S. Miller <davem@sunset.davemloft.net>2007-04-09 13:23:14 -0700
committerDavid S. Miller <davem@sunset.davemloft.net>2007-04-09 13:31:15 -0700
commit15d33c070ddde99f7368e6b17b71d22c866f97d9 (patch)
tree00e779b01fb3c48e61b3ccc4de8f082e1b929cc4 /net
parent699784b7614ce61b16a075445b8e5b6c379c5086 (diff)
downloadkernel_samsung_smdk4412-15d33c070ddde99f7368e6b17b71d22c866f97d9.tar.gz
kernel_samsung_smdk4412-15d33c070ddde99f7368e6b17b71d22c866f97d9.tar.bz2
kernel_samsung_smdk4412-15d33c070ddde99f7368e6b17b71d22c866f97d9.zip
[TCP]: slow_start_after_idle should influence cwnd validation too
For the cases that slow_start_after_idle are meant to deal with, it is almost a certainty that the congestion window tests will think the connection is application limited and we'll thus decrease the cwnd there too. This defeats the whole point of setting slow_start_after_idle to zero. So test it there too. We do not cancel out the entire tcp_cwnd_validate() function so that if the sysctl is changed we still have the validation state maintained. Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r--net/ipv4/tcp_output.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c
index 688b95594f2..3c24881f2a6 100644
--- a/net/ipv4/tcp_output.c
+++ b/net/ipv4/tcp_output.c
@@ -943,7 +943,8 @@ static void tcp_cwnd_validate(struct sock *sk, struct tcp_sock *tp)
if (tp->packets_out > tp->snd_cwnd_used)
tp->snd_cwnd_used = tp->packets_out;
- if ((s32)(tcp_time_stamp - tp->snd_cwnd_stamp) >= inet_csk(sk)->icsk_rto)
+ if (sysctl_tcp_slow_start_after_idle &&
+ (s32)(tcp_time_stamp - tp->snd_cwnd_stamp) >= inet_csk(sk)->icsk_rto)
tcp_cwnd_application_limited(sk);
}
}