tcp: better comments for RTO initiallization
Commit 1b7fdd2ab585("tcp: do not use cached RTT for RTT estimation") removes important comments on how RTO is initialized and updated. Hopefully this patch puts those information back. 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>
This commit is contained in:
parent
430eda6d6d
commit
52f20e655d
@ -481,13 +481,27 @@ void tcp_init_metrics(struct sock *sk)
|
|||||||
crtt = tcp_metric_get_jiffies(tm, TCP_METRIC_RTT);
|
crtt = tcp_metric_get_jiffies(tm, TCP_METRIC_RTT);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
reset:
|
reset:
|
||||||
|
/* The initial RTT measurement from the SYN/SYN-ACK is not ideal
|
||||||
|
* to seed the RTO for later data packets because SYN packets are
|
||||||
|
* small. Use the per-dst cached values to seed the RTO but keep
|
||||||
|
* the RTT estimator variables intact (e.g., srtt, mdev, rttvar).
|
||||||
|
* Later the RTO will be updated immediately upon obtaining the first
|
||||||
|
* data RTT sample (tcp_rtt_estimator()). Hence the cached RTT only
|
||||||
|
* influences the first RTO but not later RTT estimation.
|
||||||
|
*
|
||||||
|
* But if RTT is not available from the SYN (due to retransmits or
|
||||||
|
* syn cookies) or the cache, force a conservative 3secs timeout.
|
||||||
|
*
|
||||||
|
* A bit of theory. RTT is time passed after "normal" sized packet
|
||||||
|
* is sent until it is ACKed. In normal circumstances sending small
|
||||||
|
* packets force peer to delay ACKs and calculation is correct too.
|
||||||
|
* The algorithm is adaptive and, provided we follow specs, it
|
||||||
|
* NEVER underestimate RTT. BUT! If peer tries to make some clever
|
||||||
|
* tricks sort of "quick acks" for time long enough to decrease RTT
|
||||||
|
* to low value, and then abruptly stops to do it and starts to delay
|
||||||
|
* ACKs, wait for troubles.
|
||||||
|
*/
|
||||||
if (crtt > tp->srtt) {
|
if (crtt > tp->srtt) {
|
||||||
/* Initial RTT (tp->srtt) from SYN usually don't measure
|
|
||||||
* serialization delay on low BW links well so RTO may be
|
|
||||||
* under-estimated. Stay conservative and seed RTO with
|
|
||||||
* the RTTs from past data exchanges, using the same seeding
|
|
||||||
* formula in tcp_rtt_estimator().
|
|
||||||
*/
|
|
||||||
inet_csk(sk)->icsk_rto = crtt + max(crtt >> 2, tcp_rto_min(sk));
|
inet_csk(sk)->icsk_rto = crtt + max(crtt >> 2, tcp_rto_min(sk));
|
||||||
} else if (tp->srtt == 0) {
|
} else if (tp->srtt == 0) {
|
||||||
/* RFC6298: 5.7 We've failed to get a valid RTT sample from
|
/* RFC6298: 5.7 We've failed to get a valid RTT sample from
|
||||||
|
Loading…
Reference in New Issue
Block a user