aboutsummaryrefslogtreecommitdiffstats
path: root/block
diff options
context:
space:
mode:
authorJana Iyengar <jri@google.com>2015-09-10 06:55:16 +0200
committerWolfgang Wiedmeyer <wolfgit@wiedmeyer.de>2015-12-06 16:55:55 +0100
commitc18a06524f3eda324a4ff33b7fdb761e8d1257de (patch)
treeddb70dcde4144fb7a578eafc3a25851997b712bc /block
parenta39819e88ea4546218b581d7f061a99ca91d825b (diff)
downloadkernel_samsung_smdk4412-c18a06524f3eda324a4ff33b7fdb761e8d1257de.zip
kernel_samsung_smdk4412-c18a06524f3eda324a4ff33b7fdb761e8d1257de.tar.gz
kernel_samsung_smdk4412-c18a06524f3eda324a4ff33b7fdb761e8d1257de.tar.bz2
tcp_cubic: better follow cubic curve after idle period
Jana Iyengar found an interesting issue on CUBIC : The epoch is only updated/reset initially and when experiencing losses. The delta "t" of now - epoch_start can be arbitrary large after app idle as well as the bic_target. Consequentially the slope (inverse of ca->cnt) would be really large, and eventually ca->cnt would be lower-bounded in the end to 2 to have delayed-ACK slow-start behavior. This particularly shows up when slow_start_after_idle is disabled as a dangerous cwnd inflation (1.5 x RTT) after few seconds of idle time. Jana initial fix was to reset epoch_start if app limited, but Neal pointed out it would ask the CUBIC algorithm to recalculate the curve so that we again start growing steeply upward from where cwnd is now (as CUBIC does just after a loss). Ideally we'd want the cwnd growth curve to be the same shape, just shifted later in time by the amount of the idle period. Reported-by: Jana Iyengar <jri@google.com> Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: Yuchung Cheng <ycheng@google.com> Signed-off-by: Neal Cardwell <ncardwell@google.com> Cc: Stephen Hemminger <stephen@networkplumber.org> Cc: Sangtae Ha <sangtae.ha@gmail.com> Cc: Lawrence Brakmo <lawrence@brakmo.org> Signed-off-by: David S. Miller <davem@davemloft.net> Tested-by: Moritz Bandemer <replicant@posteo.mx>
Diffstat (limited to 'block')
0 files changed, 0 insertions, 0 deletions