mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-15 08:14:15 +08:00
tcp: fix >2 iw selection
A long-standing feature in tcp_init_metrics() is such that any of its goto reset prevents call to tcp_init_cwnd(). Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@helsinki.fi> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
1a31f2042e
commit
86bcebafc5
@ -928,6 +928,8 @@ static void tcp_init_metrics(struct sock *sk)
|
||||
tcp_set_rto(sk);
|
||||
if (inet_csk(sk)->icsk_rto < TCP_TIMEOUT_INIT && !tp->rx_opt.saw_tstamp)
|
||||
goto reset;
|
||||
|
||||
cwnd:
|
||||
tp->snd_cwnd = tcp_init_cwnd(tp, dst);
|
||||
tp->snd_cwnd_stamp = tcp_time_stamp;
|
||||
return;
|
||||
@ -942,6 +944,7 @@ reset:
|
||||
tp->mdev = tp->mdev_max = tp->rttvar = TCP_TIMEOUT_INIT;
|
||||
inet_csk(sk)->icsk_rto = TCP_TIMEOUT_INIT;
|
||||
}
|
||||
goto cwnd;
|
||||
}
|
||||
|
||||
static void tcp_update_reordering(struct sock *sk, const int metric,
|
||||
|
Loading…
Reference in New Issue
Block a user