diff options
Diffstat (limited to 'net/ipv4/tcp_rate.c')
| -rw-r--r-- | net/ipv4/tcp_rate.c | 15 | 
1 files changed, 8 insertions, 7 deletions
| diff --git a/net/ipv4/tcp_rate.c b/net/ipv4/tcp_rate.c index 4dff40dad4dc..baed2186c7c6 100644 --- a/net/ipv4/tcp_rate.c +++ b/net/ipv4/tcp_rate.c @@ -55,8 +55,10 @@ void tcp_rate_skb_sent(struct sock *sk, struct sk_buff *skb)  	  * bandwidth estimate.  	  */  	if (!tp->packets_out) { -		tp->first_tx_mstamp  = skb->skb_mstamp; -		tp->delivered_mstamp = skb->skb_mstamp; +		u64 tstamp_us = tcp_skb_timestamp_us(skb); + +		tp->first_tx_mstamp  = tstamp_us; +		tp->delivered_mstamp = tstamp_us;  	}  	TCP_SKB_CB(skb)->tx.first_tx_mstamp	= tp->first_tx_mstamp; @@ -88,13 +90,12 @@ void tcp_rate_skb_delivered(struct sock *sk, struct sk_buff *skb,  		rs->is_app_limited   = scb->tx.is_app_limited;  		rs->is_retrans	     = scb->sacked & TCPCB_RETRANS; +		/* Record send time of most recently ACKed packet: */ +		tp->first_tx_mstamp  = tcp_skb_timestamp_us(skb);  		/* Find the duration of the "send phase" of this window: */ -		rs->interval_us      = tcp_stamp_us_delta( -						skb->skb_mstamp, -						scb->tx.first_tx_mstamp); +		rs->interval_us = tcp_stamp_us_delta(tp->first_tx_mstamp, +						     scb->tx.first_tx_mstamp); -		/* Record send time of most recently ACKed packet: */ -		tp->first_tx_mstamp  = skb->skb_mstamp;  	}  	/* Mark off the skb delivered once it's sacked to avoid being  	 * used again when it's cumulatively acked. For acked packets | 
