tcp: allow dctcp alpha to drop to zero
authorAndrew Shewmaker <agshew@gmail.com>
Mon, 19 Oct 2015 04:59:08 +0000 (21:59 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 23 Oct 2015 09:46:52 +0000 (02:46 -0700)
commitc80dbe04612986fd6104b4a1be21681b113b5ac9
treea0ddb2c94d317b163b2c5a5dbff06cf6534d1f94
parentab997ad408394bcaf7f3015d4c4e38047eaf2ad6
tcp: allow dctcp alpha to drop to zero

If alpha is strictly reduced by alpha >> dctcp_shift_g and if alpha is less
than 1 << dctcp_shift_g, then alpha may never reach zero. For example,
given shift_g=4 and alpha=15, alpha >> dctcp_shift_g yields 0 and alpha
remains 15. The effect isn't noticeable in this case below cwnd=137, but
could gradually drive uncongested flows with leftover alpha down to
cwnd=137. A larger dctcp_shift_g would have a greater effect.

This change causes alpha=15 to drop to 0 instead of being decrementing by 1
as it would when alpha=16. However, it requires one less conditional to
implement since it doesn't have to guard against subtracting 1 from 0U. A
decay of 15 is not unreasonable since an equal or greater amount occurs at
alpha >= 240.

Signed-off-by: Andrew G. Shewmaker <agshew@gmail.com>
Acked-by: Florian Westphal <fw@strlen.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/tcp_dctcp.c