root / lab4 / .minix-src / include / netinet / tcp_var.h @ 13
History | View | Annotate | Download (38.1 KB)
1 | 13 | up20180614 | /* $NetBSD: tcp_var.h,v 1.177 2015/02/14 22:09:53 he Exp $ */
|
---|---|---|---|
2 | |||
3 | /*
|
||
4 | * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
|
||
5 | * All rights reserved.
|
||
6 | *
|
||
7 | * Redistribution and use in source and binary forms, with or without
|
||
8 | * modification, are permitted provided that the following conditions
|
||
9 | * are met:
|
||
10 | * 1. Redistributions of source code must retain the above copyright
|
||
11 | * notice, this list of conditions and the following disclaimer.
|
||
12 | * 2. Redistributions in binary form must reproduce the above copyright
|
||
13 | * notice, this list of conditions and the following disclaimer in the
|
||
14 | * documentation and/or other materials provided with the distribution.
|
||
15 | * 3. Neither the name of the project nor the names of its contributors
|
||
16 | * may be used to endorse or promote products derived from this software
|
||
17 | * without specific prior written permission.
|
||
18 | *
|
||
19 | * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
|
||
20 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
21 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
22 | * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
|
||
23 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||
24 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||
25 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||
26 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||
27 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||
28 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||
29 | * SUCH DAMAGE.
|
||
30 | */
|
||
31 | |||
32 | /*
|
||
33 | * @(#)COPYRIGHT 1.1 (NRL) 17 January 1995
|
||
34 | *
|
||
35 | * NRL grants permission for redistribution and use in source and binary
|
||
36 | * forms, with or without modification, of the software and documentation
|
||
37 | * created at NRL provided that the following conditions are met:
|
||
38 | *
|
||
39 | * 1. Redistributions of source code must retain the above copyright
|
||
40 | * notice, this list of conditions and the following disclaimer.
|
||
41 | * 2. Redistributions in binary form must reproduce the above copyright
|
||
42 | * notice, this list of conditions and the following disclaimer in the
|
||
43 | * documentation and/or other materials provided with the distribution.
|
||
44 | * 3. All advertising materials mentioning features or use of this software
|
||
45 | * must display the following acknowledgements:
|
||
46 | * This product includes software developed by the University of
|
||
47 | * California, Berkeley and its contributors.
|
||
48 | * This product includes software developed at the Information
|
||
49 | * Technology Division, US Naval Research Laboratory.
|
||
50 | * 4. Neither the name of the NRL nor the names of its contributors
|
||
51 | * may be used to endorse or promote products derived from this software
|
||
52 | * without specific prior written permission.
|
||
53 | *
|
||
54 | * THE SOFTWARE PROVIDED BY NRL IS PROVIDED BY NRL AND CONTRIBUTORS ``AS
|
||
55 | * IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
||
56 | * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
|
||
57 | * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL NRL OR
|
||
58 | * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||
59 | * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||
60 | * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||
61 | * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||
62 | * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||
63 | * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||
64 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
65 | *
|
||
66 | * The views and conclusions contained in the software and documentation
|
||
67 | * are those of the authors and should not be interpreted as representing
|
||
68 | * official policies, either expressed or implied, of the US Naval
|
||
69 | * Research Laboratory (NRL).
|
||
70 | */
|
||
71 | |||
72 | /*-
|
||
73 | * Copyright (c) 1997, 1998, 1999, 2001, 2005 The NetBSD Foundation, Inc.
|
||
74 | * All rights reserved.
|
||
75 | *
|
||
76 | * This code is derived from software contributed to The NetBSD Foundation
|
||
77 | * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility,
|
||
78 | * NASA Ames Research Center.
|
||
79 | * This code is derived from software contributed to The NetBSD Foundation
|
||
80 | * by Charles M. Hannum.
|
||
81 | *
|
||
82 | * Redistribution and use in source and binary forms, with or without
|
||
83 | * modification, are permitted provided that the following conditions
|
||
84 | * are met:
|
||
85 | * 1. Redistributions of source code must retain the above copyright
|
||
86 | * notice, this list of conditions and the following disclaimer.
|
||
87 | * 2. Redistributions in binary form must reproduce the above copyright
|
||
88 | * notice, this list of conditions and the following disclaimer in the
|
||
89 | * documentation and/or other materials provided with the distribution.
|
||
90 | *
|
||
91 | * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
||
92 | * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
||
93 | * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||
94 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
||
95 | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||
96 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||
97 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||
98 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||
99 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||
100 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||
101 | * POSSIBILITY OF SUCH DAMAGE.
|
||
102 | */
|
||
103 | |||
104 | /*
|
||
105 | * Copyright (c) 1982, 1986, 1993, 1994, 1995
|
||
106 | * The Regents of the University of California. All rights reserved.
|
||
107 | *
|
||
108 | * Redistribution and use in source and binary forms, with or without
|
||
109 | * modification, are permitted provided that the following conditions
|
||
110 | * are met:
|
||
111 | * 1. Redistributions of source code must retain the above copyright
|
||
112 | * notice, this list of conditions and the following disclaimer.
|
||
113 | * 2. Redistributions in binary form must reproduce the above copyright
|
||
114 | * notice, this list of conditions and the following disclaimer in the
|
||
115 | * documentation and/or other materials provided with the distribution.
|
||
116 | * 3. Neither the name of the University nor the names of its contributors
|
||
117 | * may be used to endorse or promote products derived from this software
|
||
118 | * without specific prior written permission.
|
||
119 | *
|
||
120 | * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||
121 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
122 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
123 | * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||
124 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||
125 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||
126 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||
127 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||
128 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||
129 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||
130 | * SUCH DAMAGE.
|
||
131 | *
|
||
132 | * @(#)tcp_var.h 8.4 (Berkeley) 5/24/95
|
||
133 | */
|
||
134 | |||
135 | #ifndef _NETINET_TCP_VAR_H_
|
||
136 | #define _NETINET_TCP_VAR_H_
|
||
137 | |||
138 | #if defined(_KERNEL_OPT)
|
||
139 | #include "opt_inet.h" |
||
140 | #include "opt_mbuftrace.h" |
||
141 | |||
142 | #endif
|
||
143 | |||
144 | /*
|
||
145 | * Kernel variables for tcp.
|
||
146 | */
|
||
147 | |||
148 | #include <sys/callout.h> |
||
149 | |||
150 | #ifdef TCP_SIGNATURE
|
||
151 | /*
|
||
152 | * Defines which are needed by the xform_tcp module and tcp_[in|out]put
|
||
153 | * for SADB verification and lookup.
|
||
154 | */
|
||
155 | #define TCP_SIGLEN 16 /* length of computed digest in bytes */ |
||
156 | #define TCP_KEYLEN_MIN 1 /* minimum length of TCP-MD5 key */ |
||
157 | #define TCP_KEYLEN_MAX 80 /* maximum length of TCP-MD5 key */ |
||
158 | /*
|
||
159 | * Only a single SA per host may be specified at this time. An SPI is
|
||
160 | * needed in order for the KEY_ALLOCSA() lookup to work.
|
||
161 | */
|
||
162 | #define TCP_SIG_SPI 0x1000 |
||
163 | #endif /* TCP_SIGNATURE */ |
||
164 | |||
165 | /*
|
||
166 | * SACK option block.
|
||
167 | */
|
||
168 | struct sackblk {
|
||
169 | tcp_seq left; /* Left edge of sack block. */
|
||
170 | tcp_seq right; /* Right edge of sack block. */
|
||
171 | }; |
||
172 | |||
173 | TAILQ_HEAD(sackhead, sackhole); |
||
174 | struct sackhole {
|
||
175 | tcp_seq start; |
||
176 | tcp_seq end; |
||
177 | tcp_seq rxmit; |
||
178 | |||
179 | TAILQ_ENTRY(sackhole) sackhole_q; |
||
180 | }; |
||
181 | |||
182 | /*
|
||
183 | * Tcp control block, one per tcp; fields:
|
||
184 | */
|
||
185 | struct tcpcb {
|
||
186 | int t_family; /* address family on the wire */ |
||
187 | struct ipqehead segq; /* sequencing queue */ |
||
188 | int t_segqlen; /* length of the above */ |
||
189 | callout_t t_timer[TCPT_NTIMERS];/* tcp timers */
|
||
190 | short t_state; /* state of this connection */ |
||
191 | short t_rxtshift; /* log(2) of rexmt exp. backoff */ |
||
192 | uint32_t t_rxtcur; /* current retransmit value */
|
||
193 | short t_dupacks; /* consecutive dup acks recd */ |
||
194 | /*
|
||
195 | * t_partialacks:
|
||
196 | * <0 not in fast recovery.
|
||
197 | * ==0 in fast recovery. has not received partial acks
|
||
198 | * >0 in fast recovery. has received partial acks
|
||
199 | */
|
||
200 | short t_partialacks; /* partials acks during fast rexmit */ |
||
201 | u_short t_peermss; /* peer's maximum segment size */
|
||
202 | u_short t_ourmss; /* our's maximum segment size */
|
||
203 | u_short t_segsz; /* current segment size in use */
|
||
204 | char t_force; /* 1 if forcing out a byte */ |
||
205 | u_int t_flags; |
||
206 | #define TF_ACKNOW 0x0001 /* ack peer immediately */ |
||
207 | #define TF_DELACK 0x0002 /* ack, but try to delay it */ |
||
208 | #define TF_NODELAY 0x0004 /* don't delay packets to coalesce */ |
||
209 | #define TF_NOOPT 0x0008 /* don't use tcp options */ |
||
210 | #define TF_REQ_SCALE 0x0020 /* have/will request window scaling */ |
||
211 | #define TF_RCVD_SCALE 0x0040 /* other side has requested scaling */ |
||
212 | #define TF_REQ_TSTMP 0x0080 /* have/will request timestamps */ |
||
213 | #define TF_RCVD_TSTMP 0x0100 /* a timestamp was received in SYN */ |
||
214 | #define TF_SACK_PERMIT 0x0200 /* other side said I could SACK */ |
||
215 | #define TF_SYN_REXMT 0x0400 /* rexmit timer fired on SYN */ |
||
216 | #define TF_WILL_SACK 0x0800 /* try to use SACK */ |
||
217 | #define TF_REASSEMBLING 0x1000 /* we're busy reassembling */ |
||
218 | #define TF_DEAD 0x2000 /* dead and to-be-released */ |
||
219 | #define TF_PMTUD_PEND 0x4000 /* Path MTU Discovery pending */ |
||
220 | #define TF_ECN_PERMIT 0x10000 /* other side said is ECN-ready */ |
||
221 | #define TF_ECN_SND_CWR 0x20000 /* ECN CWR in queue */ |
||
222 | #define TF_ECN_SND_ECE 0x40000 /* ECN ECE in queue */ |
||
223 | #define TF_SIGNATURE 0x400000 /* require MD5 digests (RFC2385) */ |
||
224 | |||
225 | |||
226 | struct mbuf *t_template; /* skeletal packet for transmit */ |
||
227 | struct inpcb *t_inpcb; /* back pointer to internet pcb */ |
||
228 | struct in6pcb *t_in6pcb; /* back pointer to internet pcb */ |
||
229 | callout_t t_delack_ch; /* delayed ACK callout */
|
||
230 | /*
|
||
231 | * The following fields are used as in the protocol specification.
|
||
232 | * See RFC793, Dec. 1981, page 21.
|
||
233 | */
|
||
234 | /* send sequence variables */
|
||
235 | tcp_seq snd_una; /* send unacknowledged */
|
||
236 | tcp_seq snd_nxt; /* send next */
|
||
237 | tcp_seq snd_up; /* send urgent pointer */
|
||
238 | tcp_seq snd_wl1; /* window update seg seq number */
|
||
239 | tcp_seq snd_wl2; /* window update seg ack number */
|
||
240 | tcp_seq iss; /* initial send sequence number */
|
||
241 | u_long snd_wnd; /* send window */
|
||
242 | /*
|
||
243 | * snd_recover
|
||
244 | * it's basically same as the "recover" variable in RFC 2852 (NewReno).
|
||
245 | * when entering fast retransmit, it's set to snd_max.
|
||
246 | * newreno uses this to detect partial ack.
|
||
247 | * snd_high
|
||
248 | * it's basically same as the "send_high" variable in RFC 2852 (NewReno).
|
||
249 | * on each RTO, it's set to snd_max.
|
||
250 | * newreno uses this to avoid false fast retransmits.
|
||
251 | */
|
||
252 | tcp_seq snd_recover; |
||
253 | tcp_seq snd_high; |
||
254 | /* receive sequence variables */
|
||
255 | u_long rcv_wnd; /* receive window */
|
||
256 | tcp_seq rcv_nxt; /* receive next */
|
||
257 | tcp_seq rcv_up; /* receive urgent pointer */
|
||
258 | tcp_seq irs; /* initial receive sequence number */
|
||
259 | /*
|
||
260 | * Additional variables for this implementation.
|
||
261 | */
|
||
262 | /* receive variables */
|
||
263 | tcp_seq rcv_adv; /* advertised window */
|
||
264 | |||
265 | /*
|
||
266 | * retransmit variables
|
||
267 | *
|
||
268 | * snd_max
|
||
269 | * the highest sequence number we've ever sent.
|
||
270 | * used to recognize retransmits.
|
||
271 | */
|
||
272 | tcp_seq snd_max; |
||
273 | |||
274 | /* congestion control (for slow start, source quench, retransmit after loss) */
|
||
275 | u_long snd_cwnd; /* congestion-controlled window */
|
||
276 | u_long snd_ssthresh; /* snd_cwnd size threshhold for
|
||
277 | * for slow start exponential to
|
||
278 | * linear switch
|
||
279 | */
|
||
280 | /* auto-sizing variables */
|
||
281 | u_int rfbuf_cnt; /* recv buffer autoscaling byte count */
|
||
282 | uint32_t rfbuf_ts; /* recv buffer autoscaling timestamp */
|
||
283 | |||
284 | /*
|
||
285 | * transmit timing stuff. See below for scale of srtt and rttvar.
|
||
286 | * "Variance" is actually smoothed difference.
|
||
287 | */
|
||
288 | uint32_t t_rcvtime; /* time last segment received */
|
||
289 | uint32_t t_rtttime; /* time we started measuring rtt */
|
||
290 | tcp_seq t_rtseq; /* sequence number being timed */
|
||
291 | int32_t t_srtt; /* smoothed round-trip time */
|
||
292 | int32_t t_rttvar; /* variance in round-trip time */
|
||
293 | uint32_t t_rttmin; /* minimum rtt allowed */
|
||
294 | u_long max_sndwnd; /* largest window peer has offered */
|
||
295 | |||
296 | /* out-of-band data */
|
||
297 | char t_oobflags; /* have some */ |
||
298 | char t_iobc; /* input character */ |
||
299 | #define TCPOOB_HAVEDATA 0x01 |
||
300 | #define TCPOOB_HADDATA 0x02 |
||
301 | short t_softerror; /* possible error not yet reported */ |
||
302 | |||
303 | /* RFC 1323 variables */
|
||
304 | u_char snd_scale; /* window scaling for send window */
|
||
305 | u_char rcv_scale; /* window scaling for recv window */
|
||
306 | u_char request_r_scale; /* pending window scaling */
|
||
307 | u_char requested_s_scale; |
||
308 | u_int32_t ts_recent; /* timestamp echo data */
|
||
309 | u_int32_t ts_recent_age; /* when last updated */
|
||
310 | u_int32_t ts_timebase; /* our timebase */
|
||
311 | tcp_seq last_ack_sent; |
||
312 | |||
313 | /* RFC 3465 variables */
|
||
314 | u_long t_bytes_acked; /* ABC "bytes_acked" parameter */
|
||
315 | |||
316 | /* SACK stuff */
|
||
317 | #define TCP_SACK_MAX 3 |
||
318 | #define TCPSACK_NONE 0 |
||
319 | #define TCPSACK_HAVED 1 |
||
320 | u_char rcv_sack_flags; /* SACK flags. */
|
||
321 | struct sackblk rcv_dsack_block; /* RX D-SACK block. */ |
||
322 | struct ipqehead timeq; /* time sequenced queue. */ |
||
323 | struct sackhead snd_holes; /* TX SACK holes. */ |
||
324 | int snd_numholes; /* Number of TX SACK holes. */ |
||
325 | tcp_seq rcv_lastsack; /* last seq number(+1) sack'd by rcv'r*/
|
||
326 | tcp_seq sack_newdata; /* New data xmitted in this recovery
|
||
327 | episode starts at this seq number*/
|
||
328 | tcp_seq snd_fack; /* FACK TCP. Forward-most data held by
|
||
329 | peer. */
|
||
330 | |||
331 | /* CUBIC variables */
|
||
332 | ulong snd_cubic_wmax; /* W_max */
|
||
333 | ulong snd_cubic_wmax_last; /* Used for fast convergence */
|
||
334 | ulong snd_cubic_ctime; /* Last congestion time */
|
||
335 | |||
336 | /* pointer for syn cache entries*/
|
||
337 | LIST_HEAD(, syn_cache) t_sc; /* list of entries by this tcb */
|
||
338 | |||
339 | /* prediction of next mbuf when using large window sizes */
|
||
340 | struct mbuf *t_lastm; /* last mbuf that data was sent from */ |
||
341 | int t_inoff; /* data offset in previous mbuf */ |
||
342 | int t_lastoff; /* last data address in mbuf chain */ |
||
343 | int t_lastlen; /* last length read from mbuf chain */ |
||
344 | |||
345 | /* Path-MTU discovery blackhole detection */
|
||
346 | int t_mtudisc; /* perform mtudisc for this tcb */ |
||
347 | /* Path-MTU Discovery Information */
|
||
348 | u_int t_pmtud_mss_acked; /* MSS acked, lower bound for MTU */
|
||
349 | u_int t_pmtud_mtu_sent; /* MTU used, upper bound for MTU */
|
||
350 | tcp_seq t_pmtud_th_seq; /* TCP SEQ from ICMP payload */
|
||
351 | u_int t_pmtud_nextmtu; /* Advertised Next-Hop MTU from ICMP */
|
||
352 | u_short t_pmtud_ip_len; /* IP length from ICMP payload */
|
||
353 | u_short t_pmtud_ip_hl; /* IP header length from ICMP payload */
|
||
354 | |||
355 | uint8_t t_ecn_retries; /* # of ECN setup retries */
|
||
356 | |||
357 | const struct tcp_congctl *t_congctl; /* per TCB congctl algorithm */ |
||
358 | |||
359 | /* Keepalive per socket */
|
||
360 | u_int t_keepinit; |
||
361 | u_int t_keepidle; |
||
362 | u_int t_keepintvl; |
||
363 | u_int t_keepcnt; |
||
364 | u_int t_maxidle; /* t_keepcnt * t_keepintvl */
|
||
365 | |||
366 | u_int t_msl; /* MSL to use for this connexion */
|
||
367 | |||
368 | /* maintain a few stats per connection: */
|
||
369 | uint32_t t_rcvoopack; /* out-of-order packets received */
|
||
370 | uint32_t t_sndrexmitpack; /* retransmit packets sent */
|
||
371 | uint32_t t_sndzerowin; /* zero-window updates sent */
|
||
372 | }; |
||
373 | |||
374 | /*
|
||
375 | * Macros to aid ECN TCP.
|
||
376 | */
|
||
377 | #define TCP_ECN_ALLOWED(tp) (tp->t_flags & TF_ECN_PERMIT)
|
||
378 | |||
379 | /*
|
||
380 | * Macros to aid SACK/FACK TCP.
|
||
381 | */
|
||
382 | #define TCP_SACK_ENABLED(tp) (tp->t_flags & TF_WILL_SACK)
|
||
383 | #define TCP_FACK_FASTRECOV(tp) \
|
||
384 | (TCP_SACK_ENABLED(tp) && \ |
||
385 | (SEQ_GT(tp->snd_fack, tp->snd_una + tcprexmtthresh * tp->t_segsz))) |
||
386 | |||
387 | #ifdef _KERNEL
|
||
388 | /*
|
||
389 | * TCP reassembly queue locks.
|
||
390 | */
|
||
391 | static __inline int tcp_reass_lock_try (struct tcpcb *) |
||
392 | __unused; |
||
393 | static __inline void tcp_reass_unlock (struct tcpcb *) |
||
394 | __unused; |
||
395 | |||
396 | static __inline int |
||
397 | tcp_reass_lock_try(struct tcpcb *tp)
|
||
398 | { |
||
399 | int s;
|
||
400 | |||
401 | /*
|
||
402 | * Use splvm() -- we're blocking things that would cause
|
||
403 | * mbuf allocation.
|
||
404 | */
|
||
405 | s = splvm(); |
||
406 | if (tp->t_flags & TF_REASSEMBLING) {
|
||
407 | splx(s); |
||
408 | return (0); |
||
409 | } |
||
410 | tp->t_flags |= TF_REASSEMBLING; |
||
411 | splx(s); |
||
412 | return (1); |
||
413 | } |
||
414 | |||
415 | static __inline void |
||
416 | tcp_reass_unlock(struct tcpcb *tp)
|
||
417 | { |
||
418 | int s;
|
||
419 | |||
420 | s = splvm(); |
||
421 | KASSERT((tp->t_flags & TF_REASSEMBLING) != 0);
|
||
422 | tp->t_flags &= ~TF_REASSEMBLING; |
||
423 | splx(s); |
||
424 | } |
||
425 | |||
426 | #ifdef DIAGNOSTIC
|
||
427 | #define TCP_REASS_LOCK(tp) \
|
||
428 | do { \
|
||
429 | if (tcp_reass_lock_try(tp) == 0) { \ |
||
430 | printf("%s:%d: tcpcb %p reass already locked\n", \
|
||
431 | __FILE__, __LINE__, tp); \ |
||
432 | panic("tcp_reass_lock"); \
|
||
433 | } \ |
||
434 | } while (/*CONSTCOND*/ 0) |
||
435 | #define TCP_REASS_LOCK_CHECK(tp) \
|
||
436 | do { \
|
||
437 | if (((tp)->t_flags & TF_REASSEMBLING) == 0) { \ |
||
438 | printf("%s:%d: tcpcb %p reass lock not held\n", \
|
||
439 | __FILE__, __LINE__, tp); \ |
||
440 | panic("tcp reass lock check"); \
|
||
441 | } \ |
||
442 | } while (/*CONSTCOND*/ 0) |
||
443 | #else
|
||
444 | #define TCP_REASS_LOCK(tp) (void) tcp_reass_lock_try((tp)) |
||
445 | #define TCP_REASS_LOCK_CHECK(tp) /* nothing */ |
||
446 | #endif
|
||
447 | |||
448 | #define TCP_REASS_UNLOCK(tp) tcp_reass_unlock((tp))
|
||
449 | #endif /* _KERNEL */ |
||
450 | |||
451 | /*
|
||
452 | * Queue for delayed ACK processing.
|
||
453 | */
|
||
454 | #ifdef _KERNEL
|
||
455 | extern int tcp_delack_ticks; |
||
456 | void tcp_delack(void *); |
||
457 | |||
458 | #define TCP_RESTART_DELACK(tp) \
|
||
459 | callout_reset(&(tp)->t_delack_ch, tcp_delack_ticks, \ |
||
460 | tcp_delack, tp) |
||
461 | |||
462 | #define TCP_SET_DELACK(tp) \
|
||
463 | do { \
|
||
464 | if (((tp)->t_flags & TF_DELACK) == 0) { \ |
||
465 | (tp)->t_flags |= TF_DELACK; \ |
||
466 | TCP_RESTART_DELACK(tp); \ |
||
467 | } \ |
||
468 | } while (/*CONSTCOND*/0) |
||
469 | |||
470 | #define TCP_CLEAR_DELACK(tp) \
|
||
471 | do { \
|
||
472 | if ((tp)->t_flags & TF_DELACK) { \
|
||
473 | (tp)->t_flags &= ~TF_DELACK; \ |
||
474 | callout_stop(&(tp)->t_delack_ch); \ |
||
475 | } \ |
||
476 | } while (/*CONSTCOND*/0) |
||
477 | #endif /* _KERNEL */ |
||
478 | |||
479 | /*
|
||
480 | * Compute the current timestamp for a connection.
|
||
481 | */
|
||
482 | #define TCP_TIMESTAMP(tp) (tcp_now - (tp)->ts_timebase)
|
||
483 | |||
484 | /*
|
||
485 | * Handy way of passing around TCP option info.
|
||
486 | */
|
||
487 | struct tcp_opt_info {
|
||
488 | int ts_present;
|
||
489 | u_int32_t ts_val; |
||
490 | u_int32_t ts_ecr; |
||
491 | u_int16_t maxseg; |
||
492 | }; |
||
493 | |||
494 | #define TOF_SIGNATURE 0x0040 /* signature option present */ |
||
495 | #define TOF_SIGLEN 0x0080 /* sigature length valid (RFC2385) */ |
||
496 | |||
497 | /*
|
||
498 | * Data for the TCP compressed state engine.
|
||
499 | */
|
||
500 | union syn_cache_sa {
|
||
501 | struct sockaddr sa;
|
||
502 | struct sockaddr_in sin;
|
||
503 | #if 1 /*def INET6*/ |
||
504 | struct sockaddr_in6 sin6;
|
||
505 | #endif
|
||
506 | }; |
||
507 | |||
508 | struct syn_cache {
|
||
509 | TAILQ_ENTRY(syn_cache) sc_bucketq; /* link on bucket list */
|
||
510 | callout_t sc_timer; /* rexmt timer */
|
||
511 | struct route sc_route;
|
||
512 | long sc_win; /* advertised window */ |
||
513 | int sc_bucketidx; /* our bucket index */ |
||
514 | u_int32_t sc_hash; |
||
515 | u_int32_t sc_timestamp; /* timestamp from SYN */
|
||
516 | u_int32_t sc_timebase; /* our local timebase */
|
||
517 | union syn_cache_sa sc_src;
|
||
518 | union syn_cache_sa sc_dst;
|
||
519 | tcp_seq sc_irs; |
||
520 | tcp_seq sc_iss; |
||
521 | u_int sc_rxtcur; /* current rxt timeout */
|
||
522 | u_int sc_rxttot; /* total time spend on queues */
|
||
523 | u_short sc_rxtshift; /* for computing backoff */
|
||
524 | u_short sc_flags; |
||
525 | |||
526 | #define SCF_UNREACH 0x0001 /* we've had an unreach error */ |
||
527 | #define SCF_TIMESTAMP 0x0002 /* peer will do timestamps */ |
||
528 | #define SCF_DEAD 0x0004 /* this entry to be released */ |
||
529 | #define SCF_SACK_PERMIT 0x0008 /* peer will do SACK */ |
||
530 | #define SCF_ECN_PERMIT 0x0010 /* peer will do ECN */ |
||
531 | #define SCF_SIGNATURE 0x40 /* send MD5 digests */ |
||
532 | |||
533 | struct mbuf *sc_ipopts; /* IP options */ |
||
534 | u_int16_t sc_peermaxseg; |
||
535 | u_int16_t sc_ourmaxseg; |
||
536 | u_int8_t sc_request_r_scale : 4,
|
||
537 | sc_requested_s_scale : 4;
|
||
538 | |||
539 | struct tcpcb *sc_tp; /* tcb for listening socket */ |
||
540 | LIST_ENTRY(syn_cache) sc_tpq; /* list of entries by same tp */
|
||
541 | }; |
||
542 | |||
543 | struct syn_cache_head {
|
||
544 | TAILQ_HEAD(, syn_cache) sch_bucket; /* bucket entries */
|
||
545 | u_short sch_length; /* # entries in bucket */
|
||
546 | }; |
||
547 | |||
548 | #define intotcpcb(ip) ((struct tcpcb *)(ip)->inp_ppcb) |
||
549 | #ifdef INET6
|
||
550 | #define in6totcpcb(ip) ((struct tcpcb *)(ip)->in6p_ppcb) |
||
551 | #endif
|
||
552 | #ifndef INET6
|
||
553 | #define sototcpcb(so) (intotcpcb(sotoinpcb(so)))
|
||
554 | #else
|
||
555 | #define sototcpcb(so) (((so)->so_proto->pr_domain->dom_family == AF_INET) \
|
||
556 | ? intotcpcb(sotoinpcb(so)) \ |
||
557 | : in6totcpcb(sotoin6pcb(so))) |
||
558 | #endif
|
||
559 | |||
560 | /*
|
||
561 | * See RFC2988 for a discussion of RTO calculation; comments assume
|
||
562 | * familiarity with that document.
|
||
563 | *
|
||
564 | * The smoothed round-trip time and estimated variance are stored as
|
||
565 | * fixed point numbers. Historically, srtt was scaled by
|
||
566 | * TCP_RTT_SHIFT bits, and rttvar by TCP_RTTVAR_SHIFT bits. Because
|
||
567 | * the values coincide with the alpha and beta parameters suggested
|
||
568 | * for RTO calculation (1/8 for srtt, 1/4 for rttvar), the combination
|
||
569 | * of computing 1/8 of the new value and transforming it to the
|
||
570 | * fixed-point representation required zero instructions. However,
|
||
571 | * the storage representations no longer coincide with the alpha/beta
|
||
572 | * shifts; instead, more fractional bits are present.
|
||
573 | *
|
||
574 | * The storage representation of srtt is 1/32 slow ticks, or 1/64 s.
|
||
575 | * (The assumption that a slow tick is 500 ms should not be present in
|
||
576 | * the code.)
|
||
577 | *
|
||
578 | * The storage representation of rttvar is 1/16 slow ticks, or 1/32 s.
|
||
579 | * There may be some confusion about this in the code.
|
||
580 | *
|
||
581 | * For historical reasons, these scales are also used in smoothing the
|
||
582 | * average (smoothed = (1/scale)sample + ((scale-1)/scale)smoothed).
|
||
583 | * This results in alpha of 0.125 and beta of 0.25, following RFC2988
|
||
584 | * section 2.3
|
||
585 | *
|
||
586 | * XXX Change SHIFT values to LGWEIGHT and REP_SHIFT, and adjust
|
||
587 | * the code to use the correct ones.
|
||
588 | */
|
||
589 | #define TCP_RTT_SHIFT 3 /* shift for srtt; 3 bits frac. */ |
||
590 | #define TCP_RTTVAR_SHIFT 2 /* multiplier for rttvar; 2 bits */ |
||
591 | |||
592 | /*
|
||
593 | * Compute TCP retransmission timer, following RFC2988.
|
||
594 | * This macro returns a value in slow timeout ticks.
|
||
595 | *
|
||
596 | * Section 2.2 requires that the RTO value be
|
||
597 | * srtt + max(G, 4*RTTVAR)
|
||
598 | * where G is the clock granularity.
|
||
599 | *
|
||
600 | * This comment has not necessarily been updated for the new storage
|
||
601 | * representation:
|
||
602 | *
|
||
603 | * Because of the way we do the smoothing, srtt and rttvar
|
||
604 | * will each average +1/2 tick of bias. When we compute
|
||
605 | * the retransmit timer, we want 1/2 tick of rounding and
|
||
606 | * 1 extra tick because of +-1/2 tick uncertainty in the
|
||
607 | * firing of the timer. The bias will give us exactly the
|
||
608 | * 1.5 tick we need. But, because the bias is
|
||
609 | * statistical, we have to test that we don't drop below
|
||
610 | * the minimum feasible timer (which is 2 ticks).
|
||
611 | * This macro assumes that the value of 1<<TCP_RTTVAR_SHIFT
|
||
612 | * is the same as the multiplier for rttvar.
|
||
613 | *
|
||
614 | * This macro appears to be wrong; it should be checking rttvar*4 in
|
||
615 | * ticks and making sure we use 1 instead if rttvar*4 rounds to 0. It
|
||
616 | * appears to be treating srtt as being in the old storage
|
||
617 | * representation, resulting in a factor of 4 extra.
|
||
618 | */
|
||
619 | #define TCP_REXMTVAL(tp) \
|
||
620 | ((((tp)->t_srtt >> TCP_RTT_SHIFT) + (tp)->t_rttvar) >> 2)
|
||
621 | |||
622 | /*
|
||
623 | * Compute the initial window for slow start.
|
||
624 | */
|
||
625 | #define TCP_INITIAL_WINDOW(iw, segsz) \
|
||
626 | min((iw) * (segsz), max(2 * (segsz), tcp_init_win_max[(iw)]))
|
||
627 | |||
628 | /*
|
||
629 | * TCP statistics.
|
||
630 | * Each counter is an unsigned 64-bit value.
|
||
631 | *
|
||
632 | * Many of these should be kept per connection, but that's inconvenient
|
||
633 | * at the moment.
|
||
634 | */
|
||
635 | #define TCP_STAT_CONNATTEMPT 0 /* connections initiated */ |
||
636 | #define TCP_STAT_ACCEPTS 1 /* connections accepted */ |
||
637 | #define TCP_STAT_CONNECTS 2 /* connections established */ |
||
638 | #define TCP_STAT_DROPS 3 /* connections dropped */ |
||
639 | #define TCP_STAT_CONNDROPS 4 /* embryonic connections dropped */ |
||
640 | #define TCP_STAT_CLOSED 5 /* conn. closed (includes drops) */ |
||
641 | #define TCP_STAT_SEGSTIMED 6 /* segs where we tried to get rtt */ |
||
642 | #define TCP_STAT_RTTUPDATED 7 /* times we succeeded */ |
||
643 | #define TCP_STAT_DELACK 8 /* delayed ACKs sent */ |
||
644 | #define TCP_STAT_TIMEOUTDROP 9 /* conn. dropped in rxmt timeout */ |
||
645 | #define TCP_STAT_REXMTTIMEO 10 /* retransmit timeouts */ |
||
646 | #define TCP_STAT_PERSISTTIMEO 11 /* persist timeouts */ |
||
647 | #define TCP_STAT_KEEPTIMEO 12 /* keepalive timeouts */ |
||
648 | #define TCP_STAT_KEEPPROBE 13 /* keepalive probes sent */ |
||
649 | #define TCP_STAT_KEEPDROPS 14 /* connections dropped in keepalive */ |
||
650 | #define TCP_STAT_PERSISTDROPS 15 /* connections dropped in persist */ |
||
651 | #define TCP_STAT_CONNSDRAINED 16 /* connections drained due to memory |
||
652 | shortage */
|
||
653 | #define TCP_STAT_PMTUBLACKHOLE 17 /* PMTUD blackhole detected */ |
||
654 | #define TCP_STAT_SNDTOTAL 18 /* total packets sent */ |
||
655 | #define TCP_STAT_SNDPACK 19 /* data packlets sent */ |
||
656 | #define TCP_STAT_SNDBYTE 20 /* data bytes sent */ |
||
657 | #define TCP_STAT_SNDREXMITPACK 21 /* data packets retransmitted */ |
||
658 | #define TCP_STAT_SNDREXMITBYTE 22 /* data bytes retransmitted */ |
||
659 | #define TCP_STAT_SNDACKS 23 /* ACK-only packets sent */ |
||
660 | #define TCP_STAT_SNDPROBE 24 /* window probes sent */ |
||
661 | #define TCP_STAT_SNDURG 25 /* packets sent with URG only */ |
||
662 | #define TCP_STAT_SNDWINUP 26 /* window update-only packets sent */ |
||
663 | #define TCP_STAT_SNDCTRL 27 /* control (SYN|FIN|RST) packets sent */ |
||
664 | #define TCP_STAT_RCVTOTAL 28 /* total packets received */ |
||
665 | #define TCP_STAT_RCVPACK 29 /* packets received in sequence */ |
||
666 | #define TCP_STAT_RCVBYTE 30 /* bytes received in sequence */ |
||
667 | #define TCP_STAT_RCVBADSUM 31 /* packets received with cksum errs */ |
||
668 | #define TCP_STAT_RCVBADOFF 32 /* packets received with bad offset */ |
||
669 | #define TCP_STAT_RCVMEMDROP 33 /* packets dropped for lack of memory */ |
||
670 | #define TCP_STAT_RCVSHORT 34 /* packets received too short */ |
||
671 | #define TCP_STAT_RCVDUPPACK 35 /* duplicate-only packets received */ |
||
672 | #define TCP_STAT_RCVDUPBYTE 36 /* duplicate-only bytes received */ |
||
673 | #define TCP_STAT_RCVPARTDUPPACK 37 /* packets with some duplicate data */ |
||
674 | #define TCP_STAT_RCVPARTDUPBYTE 38 /* dup. bytes in part-dup. packets */ |
||
675 | #define TCP_STAT_RCVOOPACK 39 /* out-of-order packets received */ |
||
676 | #define TCP_STAT_RCVOOBYTE 40 /* out-of-order bytes received */ |
||
677 | #define TCP_STAT_RCVPACKAFTERWIN 41 /* packets with data after window */ |
||
678 | #define TCP_STAT_RCVBYTEAFTERWIN 42 /* bytes received after window */ |
||
679 | #define TCP_STAT_RCVAFTERCLOSE 43 /* packets received after "close" */ |
||
680 | #define TCP_STAT_RCVWINPROBE 44 /* rcvd window probe packets */ |
||
681 | #define TCP_STAT_RCVDUPACK 45 /* rcvd duplicate ACKs */ |
||
682 | #define TCP_STAT_RCVACKTOOMUCH 46 /* rcvd ACKs for unsent data */ |
||
683 | #define TCP_STAT_RCVACKPACK 47 /* rcvd ACK packets */ |
||
684 | #define TCP_STAT_RCVACKBYTE 48 /* bytes ACKed by rcvd ACKs */ |
||
685 | #define TCP_STAT_RCVWINUPD 49 /* rcvd window update packets */ |
||
686 | #define TCP_STAT_PAWSDROP 50 /* segments dropped due to PAWS */ |
||
687 | #define TCP_STAT_PREDACK 51 /* times hdr predict OK for ACKs */ |
||
688 | #define TCP_STAT_PREDDAT 52 /* times hdr predict OK for data pkts */ |
||
689 | #define TCP_STAT_PCBHASHMISS 53 /* input packets missing PCB hash */ |
||
690 | #define TCP_STAT_NOPORT 54 /* no socket on port */ |
||
691 | #define TCP_STAT_BADSYN 55 /* received ACK for which we have |
||
692 | no SYN in compressed state */
|
||
693 | #define TCP_STAT_DELAYED_FREE 56 /* delayed pool_put() of tcpcb */ |
||
694 | #define TCP_STAT_SC_ADDED 57 /* # of sc entries added */ |
||
695 | #define TCP_STAT_SC_COMPLETED 58 /* # of sc connections completed */ |
||
696 | #define TCP_STAT_SC_TIMED_OUT 59 /* # of sc entries timed out */ |
||
697 | #define TCP_STAT_SC_OVERFLOWED 60 /* # of sc drops due to overflow */ |
||
698 | #define TCP_STAT_SC_RESET 61 /* # of sc drops due to RST */ |
||
699 | #define TCP_STAT_SC_UNREACH 62 /* # of sc drops due to ICMP unreach */ |
||
700 | #define TCP_STAT_SC_BUCKETOVERFLOW 63 /* # of sc drops due to bucket ovflow */ |
||
701 | #define TCP_STAT_SC_ABORTED 64 /* # of sc entries aborted (no mem) */ |
||
702 | #define TCP_STAT_SC_DUPESYN 65 /* # of duplicate SYNs received */ |
||
703 | #define TCP_STAT_SC_DROPPED 66 /* # of SYNs dropped (no route/mem) */ |
||
704 | #define TCP_STAT_SC_COLLISIONS 67 /* # of sc hash collisions */ |
||
705 | #define TCP_STAT_SC_RETRANSMITTED 68 /* # of sc retransmissions */ |
||
706 | #define TCP_STAT_SC_DELAYED_FREE 69 /* # of delayed pool_put()s */ |
||
707 | #define TCP_STAT_SELFQUENCH 70 /* # of ENOBUFS we get on output */ |
||
708 | #define TCP_STAT_BADSIG 71 /* # of drops due to bad signature */ |
||
709 | #define TCP_STAT_GOODSIG 72 /* # of packets with good signature */ |
||
710 | #define TCP_STAT_ECN_SHS 73 /* # of successful ECN handshakes */ |
||
711 | #define TCP_STAT_ECN_CE 74 /* # of packets with CE bit */ |
||
712 | #define TCP_STAT_ECN_ECT 75 /* # of packets with ECT(0) bit */ |
||
713 | |||
714 | #define TCP_NSTATS 76 |
||
715 | |||
716 | /*
|
||
717 | * Names for TCP sysctl objects.
|
||
718 | */
|
||
719 | #define TCPCTL_RFC1323 1 /* RFC1323 timestamps/scaling */ |
||
720 | #define TCPCTL_SENDSPACE 2 /* default send buffer */ |
||
721 | #define TCPCTL_RECVSPACE 3 /* default recv buffer */ |
||
722 | #define TCPCTL_MSSDFLT 4 /* default seg size */ |
||
723 | #define TCPCTL_SYN_CACHE_LIMIT 5 /* max size of comp. state engine */ |
||
724 | #define TCPCTL_SYN_BUCKET_LIMIT 6 /* max size of hash bucket */ |
||
725 | #if 0 /*obsoleted*/
|
||
726 | #define TCPCTL_SYN_CACHE_INTER 7 /* interval of comp. state timer */
|
||
727 | #endif
|
||
728 | #define TCPCTL_INIT_WIN 8 /* initial window */ |
||
729 | #define TCPCTL_MSS_IFMTU 9 /* mss from interface, not in_maxmtu */ |
||
730 | #define TCPCTL_SACK 10 /* RFC2018 selective acknowledgement */ |
||
731 | #define TCPCTL_WSCALE 11 /* RFC1323 window scaling */ |
||
732 | #define TCPCTL_TSTAMP 12 /* RFC1323 timestamps */ |
||
733 | #define TCPCTL_COMPAT_42 13 /* 4.2BSD TCP bug work-arounds */ |
||
734 | #define TCPCTL_CWM 14 /* Congestion Window Monitoring */ |
||
735 | #define TCPCTL_CWM_BURSTSIZE 15 /* burst size allowed by CWM */ |
||
736 | #define TCPCTL_ACK_ON_PUSH 16 /* ACK immediately on PUSH */ |
||
737 | #define TCPCTL_KEEPIDLE 17 /* keepalive idle time */ |
||
738 | #define TCPCTL_KEEPINTVL 18 /* keepalive probe interval */ |
||
739 | #define TCPCTL_KEEPCNT 19 /* keepalive count */ |
||
740 | #define TCPCTL_SLOWHZ 20 /* PR_SLOWHZ (read-only) */ |
||
741 | #define TCPCTL_NEWRENO 21 /* NewReno Congestion Control */ |
||
742 | #define TCPCTL_LOG_REFUSED 22 /* Log refused connections */ |
||
743 | #if 0 /*obsoleted*/
|
||
744 | #define TCPCTL_RSTRATELIMIT 23 /* RST rate limit */
|
||
745 | #endif
|
||
746 | #define TCPCTL_RSTPPSLIMIT 24 /* RST pps limit */ |
||
747 | #define TCPCTL_DELACK_TICKS 25 /* # ticks to delay ACK */ |
||
748 | #define TCPCTL_INIT_WIN_LOCAL 26 /* initial window for local nets */ |
||
749 | #define TCPCTL_IDENT 27 /* rfc 931 identd */ |
||
750 | #define TCPCTL_ACKDROPRATELIMIT 28 /* SYN/RST -> ACK rate limit */ |
||
751 | #define TCPCTL_LOOPBACKCKSUM 29 /* do TCP checksum on loopback */ |
||
752 | #define TCPCTL_STATS 30 /* TCP statistics */ |
||
753 | #define TCPCTL_DEBUG 31 /* TCP debug sockets */ |
||
754 | #define TCPCTL_DEBX 32 /* # of tcp debug sockets */ |
||
755 | #define TCPCTL_DROP 33 /* drop tcp connection */ |
||
756 | #define TCPCTL_MSL 34 /* Max Segment Life */ |
||
757 | #define TCPCTL_MAXID 35 |
||
758 | |||
759 | #define TCPCTL_NAMES { \
|
||
760 | { 0, 0 }, \ |
||
761 | { "rfc1323", CTLTYPE_INT }, \
|
||
762 | { "sendspace", CTLTYPE_INT }, \
|
||
763 | { "recvspace", CTLTYPE_INT }, \
|
||
764 | { "mssdflt", CTLTYPE_INT }, \
|
||
765 | { "syn_cache_limit", CTLTYPE_INT }, \
|
||
766 | { "syn_bucket_limit", CTLTYPE_INT }, \
|
||
767 | { 0, 0 },\ |
||
768 | { "init_win", CTLTYPE_INT }, \
|
||
769 | { "mss_ifmtu", CTLTYPE_INT }, \
|
||
770 | { "sack", CTLTYPE_INT }, \
|
||
771 | { "win_scale", CTLTYPE_INT }, \
|
||
772 | { "timestamps", CTLTYPE_INT }, \
|
||
773 | { "compat_42", CTLTYPE_INT }, \
|
||
774 | { "cwm", CTLTYPE_INT }, \
|
||
775 | { "cwm_burstsize", CTLTYPE_INT }, \
|
||
776 | { "ack_on_push", CTLTYPE_INT }, \
|
||
777 | { "keepidle", CTLTYPE_INT }, \
|
||
778 | { "keepintvl", CTLTYPE_INT }, \
|
||
779 | { "keepcnt", CTLTYPE_INT }, \
|
||
780 | { "slowhz", CTLTYPE_INT }, \
|
||
781 | { 0, 0 }, \ |
||
782 | { "log_refused",CTLTYPE_INT }, \
|
||
783 | { 0, 0 }, \ |
||
784 | { "rstppslimit", CTLTYPE_INT }, \
|
||
785 | { "delack_ticks", CTLTYPE_INT }, \
|
||
786 | { "init_win_local", CTLTYPE_INT }, \
|
||
787 | { "ident", CTLTYPE_STRUCT }, \
|
||
788 | { "ackdropppslimit", CTLTYPE_INT }, \
|
||
789 | { "do_loopback_cksum", CTLTYPE_INT }, \
|
||
790 | { "stats", CTLTYPE_STRUCT }, \
|
||
791 | { "debug", CTLTYPE_STRUCT }, \
|
||
792 | { "debx", CTLTYPE_INT }, \
|
||
793 | { "drop", CTLTYPE_STRUCT }, \
|
||
794 | { "msl", CTLTYPE_INT }, \
|
||
795 | } |
||
796 | |||
797 | #ifdef _KERNEL
|
||
798 | |||
799 | extern struct inpcbtable tcbtable; /* head of queue of active tcpcb's */ |
||
800 | extern const struct pr_usrreqs tcp_usrreqs; |
||
801 | |||
802 | extern u_int32_t tcp_now; /* for RFC 1323 timestamps */ |
||
803 | extern int tcp_do_rfc1323; /* enabled/disabled? */ |
||
804 | extern int tcp_do_sack; /* SACK enabled/disabled? */ |
||
805 | extern int tcp_do_win_scale; /* RFC1323 window scaling enabled/disabled? */ |
||
806 | extern int tcp_do_timestamps; /* RFC1323 timestamps enabled/disabled? */ |
||
807 | extern int tcp_mssdflt; /* default seg size */ |
||
808 | extern int tcp_minmss; /* minimal seg size */ |
||
809 | extern int tcp_msl; /* max segment life */ |
||
810 | extern int tcp_init_win; /* initial window */ |
||
811 | extern int tcp_init_win_local; /* initial window for local nets */ |
||
812 | extern int tcp_init_win_max[11];/* max sizes for values of tcp_init_win_* */ |
||
813 | extern int tcp_mss_ifmtu; /* take MSS from interface, not in_maxmtu */ |
||
814 | extern int tcp_compat_42; /* work around ancient broken TCP peers */ |
||
815 | extern int tcp_cwm; /* enable Congestion Window Monitoring */ |
||
816 | extern int tcp_cwm_burstsize; /* burst size allowed by CWM */ |
||
817 | extern int tcp_ack_on_push; /* ACK immediately on PUSH */ |
||
818 | extern int tcp_syn_cache_limit; /* max entries for compressed state engine */ |
||
819 | extern int tcp_syn_bucket_limit;/* max entries per hash bucket */ |
||
820 | extern int tcp_log_refused; /* log refused connections */ |
||
821 | extern int tcp_do_ecn; /* TCP ECN enabled/disabled? */ |
||
822 | extern int tcp_ecn_maxretries; /* Max ECN setup retries */ |
||
823 | extern int tcp_do_rfc1948; /* ISS by cryptographic hash */ |
||
824 | extern int tcp_sack_tp_maxholes; /* Max holes per connection. */ |
||
825 | extern int tcp_sack_globalmaxholes; /* Max holes per system. */ |
||
826 | extern int tcp_sack_globalholes; /* Number of holes present. */ |
||
827 | extern int tcp_do_abc; /* RFC3465 ABC enabled/disabled? */ |
||
828 | extern int tcp_abc_aggressive; /* 1: L=2*SMSS 0: L=1*SMSS */ |
||
829 | |||
830 | extern int tcp_msl_enable; /* enable TIME_WAIT truncation */ |
||
831 | extern int tcp_msl_loop; /* MSL for loopback */ |
||
832 | extern int tcp_msl_local; /* MSL for 'local' */ |
||
833 | extern int tcp_msl_remote; /* MSL otherwise */ |
||
834 | extern int tcp_msl_remote_threshold; /* RTT threshold */ |
||
835 | extern int tcp_rttlocal; /* Use RTT to decide who's 'local' */ |
||
836 | extern int tcp4_vtw_enable; |
||
837 | extern int tcp6_vtw_enable; |
||
838 | extern int tcp_vtw_was_enabled; |
||
839 | extern int tcp_vtw_entries; |
||
840 | |||
841 | extern int tcp_rst_ppslim; |
||
842 | extern int tcp_ackdrop_ppslim; |
||
843 | |||
844 | extern int tcp_syn_cache_size; |
||
845 | extern struct syn_cache_head tcp_syn_cache[]; |
||
846 | extern u_long syn_cache_count;
|
||
847 | |||
848 | #ifdef MBUFTRACE
|
||
849 | extern struct mowner tcp_rx_mowner; |
||
850 | extern struct mowner tcp_tx_mowner; |
||
851 | extern struct mowner tcp_reass_mowner; |
||
852 | extern struct mowner tcp_sock_mowner; |
||
853 | extern struct mowner tcp_sock_rx_mowner; |
||
854 | extern struct mowner tcp_sock_tx_mowner; |
||
855 | extern struct mowner tcp_mowner; |
||
856 | #endif
|
||
857 | |||
858 | extern int tcp_do_autorcvbuf; |
||
859 | extern int tcp_autorcvbuf_inc; |
||
860 | extern int tcp_autorcvbuf_max; |
||
861 | extern int tcp_do_autosndbuf; |
||
862 | extern int tcp_autosndbuf_inc; |
||
863 | extern int tcp_autosndbuf_max; |
||
864 | |||
865 | |||
866 | #define TCPCTL_VARIABLES { \
|
||
867 | { 0 }, \
|
||
868 | { 1, 0, &tcp_do_rfc1323 }, \ |
||
869 | { 1, 0, &tcp_sendspace }, \ |
||
870 | { 1, 0, &tcp_recvspace }, \ |
||
871 | { 1, 0, &tcp_mssdflt }, \ |
||
872 | { 1, 0, &tcp_syn_cache_limit }, \ |
||
873 | { 1, 0, &tcp_syn_bucket_limit }, \ |
||
874 | { 0 }, \
|
||
875 | { 1, 0, &tcp_init_win }, \ |
||
876 | { 1, 0, &tcp_mss_ifmtu }, \ |
||
877 | { 1, 0, &tcp_do_sack }, \ |
||
878 | { 1, 0, &tcp_do_win_scale }, \ |
||
879 | { 1, 0, &tcp_do_timestamps }, \ |
||
880 | { 1, 0, &tcp_compat_42 }, \ |
||
881 | { 1, 0, &tcp_cwm }, \ |
||
882 | { 1, 0, &tcp_cwm_burstsize }, \ |
||
883 | { 1, 0, &tcp_ack_on_push }, \ |
||
884 | { 1, 0, &tcp_keepidle }, \ |
||
885 | { 1, 0, &tcp_keepintvl }, \ |
||
886 | { 1, 0, &tcp_keepcnt }, \ |
||
887 | { 1, 1, 0, PR_SLOWHZ }, \ |
||
888 | { 0 }, \
|
||
889 | { 1, 0, &tcp_log_refused }, \ |
||
890 | { 0 }, \
|
||
891 | { 1, 0, &tcp_rst_ppslim }, \ |
||
892 | { 1, 0, &tcp_delack_ticks }, \ |
||
893 | { 1, 0, &tcp_init_win_local }, \ |
||
894 | { 1, 0, &tcp_ackdrop_ppslim }, \ |
||
895 | } |
||
896 | |||
897 | struct secasvar;
|
||
898 | |||
899 | void tcp_canceltimers(struct tcpcb *); |
||
900 | struct tcpcb *
|
||
901 | tcp_close(struct tcpcb *);
|
||
902 | int tcp_isdead(struct tcpcb *); |
||
903 | #ifdef INET6
|
||
904 | void *tcp6_ctlinput(int, const struct sockaddr *, void *); |
||
905 | #endif
|
||
906 | void *tcp_ctlinput(int, const struct sockaddr *, void *); |
||
907 | int tcp_ctloutput(int, struct socket *, struct sockopt *); |
||
908 | struct tcpcb *
|
||
909 | tcp_disconnect1(struct tcpcb *);
|
||
910 | struct tcpcb *
|
||
911 | tcp_drop(struct tcpcb *, int); |
||
912 | #ifdef TCP_SIGNATURE
|
||
913 | int tcp_signature_apply(void *, void *, u_int); |
||
914 | struct secasvar *tcp_signature_getsav(struct mbuf *, struct tcphdr *); |
||
915 | int tcp_signature(struct mbuf *, struct tcphdr *, int, struct secasvar *, |
||
916 | char *);
|
||
917 | #endif
|
||
918 | void tcp_drain(void); |
||
919 | void tcp_drainstub(void); |
||
920 | void tcp_established(struct tcpcb *); |
||
921 | void tcp_init(void); |
||
922 | void tcp_init_common(unsigned); |
||
923 | #ifdef INET6
|
||
924 | int tcp6_input(struct mbuf **, int *, int); |
||
925 | #endif
|
||
926 | void tcp_input(struct mbuf *, ...); |
||
927 | u_int tcp_hdrsz(struct tcpcb *);
|
||
928 | u_long tcp_mss_to_advertise(const struct ifnet *, int); |
||
929 | void tcp_mss_from_peer(struct tcpcb *, int); |
||
930 | void tcp_tcpcb_template(void); |
||
931 | struct tcpcb *
|
||
932 | tcp_newtcpcb(int, void *); |
||
933 | void tcp_notify(struct inpcb *, int); |
||
934 | #ifdef INET6
|
||
935 | void tcp6_notify(struct in6pcb *, int); |
||
936 | #endif
|
||
937 | u_int tcp_optlen(struct tcpcb *);
|
||
938 | int tcp_output(struct tcpcb *); |
||
939 | void tcp_pulloutofband(struct socket *, |
||
940 | struct tcphdr *, struct mbuf *, int); |
||
941 | void tcp_quench(struct inpcb *, int); |
||
942 | #ifdef INET6
|
||
943 | void tcp6_quench(struct in6pcb *, int); |
||
944 | #endif
|
||
945 | void tcp_mtudisc(struct inpcb *, int); |
||
946 | #ifdef INET6
|
||
947 | void tcp6_mtudisc_callback(struct in6_addr *); |
||
948 | #endif
|
||
949 | |||
950 | void tcpipqent_init(void); |
||
951 | struct ipqent *tcpipqent_alloc(void); |
||
952 | void tcpipqent_free(struct ipqent *); |
||
953 | |||
954 | int tcp_respond(struct tcpcb *, struct mbuf *, struct mbuf *, |
||
955 | struct tcphdr *, tcp_seq, tcp_seq, int); |
||
956 | void tcp_rmx_rtt(struct tcpcb *); |
||
957 | void tcp_setpersist(struct tcpcb *); |
||
958 | #ifdef TCP_SIGNATURE
|
||
959 | int tcp_signature_compute(struct mbuf *, struct tcphdr *, int, int, |
||
960 | int, u_char *, u_int);
|
||
961 | #endif
|
||
962 | void tcp_slowtimo(void *); |
||
963 | extern callout_t tcp_slowtimo_ch;
|
||
964 | void tcp_fasttimo(void); |
||
965 | struct mbuf *
|
||
966 | tcp_template(struct tcpcb *);
|
||
967 | void tcp_trace(short, short, struct tcpcb *, struct mbuf *, int); |
||
968 | struct tcpcb *
|
||
969 | tcp_usrclosed(struct tcpcb *);
|
||
970 | void tcp_usrreq_init(void); |
||
971 | void tcp_xmit_timer(struct tcpcb *, uint32_t); |
||
972 | tcp_seq tcp_new_iss(struct tcpcb *, tcp_seq);
|
||
973 | tcp_seq tcp_new_iss1(void *, void *, u_int16_t, u_int16_t, size_t, |
||
974 | tcp_seq); |
||
975 | |||
976 | void tcp_sack_init(void); |
||
977 | void tcp_new_dsack(struct tcpcb *, tcp_seq, u_int32_t); |
||
978 | void tcp_sack_option(struct tcpcb *, const struct tcphdr *, |
||
979 | const u_char *, int); |
||
980 | void tcp_del_sackholes(struct tcpcb *, const struct tcphdr *); |
||
981 | void tcp_free_sackholes(struct tcpcb *); |
||
982 | void tcp_sack_adjust(struct tcpcb *tp); |
||
983 | struct sackhole *tcp_sack_output(struct tcpcb *tp, int *sack_bytes_rexmt); |
||
984 | int tcp_sack_numblks(const struct tcpcb *); |
||
985 | #define TCP_SACK_OPTLEN(nblks) ((nblks) * 8 + 2 + 2) |
||
986 | |||
987 | void tcp_statinc(u_int);
|
||
988 | void tcp_statadd(u_int, uint64_t);
|
||
989 | |||
990 | int syn_cache_add(struct sockaddr *, struct sockaddr *, |
||
991 | struct tcphdr *, unsigned int, struct socket *, |
||
992 | struct mbuf *, u_char *, int, struct tcp_opt_info *); |
||
993 | void syn_cache_unreach(const struct sockaddr *, const struct sockaddr *, |
||
994 | struct tcphdr *);
|
||
995 | struct socket *syn_cache_get(struct sockaddr *, struct sockaddr *, |
||
996 | struct tcphdr *, unsigned int, unsigned int, |
||
997 | struct socket *so, struct mbuf *); |
||
998 | void syn_cache_init(void); |
||
999 | void syn_cache_insert(struct syn_cache *, struct tcpcb *); |
||
1000 | struct syn_cache *syn_cache_lookup(const struct sockaddr *, const struct sockaddr *, |
||
1001 | struct syn_cache_head **);
|
||
1002 | void syn_cache_reset(struct sockaddr *, struct sockaddr *, |
||
1003 | struct tcphdr *);
|
||
1004 | int syn_cache_respond(struct syn_cache *, struct mbuf *); |
||
1005 | void syn_cache_timer(void *); |
||
1006 | void syn_cache_cleanup(struct tcpcb *); |
||
1007 | |||
1008 | int tcp_input_checksum(int, struct mbuf *, const struct tcphdr *, int, int, |
||
1009 | int);
|
||
1010 | #endif
|
||
1011 | |||
1012 | #endif /* !_NETINET_TCP_VAR_H_ */ |