Skip to content

Commit

Permalink
tcp: fix stretch ACK bugs in Scalable
Browse files Browse the repository at this point in the history
Change Scalable to properly handle stretch ACKs in additive
increase mode by passing in the count of ACKed packets to
tcp_cong_avoid_ai().

In addition, because we are now precisely accounting for
stretch ACKs, including delayed ACKs, we can now change
TCP_SCALABLE_AI_CNT to 100.

Signed-off-by: Pengcheng Yang <[email protected]>
Acked-by: Neal Cardwell <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
  • Loading branch information
ws-yangpc authored and davem330 committed Mar 17, 2020
1 parent be0d935 commit 5415e3c
Showing 1 changed file with 9 additions and 8 deletions.
17 changes: 9 additions & 8 deletions net/ipv4/tcp_scalable.c
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,9 @@
#include <net/tcp.h>

/* These factors derived from the recommended values in the aer:
* .01 and and 7/8. We use 50 instead of 100 to account for
* delayed ack.
* .01 and and 7/8.
*/
#define TCP_SCALABLE_AI_CNT 50U
#define TCP_SCALABLE_AI_CNT 100U
#define TCP_SCALABLE_MD_SCALE 3

static void tcp_scalable_cong_avoid(struct sock *sk, u32 ack, u32 acked)
Expand All @@ -23,11 +22,13 @@ static void tcp_scalable_cong_avoid(struct sock *sk, u32 ack, u32 acked)
if (!tcp_is_cwnd_limited(sk))
return;

if (tcp_in_slow_start(tp))
tcp_slow_start(tp, acked);
else
tcp_cong_avoid_ai(tp, min(tp->snd_cwnd, TCP_SCALABLE_AI_CNT),
1);
if (tcp_in_slow_start(tp)) {
acked = tcp_slow_start(tp, acked);
if (!acked)
return;
}
tcp_cong_avoid_ai(tp, min(tp->snd_cwnd, TCP_SCALABLE_AI_CNT),
acked);
}

static u32 tcp_scalable_ssthresh(struct sock *sk)
Expand Down

0 comments on commit 5415e3c

Please sign in to comment.