diff options
Diffstat (limited to 'net/ipv4/tcp_output.c')
| -rw-r--r-- | net/ipv4/tcp_output.c | 15 | 
1 files changed, 6 insertions, 9 deletions
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index c5eadec001c1..bf38b1fb63ab 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c @@ -866,11 +866,7 @@ static int tcp_transmit_skb(struct sock *sk, struct sk_buff *skb, int clone_it,  	if (clone_it) {  		const struct sk_buff *fclone = skb + 1; -		/* If congestion control is doing timestamping, we must -		 * take such a timestamp before we potentially clone/copy. -		 */ -		if (icsk->icsk_ca_ops->flags & TCP_CONG_RTT_STAMP) -			__net_timestamp(skb); +		skb_mstamp_get(&skb->skb_mstamp);  		if (unlikely(skb->fclone == SKB_FCLONE_ORIG &&  			     fclone->fclone == SKB_FCLONE_CLONE)) @@ -1974,7 +1970,7 @@ bool tcp_schedule_loss_probe(struct sock *sk)  	struct inet_connection_sock *icsk = inet_csk(sk);  	struct tcp_sock *tp = tcp_sk(sk);  	u32 timeout, tlp_time_stamp, rto_time_stamp; -	u32 rtt = tp->srtt >> 3; +	u32 rtt = usecs_to_jiffies(tp->srtt_us >> 3);  	if (WARN_ON(icsk->icsk_pending == ICSK_TIME_EARLY_RETRANS))  		return false; @@ -1996,7 +1992,7 @@ bool tcp_schedule_loss_probe(struct sock *sk)  	/* Schedule a loss probe in 2*RTT for SACK capable connections  	 * in Open state, that are either limited by cwnd or application.  	 */ -	if (sysctl_tcp_early_retrans < 3 || !tp->srtt || !tp->packets_out || +	if (sysctl_tcp_early_retrans < 3 || !tp->srtt_us || !tp->packets_out ||  	    !tcp_is_sack(tp) || inet_csk(sk)->icsk_ca_state != TCP_CA_Open)  		return false; @@ -3050,8 +3046,9 @@ void tcp_send_delayed_ack(struct sock *sk)  		 * Do not use inet_csk(sk)->icsk_rto here, use results of rtt measurements  		 * directly.  		 */ -		if (tp->srtt) { -			int rtt = max(tp->srtt >> 3, TCP_DELACK_MIN); +		if (tp->srtt_us) { +			int rtt = max_t(int, usecs_to_jiffies(tp->srtt_us >> 3), +					TCP_DELACK_MIN);  			if (rtt < max_ato)  				max_ato = rtt;  | 
