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