diff options
Diffstat (limited to 'net/rxrpc/sendmsg.c')
| -rw-r--r-- | net/rxrpc/sendmsg.c | 26 | 
1 files changed, 9 insertions, 17 deletions
| diff --git a/net/rxrpc/sendmsg.c b/net/rxrpc/sendmsg.c index 0fcf157aa09f..5e9c43d4a314 100644 --- a/net/rxrpc/sendmsg.c +++ b/net/rxrpc/sendmsg.c @@ -66,15 +66,14 @@ static int rxrpc_wait_for_tx_window_waitall(struct rxrpc_sock *rx,  					    struct rxrpc_call *call)  {  	rxrpc_seq_t tx_start, tx_win; -	signed long rtt2, timeout; -	u64 rtt; +	signed long rtt, timeout; -	rtt = READ_ONCE(call->peer->rtt); -	rtt2 = nsecs_to_jiffies64(rtt) * 2; -	if (rtt2 < 2) -		rtt2 = 2; +	rtt = READ_ONCE(call->peer->srtt_us) >> 3; +	rtt = usecs_to_jiffies(rtt) * 2; +	if (rtt < 2) +		rtt = 2; -	timeout = rtt2; +	timeout = rtt;  	tx_start = READ_ONCE(call->tx_hard_ack);  	for (;;) { @@ -92,7 +91,7 @@ static int rxrpc_wait_for_tx_window_waitall(struct rxrpc_sock *rx,  			return -EINTR;  		if (tx_win != tx_start) { -			timeout = rtt2; +			timeout = rtt;  			tx_start = tx_win;  		} @@ -271,16 +270,9 @@ static int rxrpc_queue_packet(struct rxrpc_sock *rx, struct rxrpc_call *call,  		_debug("need instant resend %d", ret);  		rxrpc_instant_resend(call, ix);  	} else { -		unsigned long now = jiffies, resend_at; +		unsigned long now = jiffies; +		unsigned long resend_at = now + call->peer->rto_j; -		if (call->peer->rtt_usage > 1) -			resend_at = nsecs_to_jiffies(call->peer->rtt * 3 / 2); -		else -			resend_at = rxrpc_resend_timeout; -		if (resend_at < 1) -			resend_at = 1; - -		resend_at += now;  		WRITE_ONCE(call->resend_at, resend_at);  		rxrpc_reduce_call_timer(call, resend_at, now,  					rxrpc_timer_set_for_send); | 
