VM: simplify slab allocator
[minix.git] / servers / inet / generic / tcp_int.h
blob58cf174a2830560f15bf01d80661dc56634adf5d
1 /*
2 tcp_int.h
4 Copyright 1995 Philip Homburg
5 */
7 #ifndef TCP_INT_H
8 #define TCP_INT_H
10 #define IP_TCP_MIN_HDR_SIZE (IP_MIN_HDR_SIZE+TCP_MIN_HDR_SIZE)
12 #define TCP_CONN_HASH_SHIFT 4
13 #define TCP_CONN_HASH_NR (1 << TCP_CONN_HASH_SHIFT)
15 typedef struct tcp_port
17 int tp_ipdev;
18 int tp_flags;
19 int tp_state;
20 int tp_ipfd;
21 acc_t *tp_pack;
22 ipaddr_t tp_ipaddr;
23 ipaddr_t tp_subnetmask;
24 u16_t tp_mtu;
25 struct tcp_conn *tp_snd_head;
26 struct tcp_conn *tp_snd_tail;
27 event_t tp_snd_event;
28 struct tcp_conn *tp_conn_hash[TCP_CONN_HASH_NR][4];
29 } tcp_port_t;
31 #define TPF_EMPTY 0x0
32 #define TPF_SUSPEND 0x1
33 #define TPF_READ_IP 0x2
34 #define TPF_READ_SP 0x4
35 #define TPF_WRITE_IP 0x8
36 #define TPF_WRITE_SP 0x10
37 #define TPF_DELAY_TCP 0x40
39 #define TPS_EMPTY 0
40 #define TPS_SETPROTO 1
41 #define TPS_GETCONF 2
42 #define TPS_MAIN 3
43 #define TPS_ERROR 4
45 #define TFL_LISTEN_MAX 5
47 typedef struct tcp_fd
49 unsigned long tf_flags;
50 tcp_port_t *tf_port;
51 int tf_srfd;
52 ioreq_t tf_ioreq;
53 nwio_tcpconf_t tf_tcpconf;
54 nwio_tcpopt_t tf_tcpopt;
55 get_userdata_t tf_get_userdata;
56 put_userdata_t tf_put_userdata;
57 select_res_t tf_select_res;
58 struct tcp_conn *tf_conn;
59 struct tcp_conn *tf_listenq[TFL_LISTEN_MAX];
60 size_t tf_write_offset;
61 size_t tf_write_count;
62 size_t tf_read_offset;
63 size_t tf_read_count;
64 int tf_error; /* Error for nonblocking connect */
65 tcp_cookie_t tf_cookie;
66 } tcp_fd_t;
68 #define TFF_EMPTY 0x0
69 #define TFF_INUSE 0x1
70 #define TFF_READ_IP 0x2
71 #define TFF_WRITE_IP 0x4
72 #define TFF_IOCTL_IP 0x8
73 #define TFF_CONF_SET 0x10
74 #define TFF_IOC_INIT_SP 0x20
75 #define TFF_LISTENQ 0x40
76 #define TFF_CONNECTING 0x80
77 #define TFF_CONNECTED 0x100
78 #define TFF_WR_URG 0x200
79 #define TFF_PUSH_DATA 0x400
80 #define TFF_RECV_URG 0x800
81 #define TFF_SEL_READ 0x1000
82 #define TFF_SEL_WRITE 0x2000
83 #define TFF_SEL_EXCEPT 0x4000
84 #define TFF_DEL_RST 0x8000
85 #define TFF_COOKIE 0x10000
87 typedef struct tcp_conn
89 int tc_flags;
90 int tc_state;
91 int tc_busy; /* do not steal buffer when a connection is
92 * busy
94 tcp_port_t *tc_port;
95 tcp_fd_t *tc_fd;
97 tcpport_t tc_locport;
98 ipaddr_t tc_locaddr;
99 tcpport_t tc_remport;
100 ipaddr_t tc_remaddr;
102 int tc_connInprogress;
103 int tc_orglisten;
104 clock_t tc_senddis;
106 /* Sending side */
107 u32_t tc_ISS; /* initial sequence number */
108 u32_t tc_SND_UNA; /* least unacknowledged sequence number */
109 u32_t tc_SND_TRM; /* next sequence number to be transmitted */
110 u32_t tc_SND_NXT; /* next sequence number for new data */
111 u32_t tc_SND_UP; /* urgent pointer, first sequence number not
112 * urgent */
113 u32_t tc_SND_PSH; /* push pointer, data should be pushed until
114 * the push pointer is reached */
116 u32_t tc_snd_cwnd; /* highest sequence number to be sent */
117 u32_t tc_snd_cthresh; /* threshold for send window */
118 u32_t tc_snd_cinc; /* increment for send window threshold */
119 u16_t tc_snd_wnd; /* max send queue size */
120 u16_t tc_snd_dack; /* # of duplicate ACKs */
122 /* round trip calculation. */
123 clock_t tc_rt_time;
124 u32_t tc_rt_seq;
125 u32_t tc_rt_threshold;
126 clock_t tc_artt; /* Avg. retransmission time. Scaled. */
127 clock_t tc_drtt; /* Diviation, also scaled. */
128 clock_t tc_rtt; /* Computed retrans time */
130 acc_t *tc_send_data;
131 acc_t *tc_frag2send;
132 struct tcp_conn *tc_send_link;
134 /* Receiving side */
135 u32_t tc_IRS;
136 u32_t tc_RCV_LO;
137 u32_t tc_RCV_NXT;
138 u32_t tc_RCV_HI;
139 u32_t tc_RCV_UP;
141 u16_t tc_rcv_wnd;
142 acc_t *tc_rcvd_data;
143 acc_t *tc_adv_data;
144 u32_t tc_adv_seq;
146 /* Keep alive. Record SDN_NXT and RCV_NXT in tc_ka_snd and
147 * tc_ka_rcv when setting the keepalive timer to detect
148 * any activity that may have happend before the timer
149 * expired.
151 u32_t tc_ka_snd;
152 u32_t tc_ka_rcv;
153 clock_t tc_ka_time;
155 acc_t *tc_remipopt;
156 acc_t *tc_tcpopt;
157 u8_t tc_tos;
158 u8_t tc_ttl;
159 u16_t tc_max_mtu; /* Max. negotiated (or selected) MTU */
160 u16_t tc_mtu; /* discovered PMTU */
161 clock_t tc_mtutim; /* Last time MTU/TCF_PMTU flag was changed */
163 struct timer tc_transmit_timer;
164 u32_t tc_transmit_seq;
165 clock_t tc_0wnd_to;
166 clock_t tc_stt; /* time of first send after last ack */
167 clock_t tc_rt_dead;
169 int tc_error;
170 int tc_inconsistent;
171 } tcp_conn_t;
173 #define TCF_EMPTY 0x0
174 #define TCF_INUSE 0x1
175 #define TCF_FIN_RECV 0x2
176 #define TCF_RCV_PUSH 0x4
177 #define TCF_MORE2WRITE 0x8
178 #define TCF_SEND_ACK 0x10
179 #define TCF_FIN_SENT 0x20
180 #define TCF_BSD_URG 0x40
181 #define TCF_NO_PUSH 0x80
182 #define TCF_PUSH_NOW 0x100
183 #define TCF_PMTU 0x200
185 #if DEBUG & 0x200
186 #define TCF_DEBUG 0x1000
187 #endif
189 #define TCS_CLOSED 0
190 #define TCS_LISTEN 1
191 #define TCS_SYN_RECEIVED 2
192 #define TCS_SYN_SENT 3
193 #define TCS_ESTABLISHED 4
194 #define TCS_CLOSING 5
196 /* tcp_recv.c */
197 void tcp_frag2conn ARGS(( tcp_conn_t *tcp_conn, ip_hdr_t *ip_hdr,
198 tcp_hdr_t *tcp_hdr, acc_t *tcp_data, size_t data_len ));
199 void tcp_fd_read ARGS(( tcp_conn_t *tcp_conn, int enq ));
200 unsigned tcp_sel_read ARGS(( tcp_conn_t *tcp_conn ));
201 void tcp_rsel_read ARGS(( tcp_conn_t *tcp_conn ));
202 void tcp_bytesavailable ARGS(( tcp_fd_t *tcp_fd, int *bytesp ));
204 /* tcp_send.c */
205 void tcp_conn_write ARGS(( tcp_conn_t *tcp_conn, int enq ));
206 void tcp_release_retrans ARGS(( tcp_conn_t *tcp_conn, u32_t seg_ack,
207 u16_t new_win ));
208 void tcp_fast_retrans ARGS(( tcp_conn_t *tcp_conn ));
209 void tcp_set_send_timer ARGS(( tcp_conn_t *tcp_conn ));
210 void tcp_fd_write ARGS(( tcp_conn_t *tcp_conn ));
211 unsigned tcp_sel_write ARGS(( tcp_conn_t *tcp_conn ));
212 void tcp_rsel_write ARGS(( tcp_conn_t *tcp_conn ));
213 void tcp_close_connection ARGS(( tcp_conn_t *tcp_conn,
214 int error ));
215 void tcp_port_write ARGS(( tcp_port_t *tcp_port ));
216 void tcp_shutdown ARGS(( tcp_conn_t *tcp_conn ));
218 /* tcp_lib.c */
219 void tcp_extract_ipopt ARGS(( tcp_conn_t *tcp_conn,
220 ip_hdr_t *ip_hdr ));
221 void tcp_extract_tcpopt ARGS(( tcp_conn_t *tcp_conn,
222 tcp_hdr_t *tcp_hdr, size_t *mssp ));
223 void tcp_get_ipopt ARGS(( tcp_conn_t *tcp_conn, ip_hdropt_t
224 *ip_hdropt ));
225 void tcp_get_tcpopt ARGS(( tcp_conn_t *tcp_conn, tcp_hdropt_t
226 *tcp_hdropt ));
227 acc_t *tcp_make_header ARGS(( tcp_conn_t *tcp_conn,
228 ip_hdr_t **ref_ip_hdr, tcp_hdr_t **ref_tcp_hdr, acc_t *data ));
229 u16_t tcp_pack_oneCsum ARGS(( ip_hdr_t *ip_hdr, acc_t *tcp_pack ));
230 int tcp_check_conn ARGS(( tcp_conn_t *tcp_conn ));
231 void tcp_print_pack ARGS(( ip_hdr_t *ip_hdr, tcp_hdr_t *tcp_hdr ));
232 void tcp_print_state ARGS(( tcp_conn_t *tcp_conn ));
233 void tcp_print_conn ARGS(( tcp_conn_t *tcp_conn ));
234 int tcp_LEmod4G ARGS(( u32_t n1, u32_t n2 ));
235 int tcp_Lmod4G ARGS(( u32_t n1, u32_t n2 ));
236 int tcp_GEmod4G ARGS(( u32_t n1, u32_t n2 ));
237 int tcp_Gmod4G ARGS(( u32_t n1, u32_t n2 ));
239 /* tcp.c */
240 void tcp_restart_connect ARGS(( tcp_conn_t *tcp_conn ));
241 int tcp_su4listen ARGS(( tcp_fd_t *tcp_fd, tcp_conn_t *tcp_conn,
242 int do_listenq ));
243 void tcp_reply_ioctl ARGS(( tcp_fd_t *tcp_fd, int reply ));
244 void tcp_reply_write ARGS(( tcp_fd_t *tcp_fd, size_t reply ));
245 void tcp_reply_read ARGS(( tcp_fd_t *tcp_fd, size_t reply ));
246 void tcp_notreach ARGS(( tcp_conn_t *tcp_conn, int error ));
247 void tcp_mtu_exceeded ARGS(( tcp_conn_t *tcp_conn ));
248 void tcp_mtu_incr ARGS(( tcp_conn_t *tcp_conn ));
250 #define TCP_FD_NR (10*IP_PORT_MAX)
251 #define TCP_CONN_NR (2*TCP_FD_NR)
253 EXTERN tcp_port_t *tcp_port_table;
254 EXTERN tcp_conn_t tcp_conn_table[TCP_CONN_NR];
255 EXTERN tcp_fd_t tcp_fd_table[TCP_FD_NR];
257 #define tcp_Lmod4G(n1,n2) (!!(((n1)-(n2)) & 0x80000000L))
258 #define tcp_GEmod4G(n1,n2) (!(((n1)-(n2)) & 0x80000000L))
259 #define tcp_Gmod4G(n1,n2) (!!(((n2)-(n1)) & 0x80000000L))
260 #define tcp_LEmod4G(n1,n2) (!(((n2)-(n1)) & 0x80000000L))
262 #endif /* TCP_INT_H */
265 * $PchId: tcp_int.h,v 1.17 2005/06/28 14:21:08 philip Exp $