11553 Want pluggable TCP congestion control algorithms
Portions contributed by: Cody Peter Mello <cody.mello@joyent.com>
Reviewed by: Dan McDonald <danmcd@joyent.com>
Reviewed by: Robert Mustacchi <robert.mustacchi@joyent.com>
1 /*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
24 */
25
26 #ifndef _INET_TCP_STACK_H
27 #define _INET_TCP_STACK_H
28
29 #include <sys/netstack.h>
30 #include <inet/ip.h>
31 #include <inet/ipdrop.h>
32 #include <inet/tcp_stats.h>
33 #include <sys/sunddi.h>
34 #include <sys/sunldi.h>
35
36 #ifdef __cplusplus
37 extern "C" {
38 #endif
39
40 #ifdef _KERNEL
41
42 /*
43 * TCP stack instances
44 */
45 struct tcp_stack {
46 netstack_t *tcps_netstack; /* Common netstack */
47
48 /*
49 * Extra privileged ports. In host byte order.
50 * Protected by tcp_epriv_port_lock.
51 */
52 #define TCP_NUM_EPRIV_PORTS 64
53 int tcps_g_num_epriv_ports;
54 in_port_t tcps_g_epriv_ports[TCP_NUM_EPRIV_PORTS];
55 kmutex_t tcps_epriv_port_lock;
56
57 /*
58 * The smallest anonymous port in the priviledged port range which TCP
59 * looks for free port. Use in the option TCP_ANONPRIVBIND.
60 */
61 in_port_t tcps_min_anonpriv_port;
62
63 /* holds the tcp tunables */
64 struct mod_prop_info_s *tcps_propinfo_tbl;
65
66 /* Hint not protected by any lock */
67 uint_t tcps_next_port_to_try;
68
69 /* TCP bind hash list - all tcp_t with state >= BOUND. */
70 struct tf_s *tcps_bind_fanout;
71
72 /* TCP queue hash list - all tcp_t in case they will be an acceptor. */
73 struct tf_s *tcps_acceptor_fanout;
74
75 /*
76 * MIB-2 stuff for SNMP
77 * Note: tcpInErrs {tcp 15} is accumulated in ip.c
78 */
79 kstat_t *tcps_mibkp; /* kstat exporting mib2_tcp_t data */
80 kstat_t *tcps_kstat; /* kstat exporting tcp_stat_t data */
81
82 uint32_t tcps_iss_incr_extra;
83 /* Incremented for each connection */
84 kmutex_t tcps_iss_key_lock;
85 MD5_CTX tcps_iss_key;
86
87 /* Packet dropper for TCP IPsec policy drops. */
88 ipdropper_t tcps_dropper;
89
90 /*
91 * These two variables control the rate for TCP to generate RSTs in
92 * response to segments not belonging to any connections. We limit
93 * TCP to sent out tcp_rst_sent_rate (ndd param) number of RSTs in
94 * each 1 second interval. This is to protect TCP against DoS attack.
95 */
96 int64_t tcps_last_rst_intrvl;
97 uint32_t tcps_rst_cnt;
98
99 ldi_ident_t tcps_ldi_ident;
100
101 /* Used to synchronize access when reclaiming memory */
102 mblk_t *tcps_ixa_cleanup_mp;
103 kmutex_t tcps_ixa_cleanup_lock;
104 kcondvar_t tcps_ixa_cleanup_ready_cv;
105 kcondvar_t tcps_ixa_cleanup_done_cv;
106
107 /* Variables for handling kmem reclaim call back. */
108 kmutex_t tcps_reclaim_lock;
109 boolean_t tcps_reclaim;
110 timeout_id_t tcps_reclaim_tid;
111 uint32_t tcps_reclaim_period;
112
113 /* Listener connection limit configuration. */
114 kmutex_t tcps_listener_conf_lock;
115 list_t tcps_listener_conf;
116
117 /*
118 * Per CPU stats
119 *
120 * tcps_sc: array of pointer to per CPU stats. The i-th element in the
121 * array represents the stats of the CPU with cpu_seqid.
122 * tcps_sc_cnt: number of CPU stats in the tcps_sc array.
123 */
124 tcp_stats_cpu_t **tcps_sc;
125 int tcps_sc_cnt;
126 };
127
128 typedef struct tcp_stack tcp_stack_t;
129
130 #endif /* _KERNEL */
131 #ifdef __cplusplus
132 }
133 #endif
134
135 #endif /* _INET_TCP_STACK_H */
--- EOF ---