| 1 | /* | 
| 2 |  * Copyright (c) 1982, 1986, 1993 | 
| 3 |  *	The Regents of the University of California.  All rights reserved. | 
| 4 |  * | 
| 5 |  * Redistribution and use in source and binary forms, with or without | 
| 6 |  * modification, are permitted provided that the following conditions | 
| 7 |  * are met: | 
| 8 |  * 1. Redistributions of source code must retain the above copyright | 
| 9 |  *    notice, this list of conditions and the following disclaimer. | 
| 10 |  * 2. Redistributions in binary form must reproduce the above copyright | 
| 11 |  *    notice, this list of conditions and the following disclaimer in the | 
| 12 |  *    documentation and/or other materials provided with the distribution. | 
| 13 |  * 4. Neither the name of the University nor the names of its contributors | 
| 14 |  *    may be used to endorse or promote products derived from this software | 
| 15 |  *    without specific prior written permission. | 
| 16 |  * | 
| 17 |  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND | 
| 18 |  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 
| 19 |  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | 
| 20 |  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE | 
| 21 |  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | 
| 22 |  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | 
| 23 |  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | 
| 24 |  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | 
| 25 |  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | 
| 26 |  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | 
| 27 |  * SUCH DAMAGE. | 
| 28 |  * | 
| 29 |  *	@(#)tcp.h	8.1 (Berkeley) 6/10/93 | 
| 30 |  */ | 
| 31 |  | 
| 32 | #ifndef _NETINET_TCP_H | 
| 33 | #define _NETINET_TCP_H	1 | 
| 34 |  | 
| 35 | #include <features.h> | 
| 36 |  | 
| 37 | /* | 
| 38 |  * User-settable options (used with setsockopt). | 
| 39 |  */ | 
| 40 | #define	TCP_NODELAY		 1  /* Don't delay send to coalesce packets  */ | 
| 41 | #define	TCP_MAXSEG		 2  /* Set maximum segment size  */ | 
| 42 | #define TCP_CORK		 3  /* Control sending of partial frames  */ | 
| 43 | #define TCP_KEEPIDLE		 4  /* Start keeplives after this period */ | 
| 44 | #define TCP_KEEPINTVL		 5  /* Interval between keepalives */ | 
| 45 | #define TCP_KEEPCNT		 6  /* Number of keepalives before death */ | 
| 46 | #define TCP_SYNCNT		 7  /* Number of SYN retransmits */ | 
| 47 | #define TCP_LINGER2		 8  /* Life time of orphaned FIN-WAIT-2 state */ | 
| 48 | #define TCP_DEFER_ACCEPT	 9  /* Wake up listener only when data arrive */ | 
| 49 | #define TCP_WINDOW_CLAMP	 10 /* Bound advertised window */ | 
| 50 | #define TCP_INFO		 11 /* Information about this connection. */ | 
| 51 | #define	TCP_QUICKACK		 12 /* Bock/reenable quick ACKs.  */ | 
| 52 | #define TCP_CONGESTION		 13 /* Congestion control algorithm.  */ | 
| 53 | #define TCP_MD5SIG		 14 /* TCP MD5 Signature (RFC2385) */ | 
| 54 | #define TCP_COOKIE_TRANSACTIONS	 15 /* TCP Cookie Transactions */ | 
| 55 | #define TCP_THIN_LINEAR_TIMEOUTS 16 /* Use linear timeouts for thin streams*/ | 
| 56 | #define TCP_THIN_DUPACK		 17 /* Fast retrans. after 1 dupack */ | 
| 57 | #define TCP_USER_TIMEOUT	 18 /* How long for loss retry before timeout */ | 
| 58 | #define TCP_REPAIR		 19 /* TCP sock is under repair right now */ | 
| 59 | #define TCP_REPAIR_QUEUE	 20 /* Set TCP queue to repair */ | 
| 60 | #define TCP_QUEUE_SEQ		 21 /* Set sequence number of repaired queue. */ | 
| 61 | #define TCP_REPAIR_OPTIONS	 22 /* Repair TCP connection options */ | 
| 62 | #define TCP_FASTOPEN		 23 /* Enable FastOpen on listeners */ | 
| 63 | #define TCP_TIMESTAMP		 24 /* TCP time stamp */ | 
| 64 |  | 
| 65 | #ifdef __USE_MISC | 
| 66 | # include <sys/types.h> | 
| 67 | # include <sys/socket.h> | 
| 68 |  | 
| 69 | typedef	u_int32_t tcp_seq; | 
| 70 | /* | 
| 71 |  * TCP header. | 
| 72 |  * Per RFC 793, September, 1981. | 
| 73 |  */ | 
| 74 | struct tcphdr | 
| 75 |   { | 
| 76 |     __extension__ union | 
| 77 |     { | 
| 78 |       struct | 
| 79 |       { | 
| 80 | 	u_int16_t th_sport;		/* source port */ | 
| 81 | 	u_int16_t th_dport;		/* destination port */ | 
| 82 | 	tcp_seq th_seq;		/* sequence number */ | 
| 83 | 	tcp_seq th_ack;		/* acknowledgement number */ | 
| 84 | # if __BYTE_ORDER == __LITTLE_ENDIAN | 
| 85 | 	u_int8_t th_x2:4;		/* (unused) */ | 
| 86 | 	u_int8_t th_off:4;		/* data offset */ | 
| 87 | # endif | 
| 88 | # if __BYTE_ORDER == __BIG_ENDIAN | 
| 89 | 	u_int8_t th_off:4;		/* data offset */ | 
| 90 | 	u_int8_t th_x2:4;		/* (unused) */ | 
| 91 | # endif | 
| 92 | 	u_int8_t th_flags; | 
| 93 | # define TH_FIN	0x01 | 
| 94 | # define TH_SYN	0x02 | 
| 95 | # define TH_RST	0x04 | 
| 96 | # define TH_PUSH	0x08 | 
| 97 | # define TH_ACK	0x10 | 
| 98 | # define TH_URG	0x20 | 
| 99 | 	u_int16_t th_win;		/* window */ | 
| 100 | 	u_int16_t th_sum;		/* checksum */ | 
| 101 | 	u_int16_t th_urp;		/* urgent pointer */ | 
| 102 |       }; | 
| 103 |       struct | 
| 104 |       { | 
| 105 | 	u_int16_t source; | 
| 106 | 	u_int16_t dest; | 
| 107 | 	u_int32_t seq; | 
| 108 | 	u_int32_t ack_seq; | 
| 109 | # if __BYTE_ORDER == __LITTLE_ENDIAN | 
| 110 | 	u_int16_t res1:4; | 
| 111 | 	u_int16_t doff:4; | 
| 112 | 	u_int16_t fin:1; | 
| 113 | 	u_int16_t syn:1; | 
| 114 | 	u_int16_t rst:1; | 
| 115 | 	u_int16_t psh:1; | 
| 116 | 	u_int16_t ack:1; | 
| 117 | 	u_int16_t urg:1; | 
| 118 | 	u_int16_t res2:2; | 
| 119 | # elif __BYTE_ORDER == __BIG_ENDIAN | 
| 120 | 	u_int16_t doff:4; | 
| 121 | 	u_int16_t res1:4; | 
| 122 | 	u_int16_t res2:2; | 
| 123 | 	u_int16_t urg:1; | 
| 124 | 	u_int16_t ack:1; | 
| 125 | 	u_int16_t psh:1; | 
| 126 | 	u_int16_t rst:1; | 
| 127 | 	u_int16_t syn:1; | 
| 128 | 	u_int16_t fin:1; | 
| 129 | # else | 
| 130 | #  error "Adjust your <bits/endian.h> defines" | 
| 131 | # endif | 
| 132 | 	u_int16_t window; | 
| 133 | 	u_int16_t check; | 
| 134 | 	u_int16_t urg_ptr; | 
| 135 |       }; | 
| 136 |     }; | 
| 137 | }; | 
| 138 |  | 
| 139 | enum | 
| 140 | { | 
| 141 |   TCP_ESTABLISHED = 1, | 
| 142 |   TCP_SYN_SENT, | 
| 143 |   TCP_SYN_RECV, | 
| 144 |   TCP_FIN_WAIT1, | 
| 145 |   TCP_FIN_WAIT2, | 
| 146 |   TCP_TIME_WAIT, | 
| 147 |   TCP_CLOSE, | 
| 148 |   TCP_CLOSE_WAIT, | 
| 149 |   TCP_LAST_ACK, | 
| 150 |   TCP_LISTEN, | 
| 151 |   TCP_CLOSING   /* now a valid state */ | 
| 152 | }; | 
| 153 |  | 
| 154 | # define TCPOPT_EOL		0 | 
| 155 | # define TCPOPT_NOP		1 | 
| 156 | # define TCPOPT_MAXSEG		2 | 
| 157 | # define TCPOLEN_MAXSEG		4 | 
| 158 | # define TCPOPT_WINDOW		3 | 
| 159 | # define TCPOLEN_WINDOW		3 | 
| 160 | # define TCPOPT_SACK_PERMITTED	4		/* Experimental */ | 
| 161 | # define TCPOLEN_SACK_PERMITTED	2 | 
| 162 | # define TCPOPT_SACK		5		/* Experimental */ | 
| 163 | # define TCPOPT_TIMESTAMP	8 | 
| 164 | # define TCPOLEN_TIMESTAMP	10 | 
| 165 | # define TCPOLEN_TSTAMP_APPA	(TCPOLEN_TIMESTAMP+2) /* appendix A */ | 
| 166 |  | 
| 167 | # define TCPOPT_TSTAMP_HDR	\ | 
| 168 |     (TCPOPT_NOP<<24|TCPOPT_NOP<<16|TCPOPT_TIMESTAMP<<8|TCPOLEN_TIMESTAMP) | 
| 169 |  | 
| 170 | /* | 
| 171 |  * Default maximum segment size for TCP. | 
| 172 |  * With an IP MSS of 576, this is 536, | 
| 173 |  * but 512 is probably more convenient. | 
| 174 |  * This should be defined as MIN(512, IP_MSS - sizeof (struct tcpiphdr)). | 
| 175 |  */ | 
| 176 | # define TCP_MSS	512 | 
| 177 |  | 
| 178 | # define TCP_MAXWIN	65535	/* largest value for (unscaled) window */ | 
| 179 |  | 
| 180 | # define TCP_MAX_WINSHIFT	14	/* maximum window shift */ | 
| 181 |  | 
| 182 | # define SOL_TCP		6	/* TCP level */ | 
| 183 |  | 
| 184 |  | 
| 185 | # define TCPI_OPT_TIMESTAMPS	1 | 
| 186 | # define TCPI_OPT_SACK		2 | 
| 187 | # define TCPI_OPT_WSCALE	4 | 
| 188 | # define TCPI_OPT_ECN		8  /* ECN was negociated at TCP session init */ | 
| 189 | # define TCPI_OPT_ECN_SEEN	16 /* we received at least one packet with ECT */ | 
| 190 | # define TCPI_OPT_SYN_DATA	32 /* SYN-ACK acked data in SYN sent or rcvd */ | 
| 191 |  | 
| 192 | /* Values for tcpi_state.  */ | 
| 193 | enum tcp_ca_state | 
| 194 | { | 
| 195 |   TCP_CA_Open = 0, | 
| 196 |   TCP_CA_Disorder = 1, | 
| 197 |   TCP_CA_CWR = 2, | 
| 198 |   TCP_CA_Recovery = 3, | 
| 199 |   TCP_CA_Loss = 4 | 
| 200 | }; | 
| 201 |  | 
| 202 | struct tcp_info | 
| 203 | { | 
| 204 |   u_int8_t	tcpi_state; | 
| 205 |   u_int8_t	tcpi_ca_state; | 
| 206 |   u_int8_t	tcpi_retransmits; | 
| 207 |   u_int8_t	tcpi_probes; | 
| 208 |   u_int8_t	tcpi_backoff; | 
| 209 |   u_int8_t	tcpi_options; | 
| 210 |   u_int8_t	tcpi_snd_wscale : 4, tcpi_rcv_wscale : 4; | 
| 211 |  | 
| 212 |   u_int32_t	tcpi_rto; | 
| 213 |   u_int32_t	tcpi_ato; | 
| 214 |   u_int32_t	tcpi_snd_mss; | 
| 215 |   u_int32_t	tcpi_rcv_mss; | 
| 216 |  | 
| 217 |   u_int32_t	tcpi_unacked; | 
| 218 |   u_int32_t	tcpi_sacked; | 
| 219 |   u_int32_t	tcpi_lost; | 
| 220 |   u_int32_t	tcpi_retrans; | 
| 221 |   u_int32_t	tcpi_fackets; | 
| 222 |  | 
| 223 |   /* Times. */ | 
| 224 |   u_int32_t	tcpi_last_data_sent; | 
| 225 |   u_int32_t	tcpi_last_ack_sent;	/* Not remembered, sorry.  */ | 
| 226 |   u_int32_t	tcpi_last_data_recv; | 
| 227 |   u_int32_t	tcpi_last_ack_recv; | 
| 228 |  | 
| 229 |   /* Metrics. */ | 
| 230 |   u_int32_t	tcpi_pmtu; | 
| 231 |   u_int32_t	tcpi_rcv_ssthresh; | 
| 232 |   u_int32_t	tcpi_rtt; | 
| 233 |   u_int32_t	tcpi_rttvar; | 
| 234 |   u_int32_t	tcpi_snd_ssthresh; | 
| 235 |   u_int32_t	tcpi_snd_cwnd; | 
| 236 |   u_int32_t	tcpi_advmss; | 
| 237 |   u_int32_t	tcpi_reordering; | 
| 238 |  | 
| 239 |   u_int32_t	tcpi_rcv_rtt; | 
| 240 |   u_int32_t	tcpi_rcv_space; | 
| 241 |  | 
| 242 |   u_int32_t	tcpi_total_retrans; | 
| 243 | }; | 
| 244 |  | 
| 245 |  | 
| 246 | /* For TCP_MD5SIG socket option.  */ | 
| 247 | #define TCP_MD5SIG_MAXKEYLEN	80 | 
| 248 |  | 
| 249 | struct tcp_md5sig | 
| 250 | { | 
| 251 |   struct sockaddr_storage tcpm_addr;		/* Address associated.  */ | 
| 252 |   u_int16_t	__tcpm_pad1;			/* Zero.  */ | 
| 253 |   u_int16_t	tcpm_keylen;			/* Key length.  */ | 
| 254 |   u_int32_t	__tcpm_pad2;			/* Zero.  */ | 
| 255 |   u_int8_t	tcpm_key[TCP_MD5SIG_MAXKEYLEN];	/* Key (binary).  */ | 
| 256 | }; | 
| 257 |  | 
| 258 | /* For socket repair options.  */ | 
| 259 | struct tcp_repair_opt | 
| 260 | { | 
| 261 |   u_int32_t	opt_code; | 
| 262 |   u_int32_t	opt_val; | 
| 263 | }; | 
| 264 |  | 
| 265 | /* Queue to repair, for TCP_REPAIR_QUEUE.  */ | 
| 266 | enum | 
| 267 | { | 
| 268 |   TCP_NO_QUEUE, | 
| 269 |   TCP_RECV_QUEUE, | 
| 270 |   TCP_SEND_QUEUE, | 
| 271 |   TCP_QUEUES_NR, | 
| 272 | }; | 
| 273 |  | 
| 274 | /* For cookie transactions socket options.  */ | 
| 275 | #define TCP_COOKIE_MIN		8		/*  64-bits */ | 
| 276 | #define TCP_COOKIE_MAX		16		/* 128-bits */ | 
| 277 | #define TCP_COOKIE_PAIR_SIZE	(2*TCP_COOKIE_MAX) | 
| 278 |  | 
| 279 | /* Flags for both getsockopt and setsockopt */ | 
| 280 | #define TCP_COOKIE_IN_ALWAYS	(1 << 0)	/* Discard SYN without cookie */ | 
| 281 | #define TCP_COOKIE_OUT_NEVER	(1 << 1)	/* Prohibit outgoing cookies, | 
| 282 | 						 * supercedes everything. */ | 
| 283 |  | 
| 284 | /* Flags for getsockopt */ | 
| 285 | #define TCP_S_DATA_IN		(1 << 2)	/* Was data received? */ | 
| 286 | #define TCP_S_DATA_OUT		(1 << 3)	/* Was data sent? */ | 
| 287 |  | 
| 288 | #define TCP_MSS_DEFAULT		 536U	/* IPv4 (RFC1122, RFC2581) */ | 
| 289 | #define TCP_MSS_DESIRED		1220U	/* IPv6 (tunneled), EDNS0 (RFC3226) */ | 
| 290 |  | 
| 291 | struct tcp_cookie_transactions | 
| 292 | { | 
| 293 |   u_int16_t	tcpct_flags; | 
| 294 |   u_int8_t	__tcpct_pad1; | 
| 295 |   u_int8_t	tcpct_cookie_desired; | 
| 296 |   u_int16_t	tcpct_s_data_desired; | 
| 297 |   u_int16_t	tcpct_used; | 
| 298 |   u_int8_t	tcpct_value[TCP_MSS_DEFAULT]; | 
| 299 | }; | 
| 300 |  | 
| 301 | #endif /* Misc.  */ | 
| 302 |  | 
| 303 | #endif /* netinet/tcp.h */ | 
| 304 |  |