mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	tcp: tcp_v[46]_conn_request: fix snt_synack initialization
Commit016818d07(tcp: TCP Fast Open Server - take SYNACK RTT after completing 3WHS) changes the code to only take a snt_synack timestamp when a SYNACK transmit or retransmit succeeds. This behaviour is later broken by commit843f4a55e(tcp: use tcp_v4_send_synack on first SYN-ACK), as snt_synack is now updated even if tcp_v4_send_synack fails. Also, commit3a19ce0ee(tcp: IPv6 support for fastopen server) misses the required IPv6 updates for016818d07. This patch makes sure that snt_synack is updated only when the SYNACK trasnmit/retransmit succeeds, for both IPv4 and IPv6. Cc: Cardwell <ncardwell@google.com> Cc: Daniel Lee <longinus00@gmail.com> Cc: Yuchung Cheng <ycheng@google.com> Signed-off-by: Octavian Purdila <octavian.purdila@intel.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									57b47553f6
								
							
						
					
					
						commit
						aa27fc5018
					
				
					 2 changed files with 2 additions and 3 deletions
				
			
		| 
						 | 
				
			
			@ -1370,7 +1370,6 @@ int tcp_v4_conn_request(struct sock *sk, struct sk_buff *skb)
 | 
			
		|||
		goto drop_and_free;
 | 
			
		||||
 | 
			
		||||
	tcp_rsk(req)->snt_isn = isn;
 | 
			
		||||
	tcp_rsk(req)->snt_synack = tcp_time_stamp;
 | 
			
		||||
	tcp_openreq_init_rwin(req, sk, dst);
 | 
			
		||||
	fastopen = !want_cookie &&
 | 
			
		||||
		   tcp_try_fastopen(sk, skb, req, &foc, dst);
 | 
			
		||||
| 
						 | 
				
			
			@ -1380,7 +1379,6 @@ int tcp_v4_conn_request(struct sock *sk, struct sk_buff *skb)
 | 
			
		|||
		if (err || want_cookie)
 | 
			
		||||
			goto drop_and_free;
 | 
			
		||||
 | 
			
		||||
		tcp_rsk(req)->snt_synack = tcp_time_stamp;
 | 
			
		||||
		tcp_rsk(req)->listener = NULL;
 | 
			
		||||
		inet_csk_reqsk_queue_hash_add(sk, req, TCP_TIMEOUT_INIT);
 | 
			
		||||
	}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -497,6 +497,8 @@ static int tcp_v6_send_synack(struct sock *sk, struct dst_entry *dst,
 | 
			
		|||
		skb_set_queue_mapping(skb, queue_mapping);
 | 
			
		||||
		err = ip6_xmit(sk, skb, fl6, np->opt, np->tclass);
 | 
			
		||||
		err = net_xmit_eval(err);
 | 
			
		||||
		if (!tcp_rsk(req)->snt_synack && !err)
 | 
			
		||||
			tcp_rsk(req)->snt_synack = tcp_time_stamp;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
done:
 | 
			
		||||
| 
						 | 
				
			
			@ -1100,7 +1102,6 @@ static int tcp_v6_conn_request(struct sock *sk, struct sk_buff *skb)
 | 
			
		|||
		goto drop_and_free;
 | 
			
		||||
 | 
			
		||||
	tcp_rsk(req)->snt_isn = isn;
 | 
			
		||||
	tcp_rsk(req)->snt_synack = tcp_time_stamp;
 | 
			
		||||
	tcp_openreq_init_rwin(req, sk, dst);
 | 
			
		||||
	fastopen = !want_cookie &&
 | 
			
		||||
		   tcp_try_fastopen(sk, skb, req, &foc, dst);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue