diff options
Diffstat (limited to 'net/ipv4/tcp_timer.c')
| -rw-r--r-- | net/ipv4/tcp_timer.c | 7 | 
1 files changed, 4 insertions, 3 deletions
diff --git a/net/ipv4/tcp_timer.c b/net/ipv4/tcp_timer.c index c801cd37cc2a..40de2d2364a1 100644 --- a/net/ipv4/tcp_timer.c +++ b/net/ipv4/tcp_timer.c @@ -154,7 +154,7 @@ static void tcp_mtu_probing(struct inet_connection_sock *icsk, struct sock *sk)  	} else {  		mss = tcp_mtu_to_mss(sk, icsk->icsk_mtup.search_low) >> 1;  		mss = min(net->ipv4.sysctl_tcp_base_mss, mss); -		mss = max(mss, 68 - tcp_sk(sk)->tcp_header_len); +		mss = max(mss, net->ipv4.sysctl_tcp_mtu_probe_floor);  		mss = max(mss, net->ipv4.sysctl_tcp_min_snd_mss);  		icsk->icsk_mtup.search_low = tcp_mss_to_mtu(sk, mss);  	} @@ -210,7 +210,7 @@ static int tcp_write_timeout(struct sock *sk)  	struct inet_connection_sock *icsk = inet_csk(sk);  	struct tcp_sock *tp = tcp_sk(sk);  	struct net *net = sock_net(sk); -	bool expired, do_reset; +	bool expired = false, do_reset;  	int retry_until;  	if ((1 << sk->sk_state) & (TCPF_SYN_SENT | TCPF_SYN_RECV)) { @@ -242,9 +242,10 @@ static int tcp_write_timeout(struct sock *sk)  			if (tcp_out_of_resources(sk, do_reset))  				return 1;  		} +	} +	if (!expired)  		expired = retransmits_timed_out(sk, retry_until,  						icsk->icsk_user_timeout); -	}  	tcp_fastopen_active_detect_blackhole(sk, expired);  	if (BPF_SOCK_OPS_TEST_FLAG(tp, BPF_SOCK_OPS_RTO_CB_FLAG))  |