aboutsummaryrefslogtreecommitdiffstats
path: root/Documentation/networking
diff options
context:
space:
mode:
authorYuchung Cheng <ycheng@google.com>2013-03-20 09:32:58 -0400
committerDavid S. Miller <davem@davemloft.net>2013-03-21 11:47:50 -0400
commit9b44190dc114c1720b34975b5bfc65aece112ced (patch)
treec1202e05d6a04fa1d31be2ad2942fbe32ffa3f76 /Documentation/networking
parente306e2c13b8c214618af0c61acf62a6e42d486de (diff)
tcp: refactor F-RTO
The patch series refactor the F-RTO feature (RFC4138/5682). This is to simplify the loss recovery processing. Existing F-RTO was developed during the experimental stage (RFC4138) and has many experimental features. It takes a separate code path from the traditional timeout processing by overloading CA_Disorder instead of using CA_Loss state. This complicates CA_Disorder state handling because it's also used for handling dubious ACKs and undos. While the algorithm in the RFC does not change the congestion control, the implementation intercepts congestion control in various places (e.g., frto_cwnd in tcp_ack()). The new code implements newer F-RTO RFC5682 using CA_Loss processing path. F-RTO becomes a small extension in the timeout processing and interfaces with congestion control and Eifel undo modules. It lets congestion control (module) determines how many to send independently. F-RTO only chooses what to send in order to detect spurious retranmission. If timeout is found spurious it invokes existing Eifel undo algorithms like DSACK or TCP timestamp based detection. The first patch removes all F-RTO code except the sysctl_tcp_frto is left for the new implementation. Since CA_EVENT_FRTO is removed, TCP westwood now computes ssthresh on regular timeout CA_EVENT_LOSS event. Signed-off-by: Yuchung Cheng <ycheng@google.com> Acked-by: Neal Cardwell <ncardwell@google.com> Acked-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'Documentation/networking')
-rw-r--r--Documentation/networking/ip-sysctl.txt17
1 files changed, 0 insertions, 17 deletions
diff --git a/Documentation/networking/ip-sysctl.txt b/Documentation/networking/ip-sysctl.txt
index 17953e2bc3e9..8a977a0aaede 100644
--- a/Documentation/networking/ip-sysctl.txt
+++ b/Documentation/networking/ip-sysctl.txt
@@ -239,23 +239,6 @@ tcp_frto - INTEGER
239 interacts badly with the packet counting of the SACK enabled TCP 239 interacts badly with the packet counting of the SACK enabled TCP
240 flow. 240 flow.
241 241
242tcp_frto_response - INTEGER
243 When F-RTO has detected that a TCP retransmission timeout was
244 spurious (i.e, the timeout would have been avoided had TCP set a
245 longer retransmission timeout), TCP has several options what to do
246 next. Possible values are:
247 0 Rate halving based; a smooth and conservative response,
248 results in halved cwnd and ssthresh after one RTT
249 1 Very conservative response; not recommended because even
250 though being valid, it interacts poorly with the rest of
251 Linux TCP, halves cwnd and ssthresh immediately
252 2 Aggressive response; undoes congestion control measures
253 that are now known to be unnecessary (ignoring the
254 possibility of a lost retransmission that would require
255 TCP to be more cautious), cwnd and ssthresh are restored
256 to the values prior timeout
257 Default: 0 (rate halving based)
258
259tcp_keepalive_time - INTEGER 242tcp_keepalive_time - INTEGER
260 How often TCP sends out keepalive messages when keepalive is enabled. 243 How often TCP sends out keepalive messages when keepalive is enabled.
261 Default: 2hours. 244 Default: 2hours.