Blame view

include/linux/tcp.h 14.6 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
  /*
   * INET		An implementation of the TCP/IP protocol suite for the LINUX
   *		operating system.  INET is implemented using the  BSD Socket
   *		interface as the means of communication with the user level.
   *
   *		Definitions for the TCP protocol.
   *
   * Version:	@(#)tcp.h	1.0.2	04/28/93
   *
   * Author:	Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
   *
   *		This program is free software; you can redistribute it and/or
   *		modify it under the terms of the GNU General Public License
   *		as published by the Free Software Foundation; either version
   *		2 of the License, or (at your option) any later version.
   */
  #ifndef _LINUX_TCP_H
  #define _LINUX_TCP_H
  
  #include <linux/types.h>
  #include <asm/byteorder.h>
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
22
  #include <linux/socket.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
23
24
  
  struct tcphdr {
46a97324a   Al Viro   [IPV4]: TCP heade...
25
26
27
28
  	__be16	source;
  	__be16	dest;
  	__be32	seq;
  	__be32	ack_seq;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
  #if defined(__LITTLE_ENDIAN_BITFIELD)
  	__u16	res1:4,
  		doff:4,
  		fin:1,
  		syn:1,
  		rst:1,
  		psh:1,
  		ack:1,
  		urg:1,
  		ece:1,
  		cwr:1;
  #elif defined(__BIG_ENDIAN_BITFIELD)
  	__u16	doff:4,
  		res1:4,
  		cwr:1,
  		ece:1,
  		urg:1,
  		ack:1,
  		psh:1,
  		rst:1,
  		syn:1,
  		fin:1;
  #else
  #error	"Adjust your <asm/byteorder.h> defines"
  #endif	
46a97324a   Al Viro   [IPV4]: TCP heade...
54
  	__be16	window;
9981a0e36   Al Viro   [NET]: Annotate c...
55
  	__sum16	check;
46a97324a   Al Viro   [IPV4]: TCP heade...
56
  	__be16	urg_ptr;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
57
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
58
59
60
61
62
63
64
  /*
   *	The union cast uses a gcc extension to avoid aliasing problems
   *  (union is compatible to any of its members)
   *  This means this part of the code is -fstrict-aliasing safe now.
   */
  union tcp_word_hdr { 
  	struct tcphdr hdr;
46a97324a   Al Viro   [IPV4]: TCP heade...
65
  	__be32 		  words[5];
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
66
67
68
69
70
  }; 
  
  #define tcp_flag_word(tp) ( ((union tcp_word_hdr *)(tp))->words [3]) 
  
  enum { 
f3a7c66b5   Harvey Harrison   net: replace __co...
71
72
73
74
75
76
77
78
79
80
  	TCP_FLAG_CWR = __cpu_to_be32(0x00800000),
  	TCP_FLAG_ECE = __cpu_to_be32(0x00400000),
  	TCP_FLAG_URG = __cpu_to_be32(0x00200000),
  	TCP_FLAG_ACK = __cpu_to_be32(0x00100000),
  	TCP_FLAG_PSH = __cpu_to_be32(0x00080000),
  	TCP_FLAG_RST = __cpu_to_be32(0x00040000),
  	TCP_FLAG_SYN = __cpu_to_be32(0x00020000),
  	TCP_FLAG_FIN = __cpu_to_be32(0x00010000),
  	TCP_RESERVED_BITS = __cpu_to_be32(0x0F000000),
  	TCP_DATA_OFFSET = __cpu_to_be32(0xF0000000)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
81
  }; 
bee7ca9ec   William Allen Simpson   net: TCP_MSS_DEFA...
82
83
84
85
86
  /*
   * TCP general constants
   */
  #define TCP_MSS_DEFAULT		 536U	/* IPv4 (RFC1122, RFC2581) */
  #define TCP_MSS_DESIRED		1220U	/* IPv6 (tunneled), EDNS0 (RFC3226) */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
87
88
89
90
91
92
93
94
95
96
97
98
99
  /* TCP socket options */
  #define TCP_NODELAY		1	/* Turn off Nagle's algorithm. */
  #define TCP_MAXSEG		2	/* Limit MSS */
  #define TCP_CORK		3	/* Never send partially complete segments */
  #define TCP_KEEPIDLE		4	/* Start keeplives after this period */
  #define TCP_KEEPINTVL		5	/* Interval between keepalives */
  #define TCP_KEEPCNT		6	/* Number of keepalives before death */
  #define TCP_SYNCNT		7	/* Number of SYN retransmits */
  #define TCP_LINGER2		8	/* Life time of orphaned FIN-WAIT-2 state */
  #define TCP_DEFER_ACCEPT	9	/* Wake up listener only when data arrive */
  #define TCP_WINDOW_CLAMP	10	/* Bound advertised window */
  #define TCP_INFO		11	/* Information about this connection. */
  #define TCP_QUICKACK		12	/* Block/reenable quick acks */
5f8ef48d2   Stephen Hemminger   [TCP]: Allow choo...
100
  #define TCP_CONGESTION		13	/* Congestion control algorithm */
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
101
  #define TCP_MD5SIG		14	/* TCP MD5 Signature (RFC2385) */
519855c50   William Allen Simpson   TCPCT part 1c: sy...
102
  #define TCP_COOKIE_TRANSACTIONS	15	/* TCP Cookie Transactions */
36e31b0af   Andreas Petlund   net: TCP thin lin...
103
  #define TCP_THIN_LINEAR_TIMEOUTS 16      /* Use linear timeouts for thin streams*/
7e3801755   Andreas Petlund   net: TCP thin dupack
104
  #define TCP_THIN_DUPACK         17      /* Fast retrans. after 1 dupack */
dca43c75e   Jerry Chu   tcp: Add TCP_USER...
105
  #define TCP_USER_TIMEOUT	18	/* How long for loss retry before timeout */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
106

519855c50   William Allen Simpson   TCPCT part 1c: sy...
107
  /* for TCP_INFO socket option */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
108
109
110
  #define TCPI_OPT_TIMESTAMPS	1
  #define TCPI_OPT_SACK		2
  #define TCPI_OPT_WSCALE		4
b5c5693bb   Eric Dumazet   tcp: report ECN_S...
111
112
  #define TCPI_OPT_ECN		8 /* ECN was negociated at TCP session init */
  #define TCPI_OPT_ECN_SEEN	16 /* we received at least one packet with ECT */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
113

d94d9fee9   Eric Dumazet   net: cleanup incl...
114
  enum tcp_ca_state {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
115
116
117
118
119
120
121
122
123
124
125
  	TCP_CA_Open = 0,
  #define TCPF_CA_Open	(1<<TCP_CA_Open)
  	TCP_CA_Disorder = 1,
  #define TCPF_CA_Disorder (1<<TCP_CA_Disorder)
  	TCP_CA_CWR = 2,
  #define TCPF_CA_CWR	(1<<TCP_CA_CWR)
  	TCP_CA_Recovery = 3,
  #define TCPF_CA_Recovery (1<<TCP_CA_Recovery)
  	TCP_CA_Loss = 4
  #define TCPF_CA_Loss	(1<<TCP_CA_Loss)
  };
d94d9fee9   Eric Dumazet   net: cleanup incl...
126
  struct tcp_info {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
  	__u8	tcpi_state;
  	__u8	tcpi_ca_state;
  	__u8	tcpi_retransmits;
  	__u8	tcpi_probes;
  	__u8	tcpi_backoff;
  	__u8	tcpi_options;
  	__u8	tcpi_snd_wscale : 4, tcpi_rcv_wscale : 4;
  
  	__u32	tcpi_rto;
  	__u32	tcpi_ato;
  	__u32	tcpi_snd_mss;
  	__u32	tcpi_rcv_mss;
  
  	__u32	tcpi_unacked;
  	__u32	tcpi_sacked;
  	__u32	tcpi_lost;
  	__u32	tcpi_retrans;
  	__u32	tcpi_fackets;
  
  	/* Times. */
  	__u32	tcpi_last_data_sent;
  	__u32	tcpi_last_ack_sent;     /* Not remembered, sorry. */
  	__u32	tcpi_last_data_recv;
  	__u32	tcpi_last_ack_recv;
  
  	/* Metrics. */
  	__u32	tcpi_pmtu;
  	__u32	tcpi_rcv_ssthresh;
  	__u32	tcpi_rtt;
  	__u32	tcpi_rttvar;
  	__u32	tcpi_snd_ssthresh;
  	__u32	tcpi_snd_cwnd;
  	__u32	tcpi_advmss;
  	__u32	tcpi_reordering;
  
  	__u32	tcpi_rcv_rtt;
  	__u32	tcpi_rcv_space;
  
  	__u32	tcpi_total_retrans;
  };
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
167
168
169
170
171
172
173
174
175
176
  /* for TCP_MD5SIG socket option */
  #define TCP_MD5SIG_MAXKEYLEN	80
  
  struct tcp_md5sig {
  	struct __kernel_sockaddr_storage tcpm_addr;	/* address associated */
  	__u16	__tcpm_pad1;				/* zero */
  	__u16	tcpm_keylen;				/* key length */
  	__u32	__tcpm_pad2;				/* zero */
  	__u8	tcpm_key[TCP_MD5SIG_MAXKEYLEN];		/* key (binary) */
  };
519855c50   William Allen Simpson   TCPCT part 1c: sy...
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
  /* for TCP_COOKIE_TRANSACTIONS (TCPCT) socket option */
  #define TCP_COOKIE_MIN		 8		/*  64-bits */
  #define TCP_COOKIE_MAX		16		/* 128-bits */
  #define TCP_COOKIE_PAIR_SIZE	(2*TCP_COOKIE_MAX)
  
  /* Flags for both getsockopt and setsockopt */
  #define TCP_COOKIE_IN_ALWAYS	(1 << 0)	/* Discard SYN without cookie */
  #define TCP_COOKIE_OUT_NEVER	(1 << 1)	/* Prohibit outgoing cookies,
  						 * supercedes everything. */
  
  /* Flags for getsockopt */
  #define TCP_S_DATA_IN		(1 << 2)	/* Was data received? */
  #define TCP_S_DATA_OUT		(1 << 3)	/* Was data sent? */
  
  /* TCP_COOKIE_TRANSACTIONS data */
  struct tcp_cookie_transactions {
  	__u16	tcpct_flags;			/* see above */
  	__u8	__tcpct_pad1;			/* zero */
  	__u8	tcpct_cookie_desired;		/* bytes */
  	__u16	tcpct_s_data_desired;		/* bytes of variable data */
  	__u16	tcpct_used;			/* bytes in value */
  	__u8	tcpct_value[TCP_MSS_DEFAULT];
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
200
  #ifdef __KERNEL__
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
201
  #include <linux/skbuff.h>
c8a553ad7   David Woodhouse   [TCP]: Move inclu...
202
  #include <linux/dmaengine.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
203
  #include <net/sock.h>
463c84b97   Arnaldo Carvalho de Melo   [NET]: Introduce ...
204
  #include <net/inet_connection_sock.h>
8feaf0c0a   Arnaldo Carvalho de Melo   [INET]: Generalis...
205
  #include <net/inet_timewait_sock.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
206

aa8223c7b   Arnaldo Carvalho de Melo   [SK_BUFF]: Introd...
207
208
  static inline struct tcphdr *tcp_hdr(const struct sk_buff *skb)
  {
9c70220b7   Arnaldo Carvalho de Melo   [SK_BUFF]: Introd...
209
  	return (struct tcphdr *)skb_transport_header(skb);
aa8223c7b   Arnaldo Carvalho de Melo   [SK_BUFF]: Introd...
210
  }
ab6a5bb6b   Arnaldo Carvalho de Melo   [TCP]: Introduce ...
211
212
  static inline unsigned int tcp_hdrlen(const struct sk_buff *skb)
  {
aa8223c7b   Arnaldo Carvalho de Melo   [SK_BUFF]: Introd...
213
  	return tcp_hdr(skb)->doff * 4;
ab6a5bb6b   Arnaldo Carvalho de Melo   [TCP]: Introduce ...
214
215
216
217
  }
  
  static inline unsigned int tcp_optlen(const struct sk_buff *skb)
  {
aa8223c7b   Arnaldo Carvalho de Melo   [SK_BUFF]: Introd...
218
  	return (tcp_hdr(skb)->doff - 5) * 4;
ab6a5bb6b   Arnaldo Carvalho de Melo   [TCP]: Introduce ...
219
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
220
  /* This defines a selective acknowledgement block. */
269bd27e6   Al Viro   [TCP]: struct tcp...
221
222
223
224
  struct tcp_sack_block_wire {
  	__be32	start_seq;
  	__be32	end_seq;
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
225
  struct tcp_sack_block {
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
226
227
  	u32	start_seq;
  	u32	end_seq;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
228
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
229
230
231
  struct tcp_options_received {
  /*	PAWS/RTTM data	*/
  	long	ts_recent_stamp;/* Time we stored ts_recent (for aging) */
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
232
233
234
235
  	u32	ts_recent;	/* Time stamp to echo next		*/
  	u32	rcv_tsval;	/* Time stamp value             	*/
  	u32	rcv_tsecr;	/* Time stamp echo reply        	*/
  	u16 	saw_tstamp : 1,	/* Saw TIMESTAMP on last packet		*/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
236
237
238
239
240
241
  		tstamp_ok : 1,	/* TIMESTAMP seen on SYN packet		*/
  		dsack : 1,	/* D-SACK is scheduled			*/
  		wscale_ok : 1,	/* Wscale seen on SYN packet		*/
  		sack_ok : 4,	/* SACK seen on SYN packet		*/
  		snd_wscale : 4,	/* Window scaling received from sender	*/
  		rcv_wscale : 4;	/* Window scaling to send to receiver	*/
435cf559f   William Allen Simpson   TCPCT part 1d: de...
242
243
244
  	u8	cookie_plus:6,	/* bytes in authenticator/cookie option	*/
  		cookie_out_never:1,
  		cookie_in_always:1;
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
245
  	u8	num_sacks;	/* Number of SACK blocks		*/
435cf559f   William Allen Simpson   TCPCT part 1d: de...
246
  	u16	user_mss;	/* mss requested by user in ioctl	*/
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
247
  	u16	mss_clamp;	/* Maximal mss, negotiated at connection setup */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
248
  };
519855c50   William Allen Simpson   TCPCT part 1c: sy...
249
250
  static inline void tcp_clear_options(struct tcp_options_received *rx_opt)
  {
435cf559f   William Allen Simpson   TCPCT part 1d: de...
251
252
253
  	rx_opt->tstamp_ok = rx_opt->sack_ok = 0;
  	rx_opt->wscale_ok = rx_opt->snd_wscale = 0;
  	rx_opt->cookie_plus = 0;
519855c50   William Allen Simpson   TCPCT part 1c: sy...
254
  }
4389dded7   Adam Langley   tcp: Remove redun...
255
  /* This is the max number of SACKS that we'll generate and process. It's safe
435cf559f   William Allen Simpson   TCPCT part 1d: de...
256
   * to increase this, although since:
4389dded7   Adam Langley   tcp: Remove redun...
257
258
259
   *   size = TCPOLEN_SACK_BASE_ALIGNED (4) + n * TCPOLEN_SACK_PERBLOCK (8)
   * only four options will fit in a standard TCP header */
  #define TCP_NUM_SACKS 4
435cf559f   William Allen Simpson   TCPCT part 1d: de...
260
261
  struct tcp_cookie_values;
  struct tcp_request_sock_ops;
2e6599cb8   Arnaldo Carvalho de Melo   [NET] Generalise ...
262
  struct tcp_request_sock {
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
263
264
265
  	struct inet_request_sock 	req;
  #ifdef CONFIG_TCP_MD5SIG
  	/* Only used by TCP MD5 Signature so far. */
b2e4b3deb   Stephen Hemminger   tcp: MD5 operatio...
266
  	const struct tcp_request_sock_ops *af_specific;
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
267
  #endif
435cf559f   William Allen Simpson   TCPCT part 1d: de...
268
269
  	u32				rcv_isn;
  	u32				snt_isn;
9ad7c049f   Jerry Chu   tcp: RFC2988bis +...
270
  	u32				snt_synack; /* synack sent time */
2e6599cb8   Arnaldo Carvalho de Melo   [NET] Generalise ...
271
  };
60236fdd0   Arnaldo Carvalho de Melo   [NET] Rename open...
272
  static inline struct tcp_request_sock *tcp_rsk(const struct request_sock *req)
2e6599cb8   Arnaldo Carvalho de Melo   [NET] Generalise ...
273
274
275
  {
  	return (struct tcp_request_sock *)req;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
276
  struct tcp_sock {
463c84b97   Arnaldo Carvalho de Melo   [NET]: Introduce ...
277
278
  	/* inet_connection_sock has to be the first member of tcp_sock */
  	struct inet_connection_sock	inet_conn;
2ff52f282   Arnaldo Carvalho de Melo   [TCP]: Change tcp...
279
  	u16	tcp_header_len;	/* Bytes of tcp header to send		*/
2a3a041c4   Ilpo Järvinen   tcp: cache result...
280
  	u16	xmit_size_goal_segs; /* Goal for segmenting output packets */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
281
282
283
284
285
  
  /*
   *	Header prediction flags
   *	0x5?10 << 16 + snd_wnd in net byte order
   */
dddc93c05   Al Viro   [TCP]: struct tcp...
286
  	__be32	pred_flags;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
287
288
289
290
291
292
  
  /*
   *	RFC793 variables by their proper names. This means you can
   *	read the code and the spec side by side (and laugh ...)
   *	See RFC793 and RFC1122. The RFC writes these in capitals.
   */
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
293
   	u32	rcv_nxt;	/* What we want to receive next 	*/
54287cc17   Eric Dumazet   [TCP]: Keep copie...
294
295
  	u32	copied_seq;	/* Head of yet unread data		*/
  	u32	rcv_wup;	/* rcv_nxt on last window update sent	*/
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
296
   	u32	snd_nxt;	/* Next sequence we send		*/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
297

3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
298
299
300
301
   	u32	snd_una;	/* First byte we want an ack for	*/
   	u32	snd_sml;	/* Last byte of the most recently transmitted small packet */
  	u32	rcv_tstamp;	/* timestamp of last received ACK (for keepalives) */
  	u32	lsndtime;	/* timestamp of last sent data packet (for restart window) */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
302
303
304
305
306
307
308
309
  
  	/* Data for direct copy to user */
  	struct {
  		struct sk_buff_head	prequeue;
  		struct task_struct	*task;
  		struct iovec		*iov;
  		int			memory;
  		int			len;
97fc2f084   Chris Leech   [I/OAT]: Structur...
310
311
312
313
314
315
316
  #ifdef CONFIG_NET_DMA
  		/* members for async copy */
  		struct dma_chan		*dma_chan;
  		int			wakeup;
  		struct dma_pinned_list	*pinned_list;
  		dma_cookie_t		dma_cookie;
  #endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
317
  	} ucopy;
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
318
319
320
321
  	u32	snd_wl1;	/* Sequence for window update		*/
  	u32	snd_wnd;	/* The window we expect to receive	*/
  	u32	max_window;	/* Maximal window ever seen from peer	*/
  	u32	mss_cache;	/* Cached effective mss, not including SACKS */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
322

3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
323
324
  	u32	window_clamp;	/* Maximal window to advertise		*/
  	u32	rcv_ssthresh;	/* Current window clamp			*/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
325

3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
326
  	u32	frto_highmark;	/* snd_nxt when RTO occurred */
b79eeeb9e   Ilpo Järvinen   tcp: Reorganize t...
327
  	u16	advmss;		/* Advertised MSS			*/
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
328
  	u8	frto_counter;	/* Number of new acks after RTO */
36e31b0af   Andreas Petlund   net: TCP thin lin...
329
330
  	u8	nonagle     : 4,/* Disable Nagle algorithm?             */
  		thin_lto    : 1,/* Use linear timeouts for thin streams */
7e3801755   Andreas Petlund   net: TCP thin dupack
331
332
  		thin_dupack : 1,/* Fast retransmit on first dupack      */
  		unused      : 2;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
333
334
  
  /* RTT measurement */
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
335
336
337
338
339
340
341
  	u32	srtt;		/* smoothed round trip time << 3	*/
  	u32	mdev;		/* medium deviation			*/
  	u32	mdev_max;	/* maximal mdev for the last rtt period	*/
  	u32	rttvar;		/* smoothed mdev_max			*/
  	u32	rtt_seq;	/* sequence number to update rttvar	*/
  
  	u32	packets_out;	/* Packets which are "in flight"	*/
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
342
  	u32	retrans_out;	/* Retransmitted packets out		*/
b79eeeb9e   Ilpo Järvinen   tcp: Reorganize t...
343
344
  
  	u16	urg_data;	/* Saved octet of OOB data and control flags */
b79eeeb9e   Ilpo Järvinen   tcp: Reorganize t...
345
  	u8	ecn_flags;	/* ECN status bits.			*/
33f5f57ee   Ilpo Järvinen   tcp: kill pointle...
346
347
348
349
  	u8	reordering;	/* Packet reordering metric.		*/
  	u32	snd_up;		/* Urgent pointer		*/
  
  	u8	keepalive_probes; /* num of allowed keep alive probes	*/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
350
351
352
  /*
   *      Options received (usually on last packet, some only on SYN packets).
   */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
353
354
355
356
357
  	struct tcp_options_received rx_opt;
  
  /*
   *	Slow start and congestion control (see also Nagle, and Karn & Partridge)
   */
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
358
359
   	u32	snd_ssthresh;	/* Slow start size threshold		*/
   	u32	snd_cwnd;	/* Sending congestion window		*/
f78a1b389   Ilpo Järvinen   [TCP]: Make snd_c...
360
  	u32	snd_cwnd_cnt;	/* Linear increase counter		*/
e0ef57cc5   David S. Miller   [TCP]: Make snd_c...
361
  	u32	snd_cwnd_clamp; /* Do not allow snd_cwnd to grow above this */
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
362
363
  	u32	snd_cwnd_used;
  	u32	snd_cwnd_stamp;
a262f0cdf   Nandita Dukkipati   Proportional Rate...
364
365
366
367
  	u32	prior_cwnd;	/* Congestion window at start of Recovery. */
  	u32	prr_delivered;	/* Number of newly delivered packets to
  				 * receiver in Recovery. */
  	u32	prr_out;	/* Total number of pkts sent during Recovery. */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
368

3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
369
   	u32	rcv_wnd;	/* Current receiver window		*/
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
370
371
  	u32	write_seq;	/* Tail(+1) of data held in tcp send buffer */
  	u32	pushed_seq;	/* Last pushed seq, required to talk to windows */
b79eeeb9e   Ilpo Järvinen   tcp: Reorganize t...
372
373
374
375
376
  	u32	lost_out;	/* Lost packets			*/
  	u32	sacked_out;	/* SACK'd packets			*/
  	u32	fackets_out;	/* FACK'd packets			*/
  	u32	tso_deferred;
  	u32	bytes_acked;	/* Appropriate Byte Counting - RFC3465 */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
377

b79eeeb9e   Ilpo Järvinen   tcp: Reorganize t...
378
379
380
381
  	/* from STCP, retrans queue hinting */
  	struct sk_buff* lost_skb_hint;
  	struct sk_buff *scoreboard_skb_hint;
  	struct sk_buff *retransmit_skb_hint;
b79eeeb9e   Ilpo Järvinen   tcp: Reorganize t...
382
383
384
385
  
  	struct sk_buff_head	out_of_order_queue; /* Out of order segments go here */
  
  	/* SACKs data, these 2 need to be together (see tcp_build_and_update_options) */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
386
387
  	struct tcp_sack_block duplicate_sack[1]; /* D-SACK block */
  	struct tcp_sack_block selective_acks[4]; /* The SACKS themselves*/
fd6dad616   Ilpo Järvinen   [TCP]: Earlier SA...
388
  	struct tcp_sack_block recv_sack_cache[4];
6a438bbe6   Stephen Hemminger   [TCP]: speed up S...
389

a47e5a988   Ilpo Järvinen   [TCP]: Convert hi...
390
391
392
393
  	struct sk_buff *highest_sack;   /* highest skb with SACK received
  					 * (validity guaranteed only if
  					 * sacked_out > 0)
  					 */
d738cd8fc   Ilpo Järvinen   [TCP]: Add highes...
394

6a438bbe6   Stephen Hemminger   [TCP]: speed up S...
395
  	int     lost_cnt_hint;
006f582c7   Ilpo Järvinen   tcp: convert retr...
396
  	u32     retransmit_high;	/* L-bits may be on up to this seqno */
6a438bbe6   Stephen Hemminger   [TCP]: speed up S...
397

b08d6cb22   Ilpo Järvinen   [TCP]: Limit proc...
398
  	u32	lost_retrans_low;	/* Sent seq after any rxmit (lowest) */
4b7494404   Ilpo Järvinen   tcp: Make prior_s...
399
  	u32	prior_ssthresh; /* ssthresh saved at recovery start	*/
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
400
  	u32	high_seq;	/* snd_nxt at onset of congestion	*/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
401

3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
402
  	u32	retrans_stamp;	/* Timestamp of the last retransmit,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
403
404
  				 * also used in SYN-SENT to remember stamp of
  				 * the first SYN. */
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
405
  	u32	undo_marker;	/* tracking retrans started here. */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
406
  	int	undo_retrans;	/* number of undoable retransmissions. */
b79eeeb9e   Ilpo Järvinen   tcp: Reorganize t...
407
  	u32	total_retrans;	/* Total retransmits for entire connection */
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
408
  	u32	urg_seq;	/* Seq of received urgent pointer */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
409
410
  	unsigned int		keepalive_time;	  /* time before keep alive takes place */
  	unsigned int		keepalive_intvl;  /* time interval between keep alive probes */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
411

a0f82f64e   Florian Westphal   syncookies: remov...
412
  	int			linger2;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
413
414
415
  
  /* Receiver side RTT estimation */
  	struct {
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
416
417
418
  		u32	rtt;
  		u32	seq;
  		u32	time;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
419
420
421
422
423
  	} rcv_rtt_est;
  
  /* Receiver queue space */
  	struct {
  		int	space;
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
424
425
  		u32	seq;
  		u32	time;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
426
  	} rcvq_space;
0e7b13685   John Heffner   [TCP] mtu probing...
427
428
429
  
  /* TCP-specific MTU probe information. */
  	struct {
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
430
431
  		u32		  probe_seq_start;
  		u32		  probe_seq_end;
0e7b13685   John Heffner   [TCP] mtu probing...
432
  	} mtu_probe;
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
433
434
435
  
  #ifdef CONFIG_TCP_MD5SIG
  /* TCP AF-Specific parts; only used by MD5 Signature support so far */
b2e4b3deb   Stephen Hemminger   tcp: MD5 operatio...
436
  	const struct tcp_sock_af_ops	*af_specific;
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
437

b2e4b3deb   Stephen Hemminger   tcp: MD5 operatio...
438
  /* TCP MD5 Signature Option information */
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
439
440
  	struct tcp_md5sig_info	*md5sig_info;
  #endif
435cf559f   William Allen Simpson   TCPCT part 1d: de...
441
442
443
444
445
446
  
  	/* When the cookie options are generated and exchanged, then this
  	 * object holds a reference to them (cookie_values->kref).  Also
  	 * contains related tcp_cookie_transactions fields.
  	 */
  	struct tcp_cookie_values  *cookie_values;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
447
448
449
450
451
452
  };
  
  static inline struct tcp_sock *tcp_sk(const struct sock *sk)
  {
  	return (struct tcp_sock *)sk;
  }
8feaf0c0a   Arnaldo Carvalho de Melo   [INET]: Generalis...
453
454
  struct tcp_timewait_sock {
  	struct inet_timewait_sock tw_sk;
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
455
456
457
458
  	u32			  tw_rcv_nxt;
  	u32			  tw_snd_nxt;
  	u32			  tw_rcv_wnd;
  	u32			  tw_ts_recent;
8feaf0c0a   Arnaldo Carvalho de Melo   [INET]: Generalis...
459
  	long			  tw_ts_recent_stamp;
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
460
  #ifdef CONFIG_TCP_MD5SIG
3a137d206   Arnaldo Carvalho de Melo   [TCP]: Renove the...
461
462
  	u16			  tw_md5_keylen;
  	u8			  tw_md5_key[TCP_MD5SIG_MAXKEYLEN];
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
463
  #endif
435cf559f   William Allen Simpson   TCPCT part 1d: de...
464
465
466
467
  	/* Few sockets in timewait have cookies; in that case, then this
  	 * object holds a reference to them (tw_cookie_values->kref).
  	 */
  	struct tcp_cookie_values  *tw_cookie_values;
8feaf0c0a   Arnaldo Carvalho de Melo   [INET]: Generalis...
468
469
470
471
472
473
  };
  
  static inline struct tcp_timewait_sock *tcp_twsk(const struct sock *sk)
  {
  	return (struct tcp_timewait_sock *)sk;
  }
519855c50   William Allen Simpson   TCPCT part 1c: sy...
474
  #endif	/* __KERNEL__ */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
475
476
  
  #endif	/* _LINUX_TCP_H */