summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Heffner <johnwheffner@gmail.com>2008-04-16 00:26:39 +0200
committerDavid S. Miller <davem@davemloft.net>2008-04-16 11:29:56 +0200
commitdd9e0dda66ba38a2ddd1405ac279894260dc5c36 (patch)
treef515b780e78ae05f81dc21f1434fe7ba807b8509
parent[NET]: Do not allocate unneeded memory for dev->priv alignment. (diff)
downloadlinux-dd9e0dda66ba38a2ddd1405ac279894260dc5c36.tar.xz
linux-dd9e0dda66ba38a2ddd1405ac279894260dc5c36.zip
[TCP]: Increase the max_burst threshold from 3 to tp->reordering.
This change is necessary to allow cwnd to grow during persistent reordering. Cwnd moderation is applied when in the disorder state and an ack that fills the hole comes in. If the hole was greater than 3 packets, but less than tp->reordering, cwnd will shrink when it should not have. Signed-off-by: John Heffner <jheffner@napa.(none)> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--include/net/tcp.h7
1 files changed, 5 insertions, 2 deletions
diff --git a/include/net/tcp.h b/include/net/tcp.h
index 2c14edf7b076..633147cb6bbc 100644
--- a/include/net/tcp.h
+++ b/include/net/tcp.h
@@ -787,11 +787,14 @@ extern void tcp_enter_cwr(struct sock *sk, const int set_ssthresh);
extern __u32 tcp_init_cwnd(struct tcp_sock *tp, struct dst_entry *dst);
/* Slow start with delack produces 3 packets of burst, so that
- * it is safe "de facto".
+ * it is safe "de facto". This will be the default - same as
+ * the default reordering threshold - but if reordering increases,
+ * we must be able to allow cwnd to burst at least this much in order
+ * to not pull it back when holes are filled.
*/
static __inline__ __u32 tcp_max_burst(const struct tcp_sock *tp)
{
- return 3;
+ return tp->reordering;
}
/* Returns end sequence number of the receiver's advertised window */