xref: /openbmc/linux/include/net/inet_timewait_sock.h (revision 26d0dfbb16fcb17d128a79dc70f3020ea6992af0)
12874c5fdSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-or-later */
28feaf0c0SArnaldo Carvalho de Melo /*
38feaf0c0SArnaldo Carvalho de Melo  * INET		An implementation of the TCP/IP protocol suite for the LINUX
48feaf0c0SArnaldo Carvalho de Melo  *		operating system.  INET is implemented using the  BSD Socket
58feaf0c0SArnaldo Carvalho de Melo  *		interface as the means of communication with the user level.
68feaf0c0SArnaldo Carvalho de Melo  *
78feaf0c0SArnaldo Carvalho de Melo  *		Definitions for a generic INET TIMEWAIT sock
88feaf0c0SArnaldo Carvalho de Melo  *
98feaf0c0SArnaldo Carvalho de Melo  *		From code originally in net/tcp.h
108feaf0c0SArnaldo Carvalho de Melo  */
118feaf0c0SArnaldo Carvalho de Melo #ifndef _INET_TIMEWAIT_SOCK_
128feaf0c0SArnaldo Carvalho de Melo #define _INET_TIMEWAIT_SOCK_
138feaf0c0SArnaldo Carvalho de Melo 
148feaf0c0SArnaldo Carvalho de Melo #include <linux/list.h>
15295ff7edSArnaldo Carvalho de Melo #include <linux/timer.h>
168feaf0c0SArnaldo Carvalho de Melo #include <linux/types.h>
17295ff7edSArnaldo Carvalho de Melo #include <linux/workqueue.h>
188feaf0c0SArnaldo Carvalho de Melo 
1914c85021SArnaldo Carvalho de Melo #include <net/inet_sock.h>
208feaf0c0SArnaldo Carvalho de Melo #include <net/sock.h>
218feaf0c0SArnaldo Carvalho de Melo #include <net/tcp_states.h>
226d6ee43eSArnaldo Carvalho de Melo #include <net/timewait_sock.h>
238feaf0c0SArnaldo Carvalho de Melo 
2460063497SArun Sharma #include <linux/atomic.h>
258feaf0c0SArnaldo Carvalho de Melo 
268feaf0c0SArnaldo Carvalho de Melo struct inet_bind_bucket;
278feaf0c0SArnaldo Carvalho de Melo 
288feaf0c0SArnaldo Carvalho de Melo /*
298feaf0c0SArnaldo Carvalho de Melo  * This is a TIME_WAIT sock. It works around the memory consumption
308feaf0c0SArnaldo Carvalho de Melo  * problems of sockets in such a state on heavily loaded servers, but
318feaf0c0SArnaldo Carvalho de Melo  * without violating the protocol specification.
328feaf0c0SArnaldo Carvalho de Melo  */
338feaf0c0SArnaldo Carvalho de Melo struct inet_timewait_sock {
348feaf0c0SArnaldo Carvalho de Melo 	/*
358feaf0c0SArnaldo Carvalho de Melo 	 * Now struct sock also uses sock_common, so please just
368feaf0c0SArnaldo Carvalho de Melo 	 * don't add nothing before this first member (__tw_common) --acme
378feaf0c0SArnaldo Carvalho de Melo 	 */
388feaf0c0SArnaldo Carvalho de Melo 	struct sock_common	__tw_common;
398feaf0c0SArnaldo Carvalho de Melo #define tw_family		__tw_common.skc_family
408feaf0c0SArnaldo Carvalho de Melo #define tw_state		__tw_common.skc_state
418feaf0c0SArnaldo Carvalho de Melo #define tw_reuse		__tw_common.skc_reuse
423099a529SEric Dumazet #define tw_reuseport		__tw_common.skc_reuseport
439fe516baSEric Dumazet #define tw_ipv6only		__tw_common.skc_ipv6only
448feaf0c0SArnaldo Carvalho de Melo #define tw_bound_dev_if		__tw_common.skc_bound_dev_if
453ab5aee7SEric Dumazet #define tw_node			__tw_common.skc_nulls_node
468feaf0c0SArnaldo Carvalho de Melo #define tw_bind_node		__tw_common.skc_bind_node
478feaf0c0SArnaldo Carvalho de Melo #define tw_refcnt		__tw_common.skc_refcnt
4881c3d547SEric Dumazet #define tw_hash			__tw_common.skc_hash
498feaf0c0SArnaldo Carvalho de Melo #define tw_prot			__tw_common.skc_prot
5007feaebfSEric W. Biederman #define tw_net			__tw_common.skc_net
5168835abaSEric Dumazet #define tw_daddr        	__tw_common.skc_daddr
52efe4208fSEric Dumazet #define tw_v6_daddr		__tw_common.skc_v6_daddr
5368835abaSEric Dumazet #define tw_rcv_saddr    	__tw_common.skc_rcv_saddr
54efe4208fSEric Dumazet #define tw_v6_rcv_saddr    	__tw_common.skc_v6_rcv_saddr
55ce43b03eSEric Dumazet #define tw_dport		__tw_common.skc_dport
56ce43b03eSEric Dumazet #define tw_num			__tw_common.skc_num
5733cf7c90SEric Dumazet #define tw_cookie		__tw_common.skc_cookie
588e5eb54dSEric Dumazet #define tw_dr			__tw_common.skc_tw_dr
59ce43b03eSEric Dumazet 
6000483690SJon Maxwell 	__u32			tw_mark;
618feaf0c0SArnaldo Carvalho de Melo 	volatile unsigned char	tw_substate;
628feaf0c0SArnaldo Carvalho de Melo 	unsigned char		tw_rcv_wscale;
6368835abaSEric Dumazet 
648feaf0c0SArnaldo Carvalho de Melo 	/* Socket demultiplex comparisons on incoming packets. */
6568835abaSEric Dumazet 	/* these three are in inet_sock */
6623f33c2dSAl Viro 	__be16			tw_sport;
678feaf0c0SArnaldo Carvalho de Melo 	/* And these are ours. */
6827dd35e0SEric Dumazet 	unsigned int		tw_transparent  : 1,
691d13a96cSFlorent Fourcot 				tw_flowlabel	: 20,
7027dd35e0SEric Dumazet 				tw_pad		: 3,	/* 3 bits hole */
711d13a96cSFlorent Fourcot 				tw_tos		: 8;
72c67b8555SEric Dumazet 	u32			tw_txhash;
73f6c0f5d2SEric Dumazet 	u32			tw_priority;
74789f558cSEric Dumazet 	struct timer_list	tw_timer;
758feaf0c0SArnaldo Carvalho de Melo 	struct inet_bind_bucket	*tw_tb;
76936a192fSKuniyuki Iwashima 	struct inet_bind2_bucket	*tw_tb2;
77936a192fSKuniyuki Iwashima 	struct hlist_node		tw_bind2_node;
788feaf0c0SArnaldo Carvalho de Melo };
79b903d324SEric Dumazet #define tw_tclass tw_tos
808feaf0c0SArnaldo Carvalho de Melo 
81936a192fSKuniyuki Iwashima #define twsk_for_each_bound_bhash2(__tw, list) \
82936a192fSKuniyuki Iwashima 	hlist_for_each_entry(__tw, list, tw_bind2_node)
83936a192fSKuniyuki Iwashima 
inet_twsk(const struct sock * sk)848feaf0c0SArnaldo Carvalho de Melo static inline struct inet_timewait_sock *inet_twsk(const struct sock *sk)
858feaf0c0SArnaldo Carvalho de Melo {
868feaf0c0SArnaldo Carvalho de Melo 	return (struct inet_timewait_sock *)sk;
878feaf0c0SArnaldo Carvalho de Melo }
888feaf0c0SArnaldo Carvalho de Melo 
8905dbc7b5SEric Dumazet void inet_twsk_free(struct inet_timewait_sock *tw);
901fd51155SJoe Perches void inet_twsk_put(struct inet_timewait_sock *tw);
91e48c414eSArnaldo Carvalho de Melo 
92fc01538fSEric Dumazet void inet_twsk_bind_unhash(struct inet_timewait_sock *tw,
933cdaedaeSEric Dumazet 			   struct inet_hashinfo *hashinfo);
943cdaedaeSEric Dumazet 
951fd51155SJoe Perches struct inet_timewait_sock *inet_twsk_alloc(const struct sock *sk,
96789f558cSEric Dumazet 					   struct inet_timewait_death_row *dr,
97c676270bSArnaldo Carvalho de Melo 					   const int state);
98c676270bSArnaldo Carvalho de Melo 
99ec94c269SEric Dumazet void inet_twsk_hashdance(struct inet_timewait_sock *tw, struct sock *sk,
100e48c414eSArnaldo Carvalho de Melo 			 struct inet_hashinfo *hashinfo);
101696ab2d3SArnaldo Carvalho de Melo 
102ed2e9239SEric Dumazet void __inet_twsk_schedule(struct inet_timewait_sock *tw, int timeo,
103ed2e9239SEric Dumazet 			  bool rearm);
104ed2e9239SEric Dumazet 
inet_twsk_schedule(struct inet_timewait_sock * tw,int timeo)1058695a144SRaanan Avargil static inline void inet_twsk_schedule(struct inet_timewait_sock *tw, int timeo)
106ed2e9239SEric Dumazet {
107ed2e9239SEric Dumazet 	__inet_twsk_schedule(tw, timeo, false);
108ed2e9239SEric Dumazet }
109ed2e9239SEric Dumazet 
inet_twsk_reschedule(struct inet_timewait_sock * tw,int timeo)1108695a144SRaanan Avargil static inline void inet_twsk_reschedule(struct inet_timewait_sock *tw, int timeo)
111ed2e9239SEric Dumazet {
112ed2e9239SEric Dumazet 	__inet_twsk_schedule(tw, timeo, true);
113ed2e9239SEric Dumazet }
114ed2e9239SEric Dumazet 
115dbe7faa4SEric Dumazet void inet_twsk_deschedule_put(struct inet_timewait_sock *tw);
1163b1e0a65SYOSHIFUJI Hideaki 
117*73480616SEric Dumazet void inet_twsk_purge(struct inet_hashinfo *hashinfo);
11804c494e6SEric Dumazet 
1193b1e0a65SYOSHIFUJI Hideaki static inline
twsk_net(const struct inet_timewait_sock * twsk)1203b1e0a65SYOSHIFUJI Hideaki struct net *twsk_net(const struct inet_timewait_sock *twsk)
1213b1e0a65SYOSHIFUJI Hideaki {
122f943cbe6SEric Dumazet 	return read_pnet(&twsk->tw_net);
1233b1e0a65SYOSHIFUJI Hideaki }
1243b1e0a65SYOSHIFUJI Hideaki 
1253b1e0a65SYOSHIFUJI Hideaki static inline
twsk_net_set(struct inet_timewait_sock * twsk,struct net * net)126f5aa23fdSDenis V. Lunev void twsk_net_set(struct inet_timewait_sock *twsk, struct net *net)
1273b1e0a65SYOSHIFUJI Hideaki {
128f943cbe6SEric Dumazet 	write_pnet(&twsk->tw_net, net);
1293b1e0a65SYOSHIFUJI Hideaki }
1308feaf0c0SArnaldo Carvalho de Melo #endif	/* _INET_TIMEWAIT_SOCK_ */
131