Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    1) /* SPDX-License-Identifier: GPL-2.0-or-later */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    3)  * INET		An implementation of the TCP/IP protocol suite for the LINUX
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    4)  *		operating system.  INET is implemented using the  BSD Socket
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    5)  *		interface as the means of communication with the user level.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    6)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    7)  *		Definitions for the TCP module.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    8)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300    9)  * Version:	@(#)tcp.h	1.0.5	05/23/93
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   10)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   11)  * Authors:	Ross Biro
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   12)  *		Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   13)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   14) #ifndef _TCP_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   15) #define _TCP_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   16) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   17) #define FASTRETRANS_DEBUG 1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   18) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   19) #include <linux/list.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   20) #include <linux/tcp.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   21) #include <linux/bug.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   22) #include <linux/slab.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   23) #include <linux/cache.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   24) #include <linux/percpu.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   25) #include <linux/skbuff.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   26) #include <linux/kref.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   27) #include <linux/ktime.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   28) #include <linux/indirect_call_wrapper.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   29) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   30) #include <net/inet_connection_sock.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   31) #include <net/inet_timewait_sock.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   32) #include <net/inet_hashtables.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   33) #include <net/checksum.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   34) #include <net/request_sock.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   35) #include <net/sock_reuseport.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   36) #include <net/sock.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   37) #include <net/snmp.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   38) #include <net/ip.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   39) #include <net/tcp_states.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   40) #include <net/inet_ecn.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   41) #include <net/dst.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   42) #include <net/mptcp.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   43) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   44) #include <linux/seq_file.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   45) #include <linux/memcontrol.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   46) #include <linux/bpf-cgroup.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   47) #include <linux/siphash.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   48) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   49) extern struct inet_hashinfo tcp_hashinfo;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   50) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   51) extern struct percpu_counter tcp_orphan_count;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   52) void tcp_time_wait(struct sock *sk, int state, int timeo);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   53) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   54) #define MAX_TCP_HEADER	L1_CACHE_ALIGN(128 + MAX_HEADER)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   55) #define MAX_TCP_OPTION_SPACE 40
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   56) #define TCP_MIN_SND_MSS		48
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   57) #define TCP_MIN_GSO_SIZE	(TCP_MIN_SND_MSS - MAX_TCP_OPTION_SPACE)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   58) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   59) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   60)  * Never offer a window over 32767 without using window scaling. Some
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   61)  * poor stacks do signed 16bit maths!
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   62)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   63) #define MAX_TCP_WINDOW		32767U
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   64) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   65) /* Minimal accepted MSS. It is (60+60+8) - (20+20). */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   66) #define TCP_MIN_MSS		88U
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   67) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   68) /* The initial MTU to use for probing */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   69) #define TCP_BASE_MSS		1024
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   70) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   71) /* probing interval, default to 10 minutes as per RFC4821 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   72) #define TCP_PROBE_INTERVAL	600
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   73) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   74) /* Specify interval when tcp mtu probing will stop */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   75) #define TCP_PROBE_THRESHOLD	8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   76) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   77) /* After receiving this amount of duplicate ACKs fast retransmit starts. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   78) #define TCP_FASTRETRANS_THRESH 3
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   79) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   80) /* Maximal number of ACKs sent quickly to accelerate slow-start. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   81) #define TCP_MAX_QUICKACKS	16U
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   82) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   83) /* Maximal number of window scale according to RFC1323 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   84) #define TCP_MAX_WSCALE		14U
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   85) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   86) /* urg_data states */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   87) #define TCP_URG_VALID	0x0100
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   88) #define TCP_URG_NOTYET	0x0200
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   89) #define TCP_URG_READ	0x0400
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   90) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   91) #define TCP_RETR1	3	/*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   92) 				 * This is how many retries it does before it
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   93) 				 * tries to figure out if the gateway is
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   94) 				 * down. Minimal RFC value is 3; it corresponds
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   95) 				 * to ~3sec-8min depending on RTO.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   96) 				 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   97) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   98) #define TCP_RETR2	15	/*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   99) 				 * This should take at least
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  100) 				 * 90 minutes to time out.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  101) 				 * RFC1122 says that the limit is 100 sec.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  102) 				 * 15 is ~13-30min depending on RTO.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  103) 				 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  104) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  105) #define TCP_SYN_RETRIES	 6	/* This is how many retries are done
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  106) 				 * when active opening a connection.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  107) 				 * RFC1122 says the minimum retry MUST
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  108) 				 * be at least 180secs.  Nevertheless
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  109) 				 * this value is corresponding to
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  110) 				 * 63secs of retransmission with the
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  111) 				 * current initial RTO.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  112) 				 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  113) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  114) #define TCP_SYNACK_RETRIES 5	/* This is how may retries are done
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  115) 				 * when passive opening a connection.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  116) 				 * This is corresponding to 31secs of
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  117) 				 * retransmission with the current
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  118) 				 * initial RTO.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  119) 				 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  120) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  121) #define TCP_TIMEWAIT_LEN (60*HZ) /* how long to wait to destroy TIME-WAIT
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  122) 				  * state, about 60 seconds	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  123) #define TCP_FIN_TIMEOUT	TCP_TIMEWAIT_LEN
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  124)                                  /* BSD style FIN_WAIT2 deadlock breaker.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  125) 				  * It used to be 3min, new value is 60sec,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  126) 				  * to combine FIN-WAIT-2 timeout with
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  127) 				  * TIME-WAIT timer.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  128) 				  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  129) #define TCP_FIN_TIMEOUT_MAX (120 * HZ) /* max TCP_LINGER2 value (two minutes) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  130) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  131) #define TCP_DELACK_MAX	((unsigned)(HZ/5))	/* maximal time to delay before sending an ACK */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  132) #if HZ >= 100
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  133) #define TCP_DELACK_MIN	((unsigned)(HZ/25))	/* minimal time to delay before sending an ACK */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  134) #define TCP_ATO_MIN	((unsigned)(HZ/25))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  135) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  136) #define TCP_DELACK_MIN	4U
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  137) #define TCP_ATO_MIN	4U
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  138) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  139) #define TCP_RTO_MAX	((unsigned)(120*HZ))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  140) #define TCP_RTO_MIN	((unsigned)(HZ/5))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  141) #define TCP_TIMEOUT_MIN	(2U) /* Min timeout for TCP timers in jiffies */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  142) #define TCP_TIMEOUT_INIT ((unsigned)(1*HZ))	/* RFC6298 2.1 initial RTO value	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  143) #define TCP_TIMEOUT_FALLBACK ((unsigned)(3*HZ))	/* RFC 1122 initial RTO value, now
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  144) 						 * used as a fallback RTO for the
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  145) 						 * initial data transmission if no
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  146) 						 * valid RTT sample has been acquired,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  147) 						 * most likely due to retrans in 3WHS.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  148) 						 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  149) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  150) #define TCP_RESOURCE_PROBE_INTERVAL ((unsigned)(HZ/2U)) /* Maximal interval between probes
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  151) 					                 * for local resources.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  152) 					                 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  153) #define TCP_KEEPALIVE_TIME	(120*60*HZ)	/* two hours */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  154) #define TCP_KEEPALIVE_PROBES	9		/* Max of 9 keepalive probes	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  155) #define TCP_KEEPALIVE_INTVL	(75*HZ)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  156) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  157) #define MAX_TCP_KEEPIDLE	32767
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  158) #define MAX_TCP_KEEPINTVL	32767
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  159) #define MAX_TCP_KEEPCNT		127
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  160) #define MAX_TCP_SYNCNT		127
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  161) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  162) #define TCP_SYNQ_INTERVAL	(HZ/5)	/* Period of SYNACK timer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  163) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  164) #define TCP_PAWS_24DAYS	(60 * 60 * 24 * 24)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  165) #define TCP_PAWS_MSL	60		/* Per-host timestamps are invalidated
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  166) 					 * after this time. It should be equal
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  167) 					 * (or greater than) TCP_TIMEWAIT_LEN
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  168) 					 * to provide reliability equal to one
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  169) 					 * provided by timewait state.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  170) 					 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  171) #define TCP_PAWS_WINDOW	1		/* Replay window for per-host
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  172) 					 * timestamps. It must be less than
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  173) 					 * minimal timewait lifetime.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  174) 					 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  175) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  176)  *	TCP option
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  177)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  178) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  179) #define TCPOPT_NOP		1	/* Padding */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  180) #define TCPOPT_EOL		0	/* End of options */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  181) #define TCPOPT_MSS		2	/* Segment size negotiating */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  182) #define TCPOPT_WINDOW		3	/* Window scaling */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  183) #define TCPOPT_SACK_PERM        4       /* SACK Permitted */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  184) #define TCPOPT_SACK             5       /* SACK Block */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  185) #define TCPOPT_TIMESTAMP	8	/* Better RTT estimations/PAWS */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  186) #define TCPOPT_MD5SIG		19	/* MD5 Signature (RFC2385) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  187) #define TCPOPT_MPTCP		30	/* Multipath TCP (RFC6824) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  188) #define TCPOPT_FASTOPEN		34	/* Fast open (RFC7413) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  189) #define TCPOPT_EXP		254	/* Experimental */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  190) /* Magic number to be after the option value for sharing TCP
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  191)  * experimental options. See draft-ietf-tcpm-experimental-options-00.txt
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  192)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  193) #define TCPOPT_FASTOPEN_MAGIC	0xF989
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  194) #define TCPOPT_SMC_MAGIC	0xE2D4C3D9
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  195) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  196) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  197)  *     TCP option lengths
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  198)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  199) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  200) #define TCPOLEN_MSS            4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  201) #define TCPOLEN_WINDOW         3
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  202) #define TCPOLEN_SACK_PERM      2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  203) #define TCPOLEN_TIMESTAMP      10
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  204) #define TCPOLEN_MD5SIG         18
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  205) #define TCPOLEN_FASTOPEN_BASE  2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  206) #define TCPOLEN_EXP_FASTOPEN_BASE  4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  207) #define TCPOLEN_EXP_SMC_BASE   6
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  208) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  209) /* But this is what stacks really send out. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  210) #define TCPOLEN_TSTAMP_ALIGNED		12
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  211) #define TCPOLEN_WSCALE_ALIGNED		4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  212) #define TCPOLEN_SACKPERM_ALIGNED	4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  213) #define TCPOLEN_SACK_BASE		2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  214) #define TCPOLEN_SACK_BASE_ALIGNED	4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  215) #define TCPOLEN_SACK_PERBLOCK		8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  216) #define TCPOLEN_MD5SIG_ALIGNED		20
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  217) #define TCPOLEN_MSS_ALIGNED		4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  218) #define TCPOLEN_EXP_SMC_BASE_ALIGNED	8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  219) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  220) /* Flags in tp->nonagle */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  221) #define TCP_NAGLE_OFF		1	/* Nagle's algo is disabled */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  222) #define TCP_NAGLE_CORK		2	/* Socket is corked	    */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  223) #define TCP_NAGLE_PUSH		4	/* Cork is overridden for already queued data */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  224) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  225) /* TCP thin-stream limits */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  226) #define TCP_THIN_LINEAR_RETRIES 6       /* After 6 linear retries, do exp. backoff */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  227) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  228) /* TCP initial congestion window as per rfc6928 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  229) #define TCP_INIT_CWND		10
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  230) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  231) /* Bit Flags for sysctl_tcp_fastopen */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  232) #define	TFO_CLIENT_ENABLE	1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  233) #define	TFO_SERVER_ENABLE	2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  234) #define	TFO_CLIENT_NO_COOKIE	4	/* Data in SYN w/o cookie option */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  235) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  236) /* Accept SYN data w/o any cookie option */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  237) #define	TFO_SERVER_COOKIE_NOT_REQD	0x200
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  238) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  239) /* Force enable TFO on all listeners, i.e., not requiring the
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  240)  * TCP_FASTOPEN socket option.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  241)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  242) #define	TFO_SERVER_WO_SOCKOPT1	0x400
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  243) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  244) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  245) /* sysctl variables for tcp */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  246) extern int sysctl_tcp_max_orphans;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  247) extern long sysctl_tcp_mem[3];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  248) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  249) #define TCP_RACK_LOSS_DETECTION  0x1 /* Use RACK to detect losses */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  250) #define TCP_RACK_STATIC_REO_WND  0x2 /* Use static RACK reo wnd */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  251) #define TCP_RACK_NO_DUPTHRESH    0x4 /* Do not use DUPACK threshold in RACK */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  252) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  253) extern atomic_long_t tcp_memory_allocated;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  254) extern struct percpu_counter tcp_sockets_allocated;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  255) extern unsigned long tcp_memory_pressure;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  256) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  257) /* optimized version of sk_under_memory_pressure() for TCP sockets */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  258) static inline bool tcp_under_memory_pressure(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  259) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  260) 	if (mem_cgroup_sockets_enabled && sk->sk_memcg &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  261) 	    mem_cgroup_under_socket_pressure(sk->sk_memcg))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  262) 		return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  263) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  264) 	return READ_ONCE(tcp_memory_pressure);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  265) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  266) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  267)  * The next routines deal with comparing 32 bit unsigned ints
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  268)  * and worry about wraparound (automatic with unsigned arithmetic).
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  269)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  270) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  271) static inline bool before(__u32 seq1, __u32 seq2)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  272) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  273)         return (__s32)(seq1-seq2) < 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  274) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  275) #define after(seq2, seq1) 	before(seq1, seq2)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  276) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  277) /* is s2<=s1<=s3 ? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  278) static inline bool between(__u32 seq1, __u32 seq2, __u32 seq3)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  279) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  280) 	return seq3 - seq2 >= seq1 - seq2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  281) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  282) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  283) static inline bool tcp_out_of_memory(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  284) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  285) 	if (sk->sk_wmem_queued > SOCK_MIN_SNDBUF &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  286) 	    sk_memory_allocated(sk) > sk_prot_mem_limits(sk, 2))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  287) 		return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  288) 	return false;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  289) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  290) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  291) void sk_forced_mem_schedule(struct sock *sk, int size);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  292) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  293) static inline bool tcp_too_many_orphans(struct sock *sk, int shift)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  294) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  295) 	struct percpu_counter *ocp = sk->sk_prot->orphan_count;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  296) 	int orphans = percpu_counter_read_positive(ocp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  297) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  298) 	if (orphans << shift > sysctl_tcp_max_orphans) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  299) 		orphans = percpu_counter_sum_positive(ocp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  300) 		if (orphans << shift > sysctl_tcp_max_orphans)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  301) 			return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  302) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  303) 	return false;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  304) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  305) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  306) bool tcp_check_oom(struct sock *sk, int shift);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  307) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  308) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  309) extern struct proto tcp_prot;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  310) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  311) #define TCP_INC_STATS(net, field)	SNMP_INC_STATS((net)->mib.tcp_statistics, field)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  312) #define __TCP_INC_STATS(net, field)	__SNMP_INC_STATS((net)->mib.tcp_statistics, field)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  313) #define TCP_DEC_STATS(net, field)	SNMP_DEC_STATS((net)->mib.tcp_statistics, field)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  314) #define TCP_ADD_STATS(net, field, val)	SNMP_ADD_STATS((net)->mib.tcp_statistics, field, val)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  315) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  316) void tcp_tasklet_init(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  317) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  318) int tcp_v4_err(struct sk_buff *skb, u32);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  319) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  320) void tcp_shutdown(struct sock *sk, int how);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  321) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  322) int tcp_v4_early_demux(struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  323) int tcp_v4_rcv(struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  324) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  325) int tcp_v4_tw_remember_stamp(struct inet_timewait_sock *tw);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  326) int tcp_sendmsg(struct sock *sk, struct msghdr *msg, size_t size);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  327) int tcp_sendmsg_locked(struct sock *sk, struct msghdr *msg, size_t size);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  328) int tcp_sendpage(struct sock *sk, struct page *page, int offset, size_t size,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  329) 		 int flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  330) int tcp_sendpage_locked(struct sock *sk, struct page *page, int offset,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  331) 			size_t size, int flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  332) ssize_t do_tcp_sendpages(struct sock *sk, struct page *page, int offset,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  333) 		 size_t size, int flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  334) int tcp_send_mss(struct sock *sk, int *size_goal, int flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  335) void tcp_push(struct sock *sk, int flags, int mss_now, int nonagle,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  336) 	      int size_goal);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  337) void tcp_release_cb(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  338) void tcp_wfree(struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  339) void tcp_write_timer_handler(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  340) void tcp_delack_timer_handler(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  341) int tcp_ioctl(struct sock *sk, int cmd, unsigned long arg);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  342) int tcp_rcv_state_process(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  343) void tcp_rcv_established(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  344) void tcp_rcv_space_adjust(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  345) int tcp_twsk_unique(struct sock *sk, struct sock *sktw, void *twp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  346) void tcp_twsk_destructor(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  347) ssize_t tcp_splice_read(struct socket *sk, loff_t *ppos,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  348) 			struct pipe_inode_info *pipe, size_t len,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  349) 			unsigned int flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  350) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  351) void tcp_enter_quickack_mode(struct sock *sk, unsigned int max_quickacks);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  352) static inline void tcp_dec_quickack_mode(struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  353) 					 const unsigned int pkts)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  354) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  355) 	struct inet_connection_sock *icsk = inet_csk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  356) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  357) 	if (icsk->icsk_ack.quick) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  358) 		if (pkts >= icsk->icsk_ack.quick) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  359) 			icsk->icsk_ack.quick = 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  360) 			/* Leaving quickack mode we deflate ATO. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  361) 			icsk->icsk_ack.ato   = TCP_ATO_MIN;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  362) 		} else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  363) 			icsk->icsk_ack.quick -= pkts;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  364) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  365) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  366) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  367) #define	TCP_ECN_OK		1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  368) #define	TCP_ECN_QUEUE_CWR	2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  369) #define	TCP_ECN_DEMAND_CWR	4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  370) #define	TCP_ECN_SEEN		8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  371) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  372) enum tcp_tw_status {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  373) 	TCP_TW_SUCCESS = 0,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  374) 	TCP_TW_RST = 1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  375) 	TCP_TW_ACK = 2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  376) 	TCP_TW_SYN = 3
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  377) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  378) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  379) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  380) enum tcp_tw_status tcp_timewait_state_process(struct inet_timewait_sock *tw,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  381) 					      struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  382) 					      const struct tcphdr *th);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  383) struct sock *tcp_check_req(struct sock *sk, struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  384) 			   struct request_sock *req, bool fastopen,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  385) 			   bool *lost_race);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  386) int tcp_child_process(struct sock *parent, struct sock *child,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  387) 		      struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  388) void tcp_enter_loss(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  389) void tcp_cwnd_reduction(struct sock *sk, int newly_acked_sacked, int flag);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  390) void tcp_clear_retrans(struct tcp_sock *tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  391) void tcp_update_metrics(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  392) void tcp_init_metrics(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  393) void tcp_metrics_init(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  394) bool tcp_peer_is_proven(struct request_sock *req, struct dst_entry *dst);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  395) void tcp_close(struct sock *sk, long timeout);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  396) void tcp_init_sock(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  397) void tcp_init_transfer(struct sock *sk, int bpf_op, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  398) __poll_t tcp_poll(struct file *file, struct socket *sock,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  399) 		      struct poll_table_struct *wait);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  400) int tcp_getsockopt(struct sock *sk, int level, int optname,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  401) 		   char __user *optval, int __user *optlen);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  402) int tcp_setsockopt(struct sock *sk, int level, int optname, sockptr_t optval,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  403) 		   unsigned int optlen);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  404) void tcp_set_keepalive(struct sock *sk, int val);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  405) void tcp_syn_ack_timeout(const struct request_sock *req);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  406) int tcp_recvmsg(struct sock *sk, struct msghdr *msg, size_t len, int nonblock,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  407) 		int flags, int *addr_len);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  408) int tcp_set_rcvlowat(struct sock *sk, int val);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  409) void tcp_data_ready(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  410) #ifdef CONFIG_MMU
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  411) int tcp_mmap(struct file *file, struct socket *sock,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  412) 	     struct vm_area_struct *vma);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  413) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  414) void tcp_parse_options(const struct net *net, const struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  415) 		       struct tcp_options_received *opt_rx,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  416) 		       int estab, struct tcp_fastopen_cookie *foc);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  417) const u8 *tcp_parse_md5sig_option(const struct tcphdr *th);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  418) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  419) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  420)  *	BPF SKB-less helpers
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  421)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  422) u16 tcp_v4_get_syncookie(struct sock *sk, struct iphdr *iph,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  423) 			 struct tcphdr *th, u32 *cookie);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  424) u16 tcp_v6_get_syncookie(struct sock *sk, struct ipv6hdr *iph,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  425) 			 struct tcphdr *th, u32 *cookie);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  426) u16 tcp_get_syncookie_mss(struct request_sock_ops *rsk_ops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  427) 			  const struct tcp_request_sock_ops *af_ops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  428) 			  struct sock *sk, struct tcphdr *th);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  429) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  430)  *	TCP v4 functions exported for the inet6 API
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  431)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  432) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  433) void tcp_v4_send_check(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  434) void tcp_v4_mtu_reduced(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  435) void tcp_req_err(struct sock *sk, u32 seq, bool abort);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  436) void tcp_ld_RTO_revert(struct sock *sk, u32 seq);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  437) int tcp_v4_conn_request(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  438) struct sock *tcp_create_openreq_child(const struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  439) 				      struct request_sock *req,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  440) 				      struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  441) void tcp_ca_openreq_child(struct sock *sk, const struct dst_entry *dst);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  442) struct sock *tcp_v4_syn_recv_sock(const struct sock *sk, struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  443) 				  struct request_sock *req,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  444) 				  struct dst_entry *dst,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  445) 				  struct request_sock *req_unhash,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  446) 				  bool *own_req);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  447) int tcp_v4_do_rcv(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  448) int tcp_v4_connect(struct sock *sk, struct sockaddr *uaddr, int addr_len);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  449) int tcp_connect(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  450) enum tcp_synack_type {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  451) 	TCP_SYNACK_NORMAL,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  452) 	TCP_SYNACK_FASTOPEN,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  453) 	TCP_SYNACK_COOKIE,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  454) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  455) struct sk_buff *tcp_make_synack(const struct sock *sk, struct dst_entry *dst,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  456) 				struct request_sock *req,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  457) 				struct tcp_fastopen_cookie *foc,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  458) 				enum tcp_synack_type synack_type,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  459) 				struct sk_buff *syn_skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  460) int tcp_disconnect(struct sock *sk, int flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  461) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  462) void tcp_finish_connect(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  463) int tcp_send_rcvq(struct sock *sk, struct msghdr *msg, size_t size);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  464) void inet_sk_rx_dst_set(struct sock *sk, const struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  465) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  466) /* From syncookies.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  467) struct sock *tcp_get_cookie_sock(struct sock *sk, struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  468) 				 struct request_sock *req,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  469) 				 struct dst_entry *dst, u32 tsoff);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  470) int __cookie_v4_check(const struct iphdr *iph, const struct tcphdr *th,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  471) 		      u32 cookie);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  472) struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  473) struct request_sock *cookie_tcp_reqsk_alloc(const struct request_sock_ops *ops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  474) 					    struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  475) #ifdef CONFIG_SYN_COOKIES
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  476) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  477) /* Syncookies use a monotonic timer which increments every 60 seconds.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  478)  * This counter is used both as a hash input and partially encoded into
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  479)  * the cookie value.  A cookie is only validated further if the delta
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  480)  * between the current counter value and the encoded one is less than this,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  481)  * i.e. a sent cookie is valid only at most for 2*60 seconds (or less if
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  482)  * the counter advances immediately after a cookie is generated).
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  483)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  484) #define MAX_SYNCOOKIE_AGE	2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  485) #define TCP_SYNCOOKIE_PERIOD	(60 * HZ)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  486) #define TCP_SYNCOOKIE_VALID	(MAX_SYNCOOKIE_AGE * TCP_SYNCOOKIE_PERIOD)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  487) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  488) /* syncookies: remember time of last synqueue overflow
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  489)  * But do not dirty this field too often (once per second is enough)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  490)  * It is racy as we do not hold a lock, but race is very minor.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  491)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  492) static inline void tcp_synq_overflow(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  493) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  494) 	unsigned int last_overflow;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  495) 	unsigned int now = jiffies;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  496) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  497) 	if (sk->sk_reuseport) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  498) 		struct sock_reuseport *reuse;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  499) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  500) 		reuse = rcu_dereference(sk->sk_reuseport_cb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  501) 		if (likely(reuse)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  502) 			last_overflow = READ_ONCE(reuse->synq_overflow_ts);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  503) 			if (!time_between32(now, last_overflow,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  504) 					    last_overflow + HZ))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  505) 				WRITE_ONCE(reuse->synq_overflow_ts, now);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  506) 			return;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  507) 		}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  508) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  509) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  510) 	last_overflow = READ_ONCE(tcp_sk(sk)->rx_opt.ts_recent_stamp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  511) 	if (!time_between32(now, last_overflow, last_overflow + HZ))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  512) 		WRITE_ONCE(tcp_sk(sk)->rx_opt.ts_recent_stamp, now);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  513) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  514) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  515) /* syncookies: no recent synqueue overflow on this listening socket? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  516) static inline bool tcp_synq_no_recent_overflow(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  517) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  518) 	unsigned int last_overflow;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  519) 	unsigned int now = jiffies;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  520) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  521) 	if (sk->sk_reuseport) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  522) 		struct sock_reuseport *reuse;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  523) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  524) 		reuse = rcu_dereference(sk->sk_reuseport_cb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  525) 		if (likely(reuse)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  526) 			last_overflow = READ_ONCE(reuse->synq_overflow_ts);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  527) 			return !time_between32(now, last_overflow - HZ,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  528) 					       last_overflow +
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  529) 					       TCP_SYNCOOKIE_VALID);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  530) 		}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  531) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  532) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  533) 	last_overflow = READ_ONCE(tcp_sk(sk)->rx_opt.ts_recent_stamp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  534) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  535) 	/* If last_overflow <= jiffies <= last_overflow + TCP_SYNCOOKIE_VALID,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  536) 	 * then we're under synflood. However, we have to use
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  537) 	 * 'last_overflow - HZ' as lower bound. That's because a concurrent
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  538) 	 * tcp_synq_overflow() could update .ts_recent_stamp after we read
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  539) 	 * jiffies but before we store .ts_recent_stamp into last_overflow,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  540) 	 * which could lead to rejecting a valid syncookie.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  541) 	 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  542) 	return !time_between32(now, last_overflow - HZ,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  543) 			       last_overflow + TCP_SYNCOOKIE_VALID);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  544) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  545) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  546) static inline u32 tcp_cookie_time(void)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  547) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  548) 	u64 val = get_jiffies_64();
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  549) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  550) 	do_div(val, TCP_SYNCOOKIE_PERIOD);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  551) 	return val;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  552) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  553) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  554) u32 __cookie_v4_init_sequence(const struct iphdr *iph, const struct tcphdr *th,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  555) 			      u16 *mssp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  556) __u32 cookie_v4_init_sequence(const struct sk_buff *skb, __u16 *mss);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  557) u64 cookie_init_timestamp(struct request_sock *req, u64 now);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  558) bool cookie_timestamp_decode(const struct net *net,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  559) 			     struct tcp_options_received *opt);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  560) bool cookie_ecn_ok(const struct tcp_options_received *opt,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  561) 		   const struct net *net, const struct dst_entry *dst);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  562) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  563) /* From net/ipv6/syncookies.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  564) int __cookie_v6_check(const struct ipv6hdr *iph, const struct tcphdr *th,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  565) 		      u32 cookie);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  566) struct sock *cookie_v6_check(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  567) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  568) u32 __cookie_v6_init_sequence(const struct ipv6hdr *iph,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  569) 			      const struct tcphdr *th, u16 *mssp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  570) __u32 cookie_v6_init_sequence(const struct sk_buff *skb, __u16 *mss);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  571) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  572) /* tcp_output.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  573) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  574) void __tcp_push_pending_frames(struct sock *sk, unsigned int cur_mss,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  575) 			       int nonagle);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  576) int __tcp_retransmit_skb(struct sock *sk, struct sk_buff *skb, int segs);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  577) int tcp_retransmit_skb(struct sock *sk, struct sk_buff *skb, int segs);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  578) void tcp_retransmit_timer(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  579) void tcp_xmit_retransmit_queue(struct sock *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  580) void tcp_simple_retransmit(struct sock *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  581) void tcp_enter_recovery(struct sock *sk, bool ece_ack);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  582) int tcp_trim_head(struct sock *, struct sk_buff *, u32);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  583) enum tcp_queue {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  584) 	TCP_FRAG_IN_WRITE_QUEUE,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  585) 	TCP_FRAG_IN_RTX_QUEUE,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  586) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  587) int tcp_fragment(struct sock *sk, enum tcp_queue tcp_queue,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  588) 		 struct sk_buff *skb, u32 len,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  589) 		 unsigned int mss_now, gfp_t gfp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  590) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  591) void tcp_send_probe0(struct sock *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  592) void tcp_send_partial(struct sock *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  593) int tcp_write_wakeup(struct sock *, int mib);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  594) void tcp_send_fin(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  595) void tcp_send_active_reset(struct sock *sk, gfp_t priority);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  596) int tcp_send_synack(struct sock *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  597) void tcp_push_one(struct sock *, unsigned int mss_now);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  598) void __tcp_send_ack(struct sock *sk, u32 rcv_nxt);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  599) void tcp_send_ack(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  600) void tcp_send_delayed_ack(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  601) void tcp_send_loss_probe(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  602) bool tcp_schedule_loss_probe(struct sock *sk, bool advancing_rto);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  603) void tcp_skb_collapse_tstamp(struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  604) 			     const struct sk_buff *next_skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  605) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  606) /* tcp_input.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  607) void tcp_rearm_rto(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  608) void tcp_synack_rtt_meas(struct sock *sk, struct request_sock *req);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  609) void tcp_reset(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  610) void tcp_skb_mark_lost_uncond_verify(struct tcp_sock *tp, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  611) void tcp_fin(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  612) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  613) /* tcp_timer.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  614) void tcp_init_xmit_timers(struct sock *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  615) static inline void tcp_clear_xmit_timers(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  616) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  617) 	if (hrtimer_try_to_cancel(&tcp_sk(sk)->pacing_timer) == 1)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  618) 		__sock_put(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  619) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  620) 	if (hrtimer_try_to_cancel(&tcp_sk(sk)->compressed_ack_timer) == 1)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  621) 		__sock_put(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  622) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  623) 	inet_csk_clear_xmit_timers(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  624) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  625) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  626) unsigned int tcp_sync_mss(struct sock *sk, u32 pmtu);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  627) unsigned int tcp_current_mss(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  628) u32 tcp_clamp_probe0_to_user_timeout(const struct sock *sk, u32 when);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  629) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  630) /* Bound MSS / TSO packet size with the half of the window */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  631) static inline int tcp_bound_to_half_wnd(struct tcp_sock *tp, int pktsize)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  632) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  633) 	int cutoff;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  634) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  635) 	/* When peer uses tiny windows, there is no use in packetizing
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  636) 	 * to sub-MSS pieces for the sake of SWS or making sure there
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  637) 	 * are enough packets in the pipe for fast recovery.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  638) 	 *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  639) 	 * On the other hand, for extremely large MSS devices, handling
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  640) 	 * smaller than MSS windows in this way does make sense.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  641) 	 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  642) 	if (tp->max_window > TCP_MSS_DEFAULT)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  643) 		cutoff = (tp->max_window >> 1);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  644) 	else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  645) 		cutoff = tp->max_window;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  646) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  647) 	if (cutoff && pktsize > cutoff)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  648) 		return max_t(int, cutoff, 68U - tp->tcp_header_len);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  649) 	else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  650) 		return pktsize;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  651) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  652) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  653) /* tcp.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  654) void tcp_get_info(struct sock *, struct tcp_info *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  655) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  656) /* Read 'sendfile()'-style from a TCP socket */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  657) int tcp_read_sock(struct sock *sk, read_descriptor_t *desc,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  658) 		  sk_read_actor_t recv_actor);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  659) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  660) void tcp_initialize_rcv_mss(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  661) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  662) int tcp_mtu_to_mss(struct sock *sk, int pmtu);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  663) int tcp_mss_to_mtu(struct sock *sk, int mss);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  664) void tcp_mtup_init(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  665) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  666) static inline void tcp_bound_rto(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  667) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  668) 	if (inet_csk(sk)->icsk_rto > TCP_RTO_MAX)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  669) 		inet_csk(sk)->icsk_rto = TCP_RTO_MAX;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  670) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  671) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  672) static inline u32 __tcp_set_rto(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  673) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  674) 	return usecs_to_jiffies((tp->srtt_us >> 3) + tp->rttvar_us);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  675) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  676) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  677) static inline void __tcp_fast_path_on(struct tcp_sock *tp, u32 snd_wnd)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  678) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  679) 	/* mptcp hooks are only on the slow path */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  680) 	if (sk_is_mptcp((struct sock *)tp))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  681) 		return;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  682) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  683) 	tp->pred_flags = htonl((tp->tcp_header_len << 26) |
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  684) 			       ntohl(TCP_FLAG_ACK) |
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  685) 			       snd_wnd);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  686) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  687) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  688) static inline void tcp_fast_path_on(struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  689) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  690) 	__tcp_fast_path_on(tp, tp->snd_wnd >> tp->rx_opt.snd_wscale);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  691) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  692) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  693) static inline void tcp_fast_path_check(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  694) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  695) 	struct tcp_sock *tp = tcp_sk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  696) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  697) 	if (RB_EMPTY_ROOT(&tp->out_of_order_queue) &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  698) 	    tp->rcv_wnd &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  699) 	    atomic_read(&sk->sk_rmem_alloc) < sk->sk_rcvbuf &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  700) 	    !tp->urg_data)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  701) 		tcp_fast_path_on(tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  702) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  703) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  704) /* Compute the actual rto_min value */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  705) static inline u32 tcp_rto_min(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  706) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  707) 	const struct dst_entry *dst = __sk_dst_get(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  708) 	u32 rto_min = inet_csk(sk)->icsk_rto_min;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  709) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  710) 	if (dst && dst_metric_locked(dst, RTAX_RTO_MIN))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  711) 		rto_min = dst_metric_rtt(dst, RTAX_RTO_MIN);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  712) 	return rto_min;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  713) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  714) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  715) static inline u32 tcp_rto_min_us(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  716) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  717) 	return jiffies_to_usecs(tcp_rto_min(sk));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  718) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  719) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  720) static inline bool tcp_ca_dst_locked(const struct dst_entry *dst)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  721) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  722) 	return dst_metric_locked(dst, RTAX_CC_ALGO);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  723) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  724) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  725) /* Minimum RTT in usec. ~0 means not available. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  726) static inline u32 tcp_min_rtt(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  727) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  728) 	return minmax_get(&tp->rtt_min);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  729) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  730) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  731) /* Compute the actual receive window we are currently advertising.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  732)  * Rcv_nxt can be after the window if our peer push more data
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  733)  * than the offered window.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  734)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  735) static inline u32 tcp_receive_window(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  736) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  737) 	s32 win = tp->rcv_wup + tp->rcv_wnd - tp->rcv_nxt;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  738) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  739) 	if (win < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  740) 		win = 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  741) 	return (u32) win;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  742) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  743) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  744) /* Choose a new window, without checks for shrinking, and without
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  745)  * scaling applied to the result.  The caller does these things
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  746)  * if necessary.  This is a "raw" window selection.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  747)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  748) u32 __tcp_select_window(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  749) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  750) void tcp_send_window_probe(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  751) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  752) /* TCP uses 32bit jiffies to save some space.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  753)  * Note that this is different from tcp_time_stamp, which
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  754)  * historically has been the same until linux-4.13.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  755)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  756) #define tcp_jiffies32 ((u32)jiffies)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  757) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  758) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  759)  * Deliver a 32bit value for TCP timestamp option (RFC 7323)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  760)  * It is no longer tied to jiffies, but to 1 ms clock.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  761)  * Note: double check if you want to use tcp_jiffies32 instead of this.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  762)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  763) #define TCP_TS_HZ	1000
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  764) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  765) static inline u64 tcp_clock_ns(void)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  766) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  767) 	return ktime_get_ns();
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  768) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  769) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  770) static inline u64 tcp_clock_us(void)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  771) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  772) 	return div_u64(tcp_clock_ns(), NSEC_PER_USEC);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  773) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  774) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  775) /* This should only be used in contexts where tp->tcp_mstamp is up to date */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  776) static inline u32 tcp_time_stamp(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  777) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  778) 	return div_u64(tp->tcp_mstamp, USEC_PER_SEC / TCP_TS_HZ);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  779) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  780) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  781) /* Convert a nsec timestamp into TCP TSval timestamp (ms based currently) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  782) static inline u32 tcp_ns_to_ts(u64 ns)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  783) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  784) 	return div_u64(ns, NSEC_PER_SEC / TCP_TS_HZ);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  785) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  786) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  787) /* Could use tcp_clock_us() / 1000, but this version uses a single divide */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  788) static inline u32 tcp_time_stamp_raw(void)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  789) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  790) 	return tcp_ns_to_ts(tcp_clock_ns());
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  791) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  792) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  793) void tcp_mstamp_refresh(struct tcp_sock *tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  794) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  795) static inline u32 tcp_stamp_us_delta(u64 t1, u64 t0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  796) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  797) 	return max_t(s64, t1 - t0, 0);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  798) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  799) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  800) static inline u32 tcp_skb_timestamp(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  801) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  802) 	return tcp_ns_to_ts(skb->skb_mstamp_ns);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  803) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  804) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  805) /* provide the departure time in us unit */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  806) static inline u64 tcp_skb_timestamp_us(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  807) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  808) 	return div_u64(skb->skb_mstamp_ns, NSEC_PER_USEC);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  809) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  810) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  811) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  812) #define tcp_flag_byte(th) (((u_int8_t *)th)[13])
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  813) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  814) #define TCPHDR_FIN 0x01
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  815) #define TCPHDR_SYN 0x02
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  816) #define TCPHDR_RST 0x04
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  817) #define TCPHDR_PSH 0x08
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  818) #define TCPHDR_ACK 0x10
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  819) #define TCPHDR_URG 0x20
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  820) #define TCPHDR_ECE 0x40
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  821) #define TCPHDR_CWR 0x80
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  822) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  823) #define TCPHDR_SYN_ECN	(TCPHDR_SYN | TCPHDR_ECE | TCPHDR_CWR)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  824) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  825) /* This is what the send packet queuing engine uses to pass
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  826)  * TCP per-packet control information to the transmission code.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  827)  * We also store the host-order sequence numbers in here too.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  828)  * This is 44 bytes if IPV6 is enabled.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  829)  * If this grows please adjust skbuff.h:skbuff->cb[xxx] size appropriately.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  830)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  831) struct tcp_skb_cb {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  832) 	__u32		seq;		/* Starting sequence number	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  833) 	__u32		end_seq;	/* SEQ + FIN + SYN + datalen	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  834) 	union {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  835) 		/* Note : tcp_tw_isn is used in input path only
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  836) 		 *	  (isn chosen by tcp_timewait_state_process())
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  837) 		 *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  838) 		 * 	  tcp_gso_segs/size are used in write queue only,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  839) 		 *	  cf tcp_skb_pcount()/tcp_skb_mss()
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  840) 		 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  841) 		__u32		tcp_tw_isn;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  842) 		struct {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  843) 			u16	tcp_gso_segs;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  844) 			u16	tcp_gso_size;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  845) 		};
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  846) 	};
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  847) 	__u8		tcp_flags;	/* TCP header flags. (tcp[13])	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  848) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  849) 	__u8		sacked;		/* State flags for SACK.	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  850) #define TCPCB_SACKED_ACKED	0x01	/* SKB ACK'd by a SACK block	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  851) #define TCPCB_SACKED_RETRANS	0x02	/* SKB retransmitted		*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  852) #define TCPCB_LOST		0x04	/* SKB is lost			*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  853) #define TCPCB_TAGBITS		0x07	/* All tag bits			*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  854) #define TCPCB_REPAIRED		0x10	/* SKB repaired (no skb_mstamp_ns)	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  855) #define TCPCB_EVER_RETRANS	0x80	/* Ever retransmitted frame	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  856) #define TCPCB_RETRANS		(TCPCB_SACKED_RETRANS|TCPCB_EVER_RETRANS| \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  857) 				TCPCB_REPAIRED)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  858) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  859) 	__u8		ip_dsfield;	/* IPv4 tos or IPv6 dsfield	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  860) 	__u8		txstamp_ack:1,	/* Record TX timestamp for ack? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  861) 			eor:1,		/* Is skb MSG_EOR marked? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  862) 			has_rxtstamp:1,	/* SKB has a RX timestamp	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  863) 			unused:5;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  864) 	__u32		ack_seq;	/* Sequence number ACK'd	*/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  865) 	union {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  866) 		struct {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  867) 			/* There is space for up to 24 bytes */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  868) 			__u32 in_flight:30,/* Bytes in flight at transmit */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  869) 			      is_app_limited:1, /* cwnd not fully used? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  870) 			      unused:1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  871) 			/* pkts S/ACKed so far upon tx of skb, incl retrans: */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  872) 			__u32 delivered;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  873) 			/* start of send pipeline phase */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  874) 			u64 first_tx_mstamp;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  875) 			/* when we reached the "delivered" count */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  876) 			u64 delivered_mstamp;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  877) 		} tx;   /* only used for outgoing skbs */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  878) 		union {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  879) 			struct inet_skb_parm	h4;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  880) #if IS_ENABLED(CONFIG_IPV6)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  881) 			struct inet6_skb_parm	h6;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  882) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  883) 		} header;	/* For incoming skbs */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  884) 		struct {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  885) 			__u32 flags;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  886) 			struct sock *sk_redir;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  887) 			void *data_end;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  888) 		} bpf;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  889) 	};
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  890) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  891) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  892) #define TCP_SKB_CB(__skb)	((struct tcp_skb_cb *)&((__skb)->cb[0]))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  893) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  894) static inline void bpf_compute_data_end_sk_skb(struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  895) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  896) 	TCP_SKB_CB(skb)->bpf.data_end = skb->data + skb_headlen(skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  897) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  898) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  899) static inline bool tcp_skb_bpf_ingress(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  900) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  901) 	return TCP_SKB_CB(skb)->bpf.flags & BPF_F_INGRESS;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  902) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  903) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  904) static inline struct sock *tcp_skb_bpf_redirect_fetch(struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  905) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  906) 	return TCP_SKB_CB(skb)->bpf.sk_redir;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  907) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  908) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  909) static inline void tcp_skb_bpf_redirect_clear(struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  910) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  911) 	TCP_SKB_CB(skb)->bpf.sk_redir = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  912) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  913) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  914) extern const struct inet_connection_sock_af_ops ipv4_specific;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  915) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  916) #if IS_ENABLED(CONFIG_IPV6)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  917) /* This is the variant of inet6_iif() that must be used by TCP,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  918)  * as TCP moves IP6CB into a different location in skb->cb[]
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  919)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  920) static inline int tcp_v6_iif(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  921) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  922) 	return TCP_SKB_CB(skb)->header.h6.iif;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  923) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  924) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  925) static inline int tcp_v6_iif_l3_slave(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  926) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  927) 	bool l3_slave = ipv6_l3mdev_skb(TCP_SKB_CB(skb)->header.h6.flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  928) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  929) 	return l3_slave ? skb->skb_iif : TCP_SKB_CB(skb)->header.h6.iif;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  930) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  931) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  932) /* TCP_SKB_CB reference means this can not be used from early demux */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  933) static inline int tcp_v6_sdif(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  934) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  935) #if IS_ENABLED(CONFIG_NET_L3_MASTER_DEV)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  936) 	if (skb && ipv6_l3mdev_skb(TCP_SKB_CB(skb)->header.h6.flags))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  937) 		return TCP_SKB_CB(skb)->header.h6.iif;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  938) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  939) 	return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  940) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  941) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  942) extern const struct inet_connection_sock_af_ops ipv6_specific;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  943) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  944) INDIRECT_CALLABLE_DECLARE(void tcp_v6_send_check(struct sock *sk, struct sk_buff *skb));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  945) INDIRECT_CALLABLE_DECLARE(int tcp_v6_rcv(struct sk_buff *skb));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  946) INDIRECT_CALLABLE_DECLARE(void tcp_v6_early_demux(struct sk_buff *skb));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  947) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  948) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  949) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  950) /* TCP_SKB_CB reference means this can not be used from early demux */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  951) static inline int tcp_v4_sdif(struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  952) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  953) #if IS_ENABLED(CONFIG_NET_L3_MASTER_DEV)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  954) 	if (skb && ipv4_l3mdev_skb(TCP_SKB_CB(skb)->header.h4.flags))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  955) 		return TCP_SKB_CB(skb)->header.h4.iif;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  956) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  957) 	return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  958) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  959) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  960) /* Due to TSO, an SKB can be composed of multiple actual
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  961)  * packets.  To keep these tracked properly, we use this.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  962)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  963) static inline int tcp_skb_pcount(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  964) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  965) 	return TCP_SKB_CB(skb)->tcp_gso_segs;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  966) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  967) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  968) static inline void tcp_skb_pcount_set(struct sk_buff *skb, int segs)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  969) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  970) 	TCP_SKB_CB(skb)->tcp_gso_segs = segs;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  971) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  972) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  973) static inline void tcp_skb_pcount_add(struct sk_buff *skb, int segs)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  974) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  975) 	TCP_SKB_CB(skb)->tcp_gso_segs += segs;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  976) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  977) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  978) /* This is valid iff skb is in write queue and tcp_skb_pcount() > 1. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  979) static inline int tcp_skb_mss(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  980) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  981) 	return TCP_SKB_CB(skb)->tcp_gso_size;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  982) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  983) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  984) static inline bool tcp_skb_can_collapse_to(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  985) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  986) 	return likely(!TCP_SKB_CB(skb)->eor);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  987) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  988) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  989) static inline bool tcp_skb_can_collapse(const struct sk_buff *to,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  990) 					const struct sk_buff *from)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  991) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  992) 	return likely(tcp_skb_can_collapse_to(to) &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  993) 		      mptcp_skb_can_collapse(to, from));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  994) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  995) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  996) /* Events passed to congestion control interface */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  997) enum tcp_ca_event {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  998) 	CA_EVENT_TX_START,	/* first transmit when no packets in flight */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  999) 	CA_EVENT_CWND_RESTART,	/* congestion window restart */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1000) 	CA_EVENT_COMPLETE_CWR,	/* end of congestion recovery */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1001) 	CA_EVENT_LOSS,		/* loss timeout */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1002) 	CA_EVENT_ECN_NO_CE,	/* ECT set, but not CE marked */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1003) 	CA_EVENT_ECN_IS_CE,	/* received CE marked IP packet */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1004) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1005) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1006) /* Information about inbound ACK, passed to cong_ops->in_ack_event() */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1007) enum tcp_ca_ack_event_flags {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1008) 	CA_ACK_SLOWPATH		= (1 << 0),	/* In slow path processing */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1009) 	CA_ACK_WIN_UPDATE	= (1 << 1),	/* ACK updated window */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1010) 	CA_ACK_ECE		= (1 << 2),	/* ECE bit is set on ack */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1011) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1012) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1013) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1014)  * Interface for adding new TCP congestion control handlers
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1015)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1016) #define TCP_CA_NAME_MAX	16
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1017) #define TCP_CA_MAX	128
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1018) #define TCP_CA_BUF_MAX	(TCP_CA_NAME_MAX*TCP_CA_MAX)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1019) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1020) #define TCP_CA_UNSPEC	0
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1021) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1022) /* Algorithm can be set on socket without CAP_NET_ADMIN privileges */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1023) #define TCP_CONG_NON_RESTRICTED 0x1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1024) /* Requires ECN/ECT set on all packets */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1025) #define TCP_CONG_NEEDS_ECN	0x2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1026) #define TCP_CONG_MASK	(TCP_CONG_NON_RESTRICTED | TCP_CONG_NEEDS_ECN)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1027) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1028) union tcp_cc_info;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1029) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1030) struct ack_sample {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1031) 	u32 pkts_acked;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1032) 	s32 rtt_us;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1033) 	u32 in_flight;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1034) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1035) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1036) /* A rate sample measures the number of (original/retransmitted) data
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1037)  * packets delivered "delivered" over an interval of time "interval_us".
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1038)  * The tcp_rate.c code fills in the rate sample, and congestion
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1039)  * control modules that define a cong_control function to run at the end
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1040)  * of ACK processing can optionally chose to consult this sample when
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1041)  * setting cwnd and pacing rate.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1042)  * A sample is invalid if "delivered" or "interval_us" is negative.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1043)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1044) struct rate_sample {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1045) 	u64  prior_mstamp; /* starting timestamp for interval */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1046) 	u32  prior_delivered;	/* tp->delivered at "prior_mstamp" */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1047) 	s32  delivered;		/* number of packets delivered over interval */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1048) 	long interval_us;	/* time for tp->delivered to incr "delivered" */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1049) 	u32 snd_interval_us;	/* snd interval for delivered packets */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1050) 	u32 rcv_interval_us;	/* rcv interval for delivered packets */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1051) 	long rtt_us;		/* RTT of last (S)ACKed packet (or -1) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1052) 	int  losses;		/* number of packets marked lost upon ACK */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1053) 	u32  acked_sacked;	/* number of packets newly (S)ACKed upon ACK */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1054) 	u32  prior_in_flight;	/* in flight before this ACK */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1055) 	bool is_app_limited;	/* is sample from packet with bubble in pipe? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1056) 	bool is_retrans;	/* is sample from retransmission? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1057) 	bool is_ack_delayed;	/* is this (likely) a delayed ACK? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1058) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1059) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1060) struct tcp_congestion_ops {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1061) 	struct list_head	list;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1062) 	u32 key;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1063) 	u32 flags;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1064) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1065) 	/* initialize private data (optional) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1066) 	void (*init)(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1067) 	/* cleanup private data  (optional) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1068) 	void (*release)(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1069) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1070) 	/* return slow start threshold (required) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1071) 	u32 (*ssthresh)(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1072) 	/* do new cwnd calculation (required) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1073) 	void (*cong_avoid)(struct sock *sk, u32 ack, u32 acked);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1074) 	/* call before changing ca_state (optional) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1075) 	void (*set_state)(struct sock *sk, u8 new_state);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1076) 	/* call when cwnd event occurs (optional) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1077) 	void (*cwnd_event)(struct sock *sk, enum tcp_ca_event ev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1078) 	/* call when ack arrives (optional) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1079) 	void (*in_ack_event)(struct sock *sk, u32 flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1080) 	/* new value of cwnd after loss (required) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1081) 	u32  (*undo_cwnd)(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1082) 	/* hook for packet ack accounting (optional) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1083) 	void (*pkts_acked)(struct sock *sk, const struct ack_sample *sample);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1084) 	/* override sysctl_tcp_min_tso_segs */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1085) 	u32 (*min_tso_segs)(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1086) 	/* returns the multiplier used in tcp_sndbuf_expand (optional) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1087) 	u32 (*sndbuf_expand)(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1088) 	/* call when packets are delivered to update cwnd and pacing rate,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1089) 	 * after all the ca_state processing. (optional)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1090) 	 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1091) 	void (*cong_control)(struct sock *sk, const struct rate_sample *rs);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1092) 	/* get info for inet_diag (optional) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1093) 	size_t (*get_info)(struct sock *sk, u32 ext, int *attr,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1094) 			   union tcp_cc_info *info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1095) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1096) 	char 		name[TCP_CA_NAME_MAX];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1097) 	struct module 	*owner;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1098) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1099) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1100) int tcp_register_congestion_control(struct tcp_congestion_ops *type);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1101) void tcp_unregister_congestion_control(struct tcp_congestion_ops *type);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1102) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1103) void tcp_assign_congestion_control(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1104) void tcp_init_congestion_control(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1105) void tcp_cleanup_congestion_control(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1106) int tcp_set_default_congestion_control(struct net *net, const char *name);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1107) void tcp_get_default_congestion_control(struct net *net, char *name);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1108) void tcp_get_available_congestion_control(char *buf, size_t len);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1109) void tcp_get_allowed_congestion_control(char *buf, size_t len);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1110) int tcp_set_allowed_congestion_control(char *allowed);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1111) int tcp_set_congestion_control(struct sock *sk, const char *name, bool load,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1112) 			       bool cap_net_admin);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1113) u32 tcp_slow_start(struct tcp_sock *tp, u32 acked);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1114) void tcp_cong_avoid_ai(struct tcp_sock *tp, u32 w, u32 acked);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1115) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1116) u32 tcp_reno_ssthresh(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1117) u32 tcp_reno_undo_cwnd(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1118) void tcp_reno_cong_avoid(struct sock *sk, u32 ack, u32 acked);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1119) extern struct tcp_congestion_ops tcp_reno;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1120) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1121) struct tcp_congestion_ops *tcp_ca_find(const char *name);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1122) struct tcp_congestion_ops *tcp_ca_find_key(u32 key);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1123) u32 tcp_ca_get_key_by_name(struct net *net, const char *name, bool *ecn_ca);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1124) #ifdef CONFIG_INET
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1125) char *tcp_ca_get_name_by_key(u32 key, char *buffer);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1126) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1127) static inline char *tcp_ca_get_name_by_key(u32 key, char *buffer)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1128) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1129) 	return NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1130) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1131) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1132) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1133) static inline bool tcp_ca_needs_ecn(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1134) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1135) 	const struct inet_connection_sock *icsk = inet_csk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1136) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1137) 	return icsk->icsk_ca_ops->flags & TCP_CONG_NEEDS_ECN;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1138) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1139) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1140) static inline void tcp_set_ca_state(struct sock *sk, const u8 ca_state)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1141) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1142) 	struct inet_connection_sock *icsk = inet_csk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1143) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1144) 	if (icsk->icsk_ca_ops->set_state)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1145) 		icsk->icsk_ca_ops->set_state(sk, ca_state);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1146) 	icsk->icsk_ca_state = ca_state;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1147) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1148) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1149) static inline void tcp_ca_event(struct sock *sk, const enum tcp_ca_event event)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1150) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1151) 	const struct inet_connection_sock *icsk = inet_csk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1152) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1153) 	if (icsk->icsk_ca_ops->cwnd_event)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1154) 		icsk->icsk_ca_ops->cwnd_event(sk, event);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1155) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1156) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1157) /* From tcp_rate.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1158) void tcp_rate_skb_sent(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1159) void tcp_rate_skb_delivered(struct sock *sk, struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1160) 			    struct rate_sample *rs);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1161) void tcp_rate_gen(struct sock *sk, u32 delivered, u32 lost,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1162) 		  bool is_sack_reneg, struct rate_sample *rs);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1163) void tcp_rate_check_app_limited(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1164) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1165) /* These functions determine how the current flow behaves in respect of SACK
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1166)  * handling. SACK is negotiated with the peer, and therefore it can vary
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1167)  * between different flows.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1168)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1169)  * tcp_is_sack - SACK enabled
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1170)  * tcp_is_reno - No SACK
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1171)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1172) static inline int tcp_is_sack(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1173) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1174) 	return likely(tp->rx_opt.sack_ok);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1175) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1176) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1177) static inline bool tcp_is_reno(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1178) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1179) 	return !tcp_is_sack(tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1180) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1181) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1182) static inline unsigned int tcp_left_out(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1183) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1184) 	return tp->sacked_out + tp->lost_out;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1185) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1186) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1187) /* This determines how many packets are "in the network" to the best
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1188)  * of our knowledge.  In many cases it is conservative, but where
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1189)  * detailed information is available from the receiver (via SACK
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1190)  * blocks etc.) we can make more aggressive calculations.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1191)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1192)  * Use this for decisions involving congestion control, use just
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1193)  * tp->packets_out to determine if the send queue is empty or not.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1194)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1195)  * Read this equation as:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1196)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1197)  *	"Packets sent once on transmission queue" MINUS
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1198)  *	"Packets left network, but not honestly ACKed yet" PLUS
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1199)  *	"Packets fast retransmitted"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1200)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1201) static inline unsigned int tcp_packets_in_flight(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1202) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1203) 	return tp->packets_out - tcp_left_out(tp) + tp->retrans_out;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1204) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1205) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1206) #define TCP_INFINITE_SSTHRESH	0x7fffffff
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1207) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1208) static inline bool tcp_in_slow_start(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1209) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1210) 	return tp->snd_cwnd < tp->snd_ssthresh;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1211) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1212) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1213) static inline bool tcp_in_initial_slowstart(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1214) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1215) 	return tp->snd_ssthresh >= TCP_INFINITE_SSTHRESH;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1216) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1217) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1218) static inline bool tcp_in_cwnd_reduction(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1219) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1220) 	return (TCPF_CA_CWR | TCPF_CA_Recovery) &
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1221) 	       (1 << inet_csk(sk)->icsk_ca_state);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1222) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1223) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1224) /* If cwnd > ssthresh, we may raise ssthresh to be half-way to cwnd.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1225)  * The exception is cwnd reduction phase, when cwnd is decreasing towards
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1226)  * ssthresh.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1227)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1228) static inline __u32 tcp_current_ssthresh(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1229) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1230) 	const struct tcp_sock *tp = tcp_sk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1231) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1232) 	if (tcp_in_cwnd_reduction(sk))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1233) 		return tp->snd_ssthresh;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1234) 	else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1235) 		return max(tp->snd_ssthresh,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1236) 			   ((tp->snd_cwnd >> 1) +
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1237) 			    (tp->snd_cwnd >> 2)));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1238) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1239) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1240) /* Use define here intentionally to get WARN_ON location shown at the caller */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1241) #define tcp_verify_left_out(tp)	WARN_ON(tcp_left_out(tp) > tp->packets_out)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1242) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1243) void tcp_enter_cwr(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1244) __u32 tcp_init_cwnd(const struct tcp_sock *tp, const struct dst_entry *dst);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1245) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1246) /* The maximum number of MSS of available cwnd for which TSO defers
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1247)  * sending if not using sysctl_tcp_tso_win_divisor.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1248)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1249) static inline __u32 tcp_max_tso_deferred_mss(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1250) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1251) 	return 3;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1252) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1253) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1254) /* Returns end sequence number of the receiver's advertised window */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1255) static inline u32 tcp_wnd_end(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1256) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1257) 	return tp->snd_una + tp->snd_wnd;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1258) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1259) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1260) /* We follow the spirit of RFC2861 to validate cwnd but implement a more
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1261)  * flexible approach. The RFC suggests cwnd should not be raised unless
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1262)  * it was fully used previously. And that's exactly what we do in
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1263)  * congestion avoidance mode. But in slow start we allow cwnd to grow
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1264)  * as long as the application has used half the cwnd.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1265)  * Example :
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1266)  *    cwnd is 10 (IW10), but application sends 9 frames.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1267)  *    We allow cwnd to reach 18 when all frames are ACKed.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1268)  * This check is safe because it's as aggressive as slow start which already
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1269)  * risks 100% overshoot. The advantage is that we discourage application to
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1270)  * either send more filler packets or data to artificially blow up the cwnd
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1271)  * usage, and allow application-limited process to probe bw more aggressively.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1272)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1273) static inline bool tcp_is_cwnd_limited(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1274) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1275) 	const struct tcp_sock *tp = tcp_sk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1276) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1277) 	/* If in slow start, ensure cwnd grows to twice what was ACKed. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1278) 	if (tcp_in_slow_start(tp))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1279) 		return tp->snd_cwnd < 2 * tp->max_packets_out;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1280) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1281) 	return tp->is_cwnd_limited;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1282) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1283) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1284) /* BBR congestion control needs pacing.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1285)  * Same remark for SO_MAX_PACING_RATE.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1286)  * sch_fq packet scheduler is efficiently handling pacing,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1287)  * but is not always installed/used.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1288)  * Return true if TCP stack should pace packets itself.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1289)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1290) static inline bool tcp_needs_internal_pacing(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1291) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1292) 	return smp_load_acquire(&sk->sk_pacing_status) == SK_PACING_NEEDED;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1293) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1294) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1295) /* Estimates in how many jiffies next packet for this flow can be sent.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1296)  * Scheduling a retransmit timer too early would be silly.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1297)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1298) static inline unsigned long tcp_pacing_delay(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1299) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1300) 	s64 delay = tcp_sk(sk)->tcp_wstamp_ns - tcp_sk(sk)->tcp_clock_cache;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1301) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1302) 	return delay > 0 ? nsecs_to_jiffies(delay) : 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1303) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1304) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1305) static inline void tcp_reset_xmit_timer(struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1306) 					const int what,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1307) 					unsigned long when,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1308) 					const unsigned long max_when)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1309) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1310) 	inet_csk_reset_xmit_timer(sk, what, when + tcp_pacing_delay(sk),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1311) 				  max_when);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1312) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1313) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1314) /* Something is really bad, we could not queue an additional packet,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1315)  * because qdisc is full or receiver sent a 0 window, or we are paced.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1316)  * We do not want to add fuel to the fire, or abort too early,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1317)  * so make sure the timer we arm now is at least 200ms in the future,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1318)  * regardless of current icsk_rto value (as it could be ~2ms)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1319)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1320) static inline unsigned long tcp_probe0_base(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1321) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1322) 	return max_t(unsigned long, inet_csk(sk)->icsk_rto, TCP_RTO_MIN);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1323) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1324) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1325) /* Variant of inet_csk_rto_backoff() used for zero window probes */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1326) static inline unsigned long tcp_probe0_when(const struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1327) 					    unsigned long max_when)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1328) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1329) 	u64 when = (u64)tcp_probe0_base(sk) << inet_csk(sk)->icsk_backoff;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1330) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1331) 	return (unsigned long)min_t(u64, when, max_when);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1332) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1333) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1334) static inline void tcp_check_probe_timer(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1335) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1336) 	if (!tcp_sk(sk)->packets_out && !inet_csk(sk)->icsk_pending)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1337) 		tcp_reset_xmit_timer(sk, ICSK_TIME_PROBE0,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1338) 				     tcp_probe0_base(sk), TCP_RTO_MAX);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1339) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1340) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1341) static inline void tcp_init_wl(struct tcp_sock *tp, u32 seq)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1342) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1343) 	tp->snd_wl1 = seq;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1344) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1345) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1346) static inline void tcp_update_wl(struct tcp_sock *tp, u32 seq)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1347) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1348) 	tp->snd_wl1 = seq;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1349) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1350) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1351) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1352)  * Calculate(/check) TCP checksum
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1353)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1354) static inline __sum16 tcp_v4_check(int len, __be32 saddr,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1355) 				   __be32 daddr, __wsum base)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1356) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1357) 	return csum_tcpudp_magic(saddr, daddr, len, IPPROTO_TCP, base);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1358) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1359) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1360) static inline bool tcp_checksum_complete(struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1361) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1362) 	return !skb_csum_unnecessary(skb) &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1363) 		__skb_checksum_complete(skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1364) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1365) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1366) bool tcp_add_backlog(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1367) int tcp_filter(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1368) void tcp_set_state(struct sock *sk, int state);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1369) void tcp_done(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1370) int tcp_abort(struct sock *sk, int err);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1371) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1372) static inline void tcp_sack_reset(struct tcp_options_received *rx_opt)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1373) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1374) 	rx_opt->dsack = 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1375) 	rx_opt->num_sacks = 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1376) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1377) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1378) void tcp_cwnd_restart(struct sock *sk, s32 delta);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1379) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1380) static inline void tcp_slow_start_after_idle_check(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1381) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1382) 	const struct tcp_congestion_ops *ca_ops = inet_csk(sk)->icsk_ca_ops;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1383) 	struct tcp_sock *tp = tcp_sk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1384) 	s32 delta;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1385) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1386) 	if (!sock_net(sk)->ipv4.sysctl_tcp_slow_start_after_idle || tp->packets_out ||
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1387) 	    ca_ops->cong_control)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1388) 		return;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1389) 	delta = tcp_jiffies32 - tp->lsndtime;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1390) 	if (delta > inet_csk(sk)->icsk_rto)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1391) 		tcp_cwnd_restart(sk, delta);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1392) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1393) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1394) /* Determine a window scaling and initial window to offer. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1395) void tcp_select_initial_window(const struct sock *sk, int __space,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1396) 			       __u32 mss, __u32 *rcv_wnd,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1397) 			       __u32 *window_clamp, int wscale_ok,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1398) 			       __u8 *rcv_wscale, __u32 init_rcv_wnd);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1399) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1400) static inline int tcp_win_from_space(const struct sock *sk, int space)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1401) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1402) 	int tcp_adv_win_scale = sock_net(sk)->ipv4.sysctl_tcp_adv_win_scale;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1403) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1404) 	return tcp_adv_win_scale <= 0 ?
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1405) 		(space>>(-tcp_adv_win_scale)) :
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1406) 		space - (space>>tcp_adv_win_scale);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1407) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1408) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1409) /* Note: caller must be prepared to deal with negative returns */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1410) static inline int tcp_space(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1411) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1412) 	return tcp_win_from_space(sk, READ_ONCE(sk->sk_rcvbuf) -
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1413) 				  READ_ONCE(sk->sk_backlog.len) -
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1414) 				  atomic_read(&sk->sk_rmem_alloc));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1415) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1416) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1417) static inline int tcp_full_space(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1418) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1419) 	return tcp_win_from_space(sk, READ_ONCE(sk->sk_rcvbuf));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1420) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1421) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1422) void tcp_cleanup_rbuf(struct sock *sk, int copied);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1423) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1424) /* We provision sk_rcvbuf around 200% of sk_rcvlowat.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1425)  * If 87.5 % (7/8) of the space has been consumed, we want to override
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1426)  * SO_RCVLOWAT constraint, since we are receiving skbs with too small
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1427)  * len/truesize ratio.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1428)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1429) static inline bool tcp_rmem_pressure(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1430) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1431) 	int rcvbuf, threshold;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1432) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1433) 	if (tcp_under_memory_pressure(sk))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1434) 		return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1435) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1436) 	rcvbuf = READ_ONCE(sk->sk_rcvbuf);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1437) 	threshold = rcvbuf - (rcvbuf >> 3);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1438) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1439) 	return atomic_read(&sk->sk_rmem_alloc) > threshold;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1440) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1441) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1442) extern void tcp_openreq_init_rwin(struct request_sock *req,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1443) 				  const struct sock *sk_listener,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1444) 				  const struct dst_entry *dst);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1445) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1446) void tcp_enter_memory_pressure(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1447) void tcp_leave_memory_pressure(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1448) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1449) static inline int keepalive_intvl_when(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1450) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1451) 	struct net *net = sock_net((struct sock *)tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1452) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1453) 	return tp->keepalive_intvl ? : net->ipv4.sysctl_tcp_keepalive_intvl;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1454) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1455) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1456) static inline int keepalive_time_when(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1457) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1458) 	struct net *net = sock_net((struct sock *)tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1459) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1460) 	return tp->keepalive_time ? : net->ipv4.sysctl_tcp_keepalive_time;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1461) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1462) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1463) static inline int keepalive_probes(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1464) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1465) 	struct net *net = sock_net((struct sock *)tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1466) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1467) 	return tp->keepalive_probes ? : net->ipv4.sysctl_tcp_keepalive_probes;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1468) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1469) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1470) static inline u32 keepalive_time_elapsed(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1471) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1472) 	const struct inet_connection_sock *icsk = &tp->inet_conn;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1473) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1474) 	return min_t(u32, tcp_jiffies32 - icsk->icsk_ack.lrcvtime,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1475) 			  tcp_jiffies32 - tp->rcv_tstamp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1476) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1477) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1478) static inline int tcp_fin_time(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1479) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1480) 	int fin_timeout = tcp_sk(sk)->linger2 ? : sock_net(sk)->ipv4.sysctl_tcp_fin_timeout;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1481) 	const int rto = inet_csk(sk)->icsk_rto;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1482) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1483) 	if (fin_timeout < (rto << 2) - (rto >> 1))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1484) 		fin_timeout = (rto << 2) - (rto >> 1);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1485) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1486) 	return fin_timeout;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1487) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1488) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1489) static inline bool tcp_paws_check(const struct tcp_options_received *rx_opt,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1490) 				  int paws_win)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1491) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1492) 	if ((s32)(rx_opt->ts_recent - rx_opt->rcv_tsval) <= paws_win)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1493) 		return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1494) 	if (unlikely(!time_before32(ktime_get_seconds(),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1495) 				    rx_opt->ts_recent_stamp + TCP_PAWS_24DAYS)))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1496) 		return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1497) 	/*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1498) 	 * Some OSes send SYN and SYNACK messages with tsval=0 tsecr=0,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1499) 	 * then following tcp messages have valid values. Ignore 0 value,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1500) 	 * or else 'negative' tsval might forbid us to accept their packets.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1501) 	 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1502) 	if (!rx_opt->ts_recent)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1503) 		return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1504) 	return false;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1505) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1506) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1507) static inline bool tcp_paws_reject(const struct tcp_options_received *rx_opt,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1508) 				   int rst)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1509) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1510) 	if (tcp_paws_check(rx_opt, 0))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1511) 		return false;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1512) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1513) 	/* RST segments are not recommended to carry timestamp,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1514) 	   and, if they do, it is recommended to ignore PAWS because
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1515) 	   "their cleanup function should take precedence over timestamps."
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1516) 	   Certainly, it is mistake. It is necessary to understand the reasons
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1517) 	   of this constraint to relax it: if peer reboots, clock may go
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1518) 	   out-of-sync and half-open connections will not be reset.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1519) 	   Actually, the problem would be not existing if all
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1520) 	   the implementations followed draft about maintaining clock
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1521) 	   via reboots. Linux-2.2 DOES NOT!
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1522) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1523) 	   However, we can relax time bounds for RST segments to MSL.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1524) 	 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1525) 	if (rst && !time_before32(ktime_get_seconds(),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1526) 				  rx_opt->ts_recent_stamp + TCP_PAWS_MSL))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1527) 		return false;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1528) 	return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1529) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1530) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1531) bool tcp_oow_rate_limited(struct net *net, const struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1532) 			  int mib_idx, u32 *last_oow_ack_time);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1533) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1534) static inline void tcp_mib_init(struct net *net)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1535) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1536) 	/* See RFC 2012 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1537) 	TCP_ADD_STATS(net, TCP_MIB_RTOALGORITHM, 1);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1538) 	TCP_ADD_STATS(net, TCP_MIB_RTOMIN, TCP_RTO_MIN*1000/HZ);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1539) 	TCP_ADD_STATS(net, TCP_MIB_RTOMAX, TCP_RTO_MAX*1000/HZ);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1540) 	TCP_ADD_STATS(net, TCP_MIB_MAXCONN, -1);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1541) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1542) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1543) /* from STCP */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1544) static inline void tcp_clear_retrans_hints_partial(struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1545) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1546) 	tp->lost_skb_hint = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1547) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1548) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1549) static inline void tcp_clear_all_retrans_hints(struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1550) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1551) 	tcp_clear_retrans_hints_partial(tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1552) 	tp->retransmit_skb_hint = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1553) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1554) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1555) union tcp_md5_addr {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1556) 	struct in_addr  a4;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1557) #if IS_ENABLED(CONFIG_IPV6)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1558) 	struct in6_addr	a6;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1559) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1560) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1561) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1562) /* - key database */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1563) struct tcp_md5sig_key {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1564) 	struct hlist_node	node;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1565) 	u8			keylen;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1566) 	u8			family; /* AF_INET or AF_INET6 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1567) 	u8			prefixlen;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1568) 	union tcp_md5_addr	addr;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1569) 	int			l3index; /* set if key added with L3 scope */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1570) 	u8			key[TCP_MD5SIG_MAXKEYLEN];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1571) 	struct rcu_head		rcu;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1572) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1573) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1574) /* - sock block */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1575) struct tcp_md5sig_info {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1576) 	struct hlist_head	head;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1577) 	struct rcu_head		rcu;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1578) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1579) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1580) /* - pseudo header */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1581) struct tcp4_pseudohdr {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1582) 	__be32		saddr;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1583) 	__be32		daddr;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1584) 	__u8		pad;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1585) 	__u8		protocol;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1586) 	__be16		len;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1587) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1588) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1589) struct tcp6_pseudohdr {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1590) 	struct in6_addr	saddr;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1591) 	struct in6_addr daddr;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1592) 	__be32		len;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1593) 	__be32		protocol;	/* including padding */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1594) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1595) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1596) union tcp_md5sum_block {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1597) 	struct tcp4_pseudohdr ip4;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1598) #if IS_ENABLED(CONFIG_IPV6)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1599) 	struct tcp6_pseudohdr ip6;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1600) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1601) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1602) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1603) /* - pool: digest algorithm, hash description and scratch buffer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1604) struct tcp_md5sig_pool {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1605) 	struct ahash_request	*md5_req;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1606) 	void			*scratch;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1607) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1608) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1609) /* - functions */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1610) int tcp_v4_md5_hash_skb(char *md5_hash, const struct tcp_md5sig_key *key,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1611) 			const struct sock *sk, const struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1612) int tcp_md5_do_add(struct sock *sk, const union tcp_md5_addr *addr,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1613) 		   int family, u8 prefixlen, int l3index,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1614) 		   const u8 *newkey, u8 newkeylen, gfp_t gfp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1615) int tcp_md5_do_del(struct sock *sk, const union tcp_md5_addr *addr,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1616) 		   int family, u8 prefixlen, int l3index);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1617) struct tcp_md5sig_key *tcp_v4_md5_lookup(const struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1618) 					 const struct sock *addr_sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1619) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1620) #ifdef CONFIG_TCP_MD5SIG
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1621) #include <linux/jump_label.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1622) extern struct static_key_false tcp_md5_needed;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1623) struct tcp_md5sig_key *__tcp_md5_do_lookup(const struct sock *sk, int l3index,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1624) 					   const union tcp_md5_addr *addr,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1625) 					   int family);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1626) static inline struct tcp_md5sig_key *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1627) tcp_md5_do_lookup(const struct sock *sk, int l3index,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1628) 		  const union tcp_md5_addr *addr, int family)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1629) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1630) 	if (!static_branch_unlikely(&tcp_md5_needed))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1631) 		return NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1632) 	return __tcp_md5_do_lookup(sk, l3index, addr, family);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1633) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1634) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1635) #define tcp_twsk_md5_key(twsk)	((twsk)->tw_md5_key)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1636) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1637) static inline struct tcp_md5sig_key *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1638) tcp_md5_do_lookup(const struct sock *sk, int l3index,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1639) 		  const union tcp_md5_addr *addr, int family)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1640) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1641) 	return NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1642) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1643) #define tcp_twsk_md5_key(twsk)	NULL
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1644) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1645) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1646) bool tcp_alloc_md5sig_pool(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1647) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1648) struct tcp_md5sig_pool *tcp_get_md5sig_pool(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1649) static inline void tcp_put_md5sig_pool(void)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1650) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1651) 	local_bh_enable();
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1652) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1653) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1654) int tcp_md5_hash_skb_data(struct tcp_md5sig_pool *, const struct sk_buff *,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1655) 			  unsigned int header_len);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1656) int tcp_md5_hash_key(struct tcp_md5sig_pool *hp,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1657) 		     const struct tcp_md5sig_key *key);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1658) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1659) /* From tcp_fastopen.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1660) void tcp_fastopen_cache_get(struct sock *sk, u16 *mss,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1661) 			    struct tcp_fastopen_cookie *cookie);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1662) void tcp_fastopen_cache_set(struct sock *sk, u16 mss,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1663) 			    struct tcp_fastopen_cookie *cookie, bool syn_lost,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1664) 			    u16 try_exp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1665) struct tcp_fastopen_request {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1666) 	/* Fast Open cookie. Size 0 means a cookie request */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1667) 	struct tcp_fastopen_cookie	cookie;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1668) 	struct msghdr			*data;  /* data in MSG_FASTOPEN */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1669) 	size_t				size;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1670) 	int				copied;	/* queued in tcp_connect() */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1671) 	struct ubuf_info		*uarg;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1672) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1673) void tcp_free_fastopen_req(struct tcp_sock *tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1674) void tcp_fastopen_destroy_cipher(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1675) void tcp_fastopen_ctx_destroy(struct net *net);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1676) int tcp_fastopen_reset_cipher(struct net *net, struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1677) 			      void *primary_key, void *backup_key);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1678) int tcp_fastopen_get_cipher(struct net *net, struct inet_connection_sock *icsk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1679) 			    u64 *key);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1680) void tcp_fastopen_add_skb(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1681) struct sock *tcp_try_fastopen(struct sock *sk, struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1682) 			      struct request_sock *req,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1683) 			      struct tcp_fastopen_cookie *foc,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1684) 			      const struct dst_entry *dst);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1685) void tcp_fastopen_init_key_once(struct net *net);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1686) bool tcp_fastopen_cookie_check(struct sock *sk, u16 *mss,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1687) 			     struct tcp_fastopen_cookie *cookie);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1688) bool tcp_fastopen_defer_connect(struct sock *sk, int *err);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1689) #define TCP_FASTOPEN_KEY_LENGTH sizeof(siphash_key_t)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1690) #define TCP_FASTOPEN_KEY_MAX 2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1691) #define TCP_FASTOPEN_KEY_BUF_LENGTH \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1692) 	(TCP_FASTOPEN_KEY_LENGTH * TCP_FASTOPEN_KEY_MAX)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1693) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1694) /* Fastopen key context */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1695) struct tcp_fastopen_context {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1696) 	siphash_key_t	key[TCP_FASTOPEN_KEY_MAX];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1697) 	int		num;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1698) 	struct rcu_head	rcu;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1699) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1700) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1701) extern unsigned int sysctl_tcp_fastopen_blackhole_timeout;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1702) void tcp_fastopen_active_disable(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1703) bool tcp_fastopen_active_should_disable(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1704) void tcp_fastopen_active_disable_ofo_check(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1705) void tcp_fastopen_active_detect_blackhole(struct sock *sk, bool expired);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1706) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1707) /* Caller needs to wrap with rcu_read_(un)lock() */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1708) static inline
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1709) struct tcp_fastopen_context *tcp_fastopen_get_ctx(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1710) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1711) 	struct tcp_fastopen_context *ctx;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1712) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1713) 	ctx = rcu_dereference(inet_csk(sk)->icsk_accept_queue.fastopenq.ctx);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1714) 	if (!ctx)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1715) 		ctx = rcu_dereference(sock_net(sk)->ipv4.tcp_fastopen_ctx);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1716) 	return ctx;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1717) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1718) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1719) static inline
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1720) bool tcp_fastopen_cookie_match(const struct tcp_fastopen_cookie *foc,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1721) 			       const struct tcp_fastopen_cookie *orig)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1722) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1723) 	if (orig->len == TCP_FASTOPEN_COOKIE_SIZE &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1724) 	    orig->len == foc->len &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1725) 	    !memcmp(orig->val, foc->val, foc->len))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1726) 		return true;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1727) 	return false;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1728) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1729) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1730) static inline
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1731) int tcp_fastopen_context_len(const struct tcp_fastopen_context *ctx)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1732) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1733) 	return ctx->num;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1734) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1735) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1736) /* Latencies incurred by various limits for a sender. They are
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1737)  * chronograph-like stats that are mutually exclusive.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1738)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1739) enum tcp_chrono {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1740) 	TCP_CHRONO_UNSPEC,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1741) 	TCP_CHRONO_BUSY, /* Actively sending data (non-empty write queue) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1742) 	TCP_CHRONO_RWND_LIMITED, /* Stalled by insufficient receive window */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1743) 	TCP_CHRONO_SNDBUF_LIMITED, /* Stalled by insufficient send buffer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1744) 	__TCP_CHRONO_MAX,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1745) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1746) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1747) void tcp_chrono_start(struct sock *sk, const enum tcp_chrono type);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1748) void tcp_chrono_stop(struct sock *sk, const enum tcp_chrono type);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1749) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1750) /* This helper is needed, because skb->tcp_tsorted_anchor uses
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1751)  * the same memory storage than skb->destructor/_skb_refdst
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1752)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1753) static inline void tcp_skb_tsorted_anchor_cleanup(struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1754) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1755) 	skb->destructor = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1756) 	skb->_skb_refdst = 0UL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1757) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1758) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1759) #define tcp_skb_tsorted_save(skb) {		\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1760) 	unsigned long _save = skb->_skb_refdst;	\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1761) 	skb->_skb_refdst = 0UL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1762) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1763) #define tcp_skb_tsorted_restore(skb)		\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1764) 	skb->_skb_refdst = _save;		\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1765) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1766) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1767) void tcp_write_queue_purge(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1768) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1769) static inline struct sk_buff *tcp_rtx_queue_head(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1770) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1771) 	return skb_rb_first(&sk->tcp_rtx_queue);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1772) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1773) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1774) static inline struct sk_buff *tcp_rtx_queue_tail(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1775) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1776) 	return skb_rb_last(&sk->tcp_rtx_queue);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1777) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1778) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1779) static inline struct sk_buff *tcp_write_queue_head(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1780) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1781) 	return skb_peek(&sk->sk_write_queue);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1782) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1783) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1784) static inline struct sk_buff *tcp_write_queue_tail(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1785) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1786) 	return skb_peek_tail(&sk->sk_write_queue);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1787) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1788) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1789) #define tcp_for_write_queue_from_safe(skb, tmp, sk)			\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1790) 	skb_queue_walk_from_safe(&(sk)->sk_write_queue, skb, tmp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1791) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1792) static inline struct sk_buff *tcp_send_head(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1793) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1794) 	return skb_peek(&sk->sk_write_queue);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1795) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1796) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1797) static inline bool tcp_skb_is_last(const struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1798) 				   const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1799) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1800) 	return skb_queue_is_last(&sk->sk_write_queue, skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1801) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1802) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1803) /**
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1804)  * tcp_write_queue_empty - test if any payload (or FIN) is available in write queue
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1805)  * @sk: socket
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1806)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1807)  * Since the write queue can have a temporary empty skb in it,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1808)  * we must not use "return skb_queue_empty(&sk->sk_write_queue)"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1809)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1810) static inline bool tcp_write_queue_empty(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1811) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1812) 	const struct tcp_sock *tp = tcp_sk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1813) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1814) 	return tp->write_seq == tp->snd_nxt;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1815) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1816) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1817) static inline bool tcp_rtx_queue_empty(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1818) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1819) 	return RB_EMPTY_ROOT(&sk->tcp_rtx_queue);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1820) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1821) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1822) static inline bool tcp_rtx_and_write_queues_empty(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1823) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1824) 	return tcp_rtx_queue_empty(sk) && tcp_write_queue_empty(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1825) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1826) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1827) static inline void tcp_add_write_queue_tail(struct sock *sk, struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1828) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1829) 	__skb_queue_tail(&sk->sk_write_queue, skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1830) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1831) 	/* Queue it, remembering where we must start sending. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1832) 	if (sk->sk_write_queue.next == skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1833) 		tcp_chrono_start(sk, TCP_CHRONO_BUSY);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1834) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1835) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1836) /* Insert new before skb on the write queue of sk.  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1837) static inline void tcp_insert_write_queue_before(struct sk_buff *new,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1838) 						  struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1839) 						  struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1840) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1841) 	__skb_queue_before(&sk->sk_write_queue, skb, new);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1842) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1843) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1844) static inline void tcp_unlink_write_queue(struct sk_buff *skb, struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1845) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1846) 	tcp_skb_tsorted_anchor_cleanup(skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1847) 	__skb_unlink(skb, &sk->sk_write_queue);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1848) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1849) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1850) void tcp_rbtree_insert(struct rb_root *root, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1851) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1852) static inline void tcp_rtx_queue_unlink(struct sk_buff *skb, struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1853) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1854) 	tcp_skb_tsorted_anchor_cleanup(skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1855) 	rb_erase(&skb->rbnode, &sk->tcp_rtx_queue);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1856) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1857) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1858) static inline void tcp_rtx_queue_unlink_and_free(struct sk_buff *skb, struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1859) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1860) 	list_del(&skb->tcp_tsorted_anchor);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1861) 	tcp_rtx_queue_unlink(skb, sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1862) 	sk_wmem_free_skb(sk, skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1863) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1864) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1865) static inline void tcp_push_pending_frames(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1866) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1867) 	if (tcp_send_head(sk)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1868) 		struct tcp_sock *tp = tcp_sk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1869) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1870) 		__tcp_push_pending_frames(sk, tcp_current_mss(sk), tp->nonagle);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1871) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1872) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1873) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1874) /* Start sequence of the skb just after the highest skb with SACKed
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1875)  * bit, valid only if sacked_out > 0 or when the caller has ensured
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1876)  * validity by itself.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1877)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1878) static inline u32 tcp_highest_sack_seq(struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1879) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1880) 	if (!tp->sacked_out)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1881) 		return tp->snd_una;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1882) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1883) 	if (tp->highest_sack == NULL)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1884) 		return tp->snd_nxt;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1885) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1886) 	return TCP_SKB_CB(tp->highest_sack)->seq;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1887) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1888) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1889) static inline void tcp_advance_highest_sack(struct sock *sk, struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1890) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1891) 	tcp_sk(sk)->highest_sack = skb_rb_next(skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1892) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1893) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1894) static inline struct sk_buff *tcp_highest_sack(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1895) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1896) 	return tcp_sk(sk)->highest_sack;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1897) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1898) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1899) static inline void tcp_highest_sack_reset(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1900) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1901) 	tcp_sk(sk)->highest_sack = tcp_rtx_queue_head(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1902) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1903) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1904) /* Called when old skb is about to be deleted and replaced by new skb */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1905) static inline void tcp_highest_sack_replace(struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1906) 					    struct sk_buff *old,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1907) 					    struct sk_buff *new)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1908) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1909) 	if (old == tcp_highest_sack(sk))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1910) 		tcp_sk(sk)->highest_sack = new;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1911) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1912) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1913) /* This helper checks if socket has IP_TRANSPARENT set */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1914) static inline bool inet_sk_transparent(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1915) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1916) 	switch (sk->sk_state) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1917) 	case TCP_TIME_WAIT:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1918) 		return inet_twsk(sk)->tw_transparent;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1919) 	case TCP_NEW_SYN_RECV:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1920) 		return inet_rsk(inet_reqsk(sk))->no_srccheck;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1921) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1922) 	return inet_sk(sk)->transparent;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1923) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1924) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1925) /* Determines whether this is a thin stream (which may suffer from
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1926)  * increased latency). Used to trigger latency-reducing mechanisms.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1927)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1928) static inline bool tcp_stream_is_thin(struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1929) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1930) 	return tp->packets_out < 4 && !tcp_in_initial_slowstart(tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1931) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1932) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1933) /* /proc */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1934) enum tcp_seq_states {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1935) 	TCP_SEQ_STATE_LISTENING,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1936) 	TCP_SEQ_STATE_ESTABLISHED,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1937) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1938) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1939) void *tcp_seq_start(struct seq_file *seq, loff_t *pos);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1940) void *tcp_seq_next(struct seq_file *seq, void *v, loff_t *pos);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1941) void tcp_seq_stop(struct seq_file *seq, void *v);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1942) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1943) struct tcp_seq_afinfo {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1944) 	sa_family_t			family;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1945) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1946) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1947) struct tcp_iter_state {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1948) 	struct seq_net_private	p;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1949) 	enum tcp_seq_states	state;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1950) 	struct sock		*syn_wait_sk;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1951) 	struct tcp_seq_afinfo	*bpf_seq_afinfo;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1952) 	int			bucket, offset, sbucket, num;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1953) 	loff_t			last_pos;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1954) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1955) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1956) extern struct request_sock_ops tcp_request_sock_ops;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1957) extern struct request_sock_ops tcp6_request_sock_ops;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1958) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1959) void tcp_v4_destroy_sock(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1960) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1961) struct sk_buff *tcp_gso_segment(struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1962) 				netdev_features_t features);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1963) struct sk_buff *tcp_gro_receive(struct list_head *head, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1964) INDIRECT_CALLABLE_DECLARE(int tcp4_gro_complete(struct sk_buff *skb, int thoff));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1965) INDIRECT_CALLABLE_DECLARE(struct sk_buff *tcp4_gro_receive(struct list_head *head, struct sk_buff *skb));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1966) INDIRECT_CALLABLE_DECLARE(int tcp6_gro_complete(struct sk_buff *skb, int thoff));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1967) INDIRECT_CALLABLE_DECLARE(struct sk_buff *tcp6_gro_receive(struct list_head *head, struct sk_buff *skb));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1968) int tcp_gro_complete(struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1969) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1970) void __tcp_v4_send_check(struct sk_buff *skb, __be32 saddr, __be32 daddr);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1971) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1972) static inline u32 tcp_notsent_lowat(const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1973) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1974) 	struct net *net = sock_net((struct sock *)tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1975) 	return tp->notsent_lowat ?: net->ipv4.sysctl_tcp_notsent_lowat;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1976) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1977) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1978) /* @wake is one when sk_stream_write_space() calls us.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1979)  * This sends EPOLLOUT only if notsent_bytes is half the limit.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1980)  * This mimics the strategy used in sock_def_write_space().
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1981)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1982) static inline bool tcp_stream_memory_free(const struct sock *sk, int wake)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1983) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1984) 	const struct tcp_sock *tp = tcp_sk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1985) 	u32 notsent_bytes = READ_ONCE(tp->write_seq) -
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1986) 			    READ_ONCE(tp->snd_nxt);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1987) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1988) 	return (notsent_bytes << wake) < tcp_notsent_lowat(tp);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1989) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1990) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1991) #ifdef CONFIG_PROC_FS
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1992) int tcp4_proc_init(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1993) void tcp4_proc_exit(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1994) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1995) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1996) int tcp_rtx_synack(const struct sock *sk, struct request_sock *req);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1997) int tcp_conn_request(struct request_sock_ops *rsk_ops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1998) 		     const struct tcp_request_sock_ops *af_ops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1999) 		     struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2000) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2001) /* TCP af-specific functions */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2002) struct tcp_sock_af_ops {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2003) #ifdef CONFIG_TCP_MD5SIG
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2004) 	struct tcp_md5sig_key	*(*md5_lookup) (const struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2005) 						const struct sock *addr_sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2006) 	int		(*calc_md5_hash)(char *location,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2007) 					 const struct tcp_md5sig_key *md5,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2008) 					 const struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2009) 					 const struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2010) 	int		(*md5_parse)(struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2011) 				     int optname,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2012) 				     sockptr_t optval,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2013) 				     int optlen);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2014) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2015) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2016) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2017) struct tcp_request_sock_ops {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2018) 	u16 mss_clamp;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2019) #ifdef CONFIG_TCP_MD5SIG
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2020) 	struct tcp_md5sig_key *(*req_md5_lookup)(const struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2021) 						 const struct sock *addr_sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2022) 	int		(*calc_md5_hash) (char *location,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2023) 					  const struct tcp_md5sig_key *md5,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2024) 					  const struct sock *sk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2025) 					  const struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2026) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2027) 	void (*init_req)(struct request_sock *req,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2028) 			 const struct sock *sk_listener,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2029) 			 struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2030) #ifdef CONFIG_SYN_COOKIES
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2031) 	__u32 (*cookie_init_seq)(const struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2032) 				 __u16 *mss);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2033) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2034) 	struct dst_entry *(*route_req)(const struct sock *sk, struct flowi *fl,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2035) 				       const struct request_sock *req);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2036) 	u32 (*init_seq)(const struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2037) 	u32 (*init_ts_off)(const struct net *net, const struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2038) 	int (*send_synack)(const struct sock *sk, struct dst_entry *dst,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2039) 			   struct flowi *fl, struct request_sock *req,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2040) 			   struct tcp_fastopen_cookie *foc,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2041) 			   enum tcp_synack_type synack_type,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2042) 			   struct sk_buff *syn_skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2043) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2044) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2045) extern const struct tcp_request_sock_ops tcp_request_sock_ipv4_ops;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2046) #if IS_ENABLED(CONFIG_IPV6)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2047) extern const struct tcp_request_sock_ops tcp_request_sock_ipv6_ops;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2048) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2049) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2050) #ifdef CONFIG_SYN_COOKIES
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2051) static inline __u32 cookie_init_sequence(const struct tcp_request_sock_ops *ops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2052) 					 const struct sock *sk, struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2053) 					 __u16 *mss)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2054) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2055) 	tcp_synq_overflow(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2056) 	__NET_INC_STATS(sock_net(sk), LINUX_MIB_SYNCOOKIESSENT);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2057) 	return ops->cookie_init_seq(skb, mss);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2058) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2059) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2060) static inline __u32 cookie_init_sequence(const struct tcp_request_sock_ops *ops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2061) 					 const struct sock *sk, struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2062) 					 __u16 *mss)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2063) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2064) 	return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2065) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2066) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2067) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2068) int tcpv4_offload_init(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2069) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2070) void tcp_v4_init(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2071) void tcp_init(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2072) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2073) /* tcp_recovery.c */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2074) void tcp_mark_skb_lost(struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2075) void tcp_newreno_mark_lost(struct sock *sk, bool snd_una_advanced);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2076) extern s32 tcp_rack_skb_timeout(struct tcp_sock *tp, struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2077) 				u32 reo_wnd);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2078) extern bool tcp_rack_mark_lost(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2079) extern void tcp_rack_advance(struct tcp_sock *tp, u8 sacked, u32 end_seq,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2080) 			     u64 xmit_time);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2081) extern void tcp_rack_reo_timeout(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2082) extern void tcp_rack_update_reo_wnd(struct sock *sk, struct rate_sample *rs);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2083) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2084) /* At how many usecs into the future should the RTO fire? */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2085) static inline s64 tcp_rto_delta_us(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2086) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2087) 	const struct sk_buff *skb = tcp_rtx_queue_head(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2088) 	u32 rto = inet_csk(sk)->icsk_rto;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2089) 	u64 rto_time_stamp_us = tcp_skb_timestamp_us(skb) + jiffies_to_usecs(rto);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2090) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2091) 	return rto_time_stamp_us - tcp_sk(sk)->tcp_mstamp;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2092) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2093) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2094) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2095)  * Save and compile IPv4 options, return a pointer to it
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2096)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2097) static inline struct ip_options_rcu *tcp_v4_save_options(struct net *net,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2098) 							 struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2099) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2100) 	const struct ip_options *opt = &TCP_SKB_CB(skb)->header.h4.opt;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2101) 	struct ip_options_rcu *dopt = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2102) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2103) 	if (opt->optlen) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2104) 		int opt_size = sizeof(*dopt) + opt->optlen;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2105) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2106) 		dopt = kmalloc(opt_size, GFP_ATOMIC);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2107) 		if (dopt && __ip_options_echo(net, &dopt->opt, skb, opt)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2108) 			kfree(dopt);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2109) 			dopt = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2110) 		}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2111) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2112) 	return dopt;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2113) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2114) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2115) /* locally generated TCP pure ACKs have skb->truesize == 2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2116)  * (check tcp_send_ack() in net/ipv4/tcp_output.c )
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2117)  * This is much faster than dissecting the packet to find out.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2118)  * (Think of GRE encapsulations, IPv4, IPv6, ...)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2119)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2120) static inline bool skb_is_tcp_pure_ack(const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2121) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2122) 	return skb->truesize == 2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2123) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2124) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2125) static inline void skb_set_tcp_pure_ack(struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2126) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2127) 	skb->truesize = 2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2128) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2129) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2130) static inline int tcp_inq(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2131) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2132) 	struct tcp_sock *tp = tcp_sk(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2133) 	int answ;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2134) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2135) 	if ((1 << sk->sk_state) & (TCPF_SYN_SENT | TCPF_SYN_RECV)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2136) 		answ = 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2137) 	} else if (sock_flag(sk, SOCK_URGINLINE) ||
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2138) 		   !tp->urg_data ||
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2139) 		   before(tp->urg_seq, tp->copied_seq) ||
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2140) 		   !before(tp->urg_seq, tp->rcv_nxt)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2141) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2142) 		answ = tp->rcv_nxt - tp->copied_seq;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2143) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2144) 		/* Subtract 1, if FIN was received */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2145) 		if (answ && sock_flag(sk, SOCK_DONE))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2146) 			answ--;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2147) 	} else {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2148) 		answ = tp->urg_seq - tp->copied_seq;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2149) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2150) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2151) 	return answ;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2152) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2153) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2154) int tcp_peek_len(struct socket *sock);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2155) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2156) static inline void tcp_segs_in(struct tcp_sock *tp, const struct sk_buff *skb)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2157) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2158) 	u16 segs_in;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2159) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2160) 	segs_in = max_t(u16, 1, skb_shinfo(skb)->gso_segs);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2161) 	tp->segs_in += segs_in;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2162) 	if (skb->len > tcp_hdrlen(skb))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2163) 		tp->data_segs_in += segs_in;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2164) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2165) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2166) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2167)  * TCP listen path runs lockless.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2168)  * We forced "struct sock" to be const qualified to make sure
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2169)  * we don't modify one of its field by mistake.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2170)  * Here, we increment sk_drops which is an atomic_t, so we can safely
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2171)  * make sock writable again.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2172)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2173) static inline void tcp_listendrop(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2174) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2175) 	atomic_inc(&((struct sock *)sk)->sk_drops);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2176) 	__NET_INC_STATS(sock_net(sk), LINUX_MIB_LISTENDROPS);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2177) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2178) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2179) enum hrtimer_restart tcp_pace_kick(struct hrtimer *timer);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2180) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2181) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2182)  * Interface for adding Upper Level Protocols over TCP
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2183)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2184) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2185) #define TCP_ULP_NAME_MAX	16
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2186) #define TCP_ULP_MAX		128
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2187) #define TCP_ULP_BUF_MAX		(TCP_ULP_NAME_MAX*TCP_ULP_MAX)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2188) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2189) struct tcp_ulp_ops {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2190) 	struct list_head	list;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2191) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2192) 	/* initialize ulp */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2193) 	int (*init)(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2194) 	/* update ulp */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2195) 	void (*update)(struct sock *sk, struct proto *p,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2196) 		       void (*write_space)(struct sock *sk));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2197) 	/* cleanup ulp */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2198) 	void (*release)(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2199) 	/* diagnostic */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2200) 	int (*get_info)(const struct sock *sk, struct sk_buff *skb);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2201) 	size_t (*get_info_size)(const struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2202) 	/* clone ulp */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2203) 	void (*clone)(const struct request_sock *req, struct sock *newsk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2204) 		      const gfp_t priority);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2205) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2206) 	char		name[TCP_ULP_NAME_MAX];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2207) 	struct module	*owner;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2208) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2209) int tcp_register_ulp(struct tcp_ulp_ops *type);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2210) void tcp_unregister_ulp(struct tcp_ulp_ops *type);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2211) int tcp_set_ulp(struct sock *sk, const char *name);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2212) void tcp_get_available_ulp(char *buf, size_t len);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2213) void tcp_cleanup_ulp(struct sock *sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2214) void tcp_update_ulp(struct sock *sk, struct proto *p,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2215) 		    void (*write_space)(struct sock *sk));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2216) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2217) #define MODULE_ALIAS_TCP_ULP(name)				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2218) 	__MODULE_INFO(alias, alias_userspace, name);		\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2219) 	__MODULE_INFO(alias, alias_tcp_ulp, "tcp-ulp-" name)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2220) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2221) struct sk_msg;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2222) struct sk_psock;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2223) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2224) #ifdef CONFIG_BPF_STREAM_PARSER
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2225) struct proto *tcp_bpf_get_proto(struct sock *sk, struct sk_psock *psock);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2226) void tcp_bpf_clone(const struct sock *sk, struct sock *newsk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2227) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2228) static inline void tcp_bpf_clone(const struct sock *sk, struct sock *newsk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2229) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2230) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2231) #endif /* CONFIG_BPF_STREAM_PARSER */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2232) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2233) #ifdef CONFIG_NET_SOCK_MSG
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2234) int tcp_bpf_sendmsg_redir(struct sock *sk, struct sk_msg *msg, u32 bytes,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2235) 			  int flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2236) int __tcp_bpf_recvmsg(struct sock *sk, struct sk_psock *psock,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2237) 		      struct msghdr *msg, int len, int flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2238) #endif /* CONFIG_NET_SOCK_MSG */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2239) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2240) #ifdef CONFIG_CGROUP_BPF
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2241) static inline void bpf_skops_init_skb(struct bpf_sock_ops_kern *skops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2242) 				      struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2243) 				      unsigned int end_offset)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2244) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2245) 	skops->skb = skb;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2246) 	skops->skb_data_end = skb->data + end_offset;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2247) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2248) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2249) static inline void bpf_skops_init_skb(struct bpf_sock_ops_kern *skops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2250) 				      struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2251) 				      unsigned int end_offset)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2252) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2253) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2254) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2255) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2256) /* Call BPF_SOCK_OPS program that returns an int. If the return value
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2257)  * is < 0, then the BPF op failed (for example if the loaded BPF
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2258)  * program does not support the chosen operation or there is no BPF
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2259)  * program loaded).
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2260)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2261) #ifdef CONFIG_BPF
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2262) static inline int tcp_call_bpf(struct sock *sk, int op, u32 nargs, u32 *args)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2263) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2264) 	struct bpf_sock_ops_kern sock_ops;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2265) 	int ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2266) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2267) 	memset(&sock_ops, 0, offsetof(struct bpf_sock_ops_kern, temp));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2268) 	if (sk_fullsock(sk)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2269) 		sock_ops.is_fullsock = 1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2270) 		sock_owned_by_me(sk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2271) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2272) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2273) 	sock_ops.sk = sk;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2274) 	sock_ops.op = op;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2275) 	if (nargs > 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2276) 		memcpy(sock_ops.args, args, nargs * sizeof(*args));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2277) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2278) 	ret = BPF_CGROUP_RUN_PROG_SOCK_OPS(&sock_ops);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2279) 	if (ret == 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2280) 		ret = sock_ops.reply;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2281) 	else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2282) 		ret = -1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2283) 	return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2284) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2285) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2286) static inline int tcp_call_bpf_2arg(struct sock *sk, int op, u32 arg1, u32 arg2)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2287) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2288) 	u32 args[2] = {arg1, arg2};
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2289) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2290) 	return tcp_call_bpf(sk, op, 2, args);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2291) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2292) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2293) static inline int tcp_call_bpf_3arg(struct sock *sk, int op, u32 arg1, u32 arg2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2294) 				    u32 arg3)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2295) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2296) 	u32 args[3] = {arg1, arg2, arg3};
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2297) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2298) 	return tcp_call_bpf(sk, op, 3, args);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2299) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2300) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2301) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2302) static inline int tcp_call_bpf(struct sock *sk, int op, u32 nargs, u32 *args)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2303) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2304) 	return -EPERM;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2305) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2306) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2307) static inline int tcp_call_bpf_2arg(struct sock *sk, int op, u32 arg1, u32 arg2)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2308) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2309) 	return -EPERM;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2310) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2311) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2312) static inline int tcp_call_bpf_3arg(struct sock *sk, int op, u32 arg1, u32 arg2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2313) 				    u32 arg3)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2314) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2315) 	return -EPERM;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2316) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2317) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2318) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2319) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2320) static inline u32 tcp_timeout_init(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2321) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2322) 	int timeout;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2323) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2324) 	timeout = tcp_call_bpf(sk, BPF_SOCK_OPS_TIMEOUT_INIT, 0, NULL);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2325) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2326) 	if (timeout <= 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2327) 		timeout = TCP_TIMEOUT_INIT;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2328) 	return timeout;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2329) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2330) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2331) static inline u32 tcp_rwnd_init_bpf(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2332) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2333) 	int rwnd;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2334) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2335) 	rwnd = tcp_call_bpf(sk, BPF_SOCK_OPS_RWND_INIT, 0, NULL);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2336) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2337) 	if (rwnd < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2338) 		rwnd = 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2339) 	return rwnd;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2340) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2341) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2342) static inline bool tcp_bpf_ca_needs_ecn(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2343) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2344) 	return (tcp_call_bpf(sk, BPF_SOCK_OPS_NEEDS_ECN, 0, NULL) == 1);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2345) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2346) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2347) static inline void tcp_bpf_rtt(struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2348) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2349) 	if (BPF_SOCK_OPS_TEST_FLAG(tcp_sk(sk), BPF_SOCK_OPS_RTT_CB_FLAG))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2350) 		tcp_call_bpf(sk, BPF_SOCK_OPS_RTT_CB, 0, NULL);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2351) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2352) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2353) #if IS_ENABLED(CONFIG_SMC)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2354) extern struct static_key_false tcp_have_smc;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2355) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2356) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2357) #if IS_ENABLED(CONFIG_TLS_DEVICE)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2358) void clean_acked_data_enable(struct inet_connection_sock *icsk,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2359) 			     void (*cad)(struct sock *sk, u32 ack_seq));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2360) void clean_acked_data_disable(struct inet_connection_sock *icsk);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2361) void clean_acked_data_flush(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2362) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2363) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2364) DECLARE_STATIC_KEY_FALSE(tcp_tx_delay_enabled);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2365) static inline void tcp_add_tx_delay(struct sk_buff *skb,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2366) 				    const struct tcp_sock *tp)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2367) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2368) 	if (static_branch_unlikely(&tcp_tx_delay_enabled))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2369) 		skb->skb_mstamp_ns += (u64)tp->tcp_tx_delay * NSEC_PER_USEC;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2370) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2371) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2372) /* Compute Earliest Departure Time for some control packets
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2373)  * like ACK or RST for TIME_WAIT or non ESTABLISHED sockets.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2374)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2375) static inline u64 tcp_transmit_time(const struct sock *sk)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2376) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2377) 	if (static_branch_unlikely(&tcp_tx_delay_enabled)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2378) 		u32 delay = (sk->sk_state == TCP_TIME_WAIT) ?
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2379) 			tcp_twsk(sk)->tw_tx_delay : tcp_sk(sk)->tcp_tx_delay;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2380) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2381) 		return tcp_clock_ns() + (u64)delay * NSEC_PER_USEC;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2382) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2383) 	return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2384) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2385) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2386) #endif	/* _TCP_H */