at v2.6.19 389 lines 11 kB view raw
1/* 2 * INET An implementation of the TCP/IP protocol suite for the LINUX 3 * operating system. INET is implemented using the BSD Socket 4 * interface as the means of communication with the user level. 5 * 6 * Definitions for the TCP protocol. 7 * 8 * Version: @(#)tcp.h 1.0.2 04/28/93 9 * 10 * Author: Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG> 11 * 12 * This program is free software; you can redistribute it and/or 13 * modify it under the terms of the GNU General Public License 14 * as published by the Free Software Foundation; either version 15 * 2 of the License, or (at your option) any later version. 16 */ 17#ifndef _LINUX_TCP_H 18#define _LINUX_TCP_H 19 20#include <linux/types.h> 21#include <asm/byteorder.h> 22 23struct tcphdr { 24 __be16 source; 25 __be16 dest; 26 __be32 seq; 27 __be32 ack_seq; 28#if defined(__LITTLE_ENDIAN_BITFIELD) 29 __u16 res1:4, 30 doff:4, 31 fin:1, 32 syn:1, 33 rst:1, 34 psh:1, 35 ack:1, 36 urg:1, 37 ece:1, 38 cwr:1; 39#elif defined(__BIG_ENDIAN_BITFIELD) 40 __u16 doff:4, 41 res1:4, 42 cwr:1, 43 ece:1, 44 urg:1, 45 ack:1, 46 psh:1, 47 rst:1, 48 syn:1, 49 fin:1; 50#else 51#error "Adjust your <asm/byteorder.h> defines" 52#endif 53 __be16 window; 54 __be16 check; 55 __be16 urg_ptr; 56}; 57 58/* 59 * The union cast uses a gcc extension to avoid aliasing problems 60 * (union is compatible to any of its members) 61 * This means this part of the code is -fstrict-aliasing safe now. 62 */ 63union tcp_word_hdr { 64 struct tcphdr hdr; 65 __be32 words[5]; 66}; 67 68#define tcp_flag_word(tp) ( ((union tcp_word_hdr *)(tp))->words [3]) 69 70enum { 71 TCP_FLAG_CWR = __constant_htonl(0x00800000), 72 TCP_FLAG_ECE = __constant_htonl(0x00400000), 73 TCP_FLAG_URG = __constant_htonl(0x00200000), 74 TCP_FLAG_ACK = __constant_htonl(0x00100000), 75 TCP_FLAG_PSH = __constant_htonl(0x00080000), 76 TCP_FLAG_RST = __constant_htonl(0x00040000), 77 TCP_FLAG_SYN = __constant_htonl(0x00020000), 78 TCP_FLAG_FIN = __constant_htonl(0x00010000), 79 TCP_RESERVED_BITS = __constant_htonl(0x0F000000), 80 TCP_DATA_OFFSET = __constant_htonl(0xF0000000) 81}; 82 83/* TCP socket options */ 84#define TCP_NODELAY 1 /* Turn off Nagle's algorithm. */ 85#define TCP_MAXSEG 2 /* Limit MSS */ 86#define TCP_CORK 3 /* Never send partially complete segments */ 87#define TCP_KEEPIDLE 4 /* Start keeplives after this period */ 88#define TCP_KEEPINTVL 5 /* Interval between keepalives */ 89#define TCP_KEEPCNT 6 /* Number of keepalives before death */ 90#define TCP_SYNCNT 7 /* Number of SYN retransmits */ 91#define TCP_LINGER2 8 /* Life time of orphaned FIN-WAIT-2 state */ 92#define TCP_DEFER_ACCEPT 9 /* Wake up listener only when data arrive */ 93#define TCP_WINDOW_CLAMP 10 /* Bound advertised window */ 94#define TCP_INFO 11 /* Information about this connection. */ 95#define TCP_QUICKACK 12 /* Block/reenable quick acks */ 96#define TCP_CONGESTION 13 /* Congestion control algorithm */ 97 98#define TCPI_OPT_TIMESTAMPS 1 99#define TCPI_OPT_SACK 2 100#define TCPI_OPT_WSCALE 4 101#define TCPI_OPT_ECN 8 102 103enum tcp_ca_state 104{ 105 TCP_CA_Open = 0, 106#define TCPF_CA_Open (1<<TCP_CA_Open) 107 TCP_CA_Disorder = 1, 108#define TCPF_CA_Disorder (1<<TCP_CA_Disorder) 109 TCP_CA_CWR = 2, 110#define TCPF_CA_CWR (1<<TCP_CA_CWR) 111 TCP_CA_Recovery = 3, 112#define TCPF_CA_Recovery (1<<TCP_CA_Recovery) 113 TCP_CA_Loss = 4 114#define TCPF_CA_Loss (1<<TCP_CA_Loss) 115}; 116 117struct tcp_info 118{ 119 __u8 tcpi_state; 120 __u8 tcpi_ca_state; 121 __u8 tcpi_retransmits; 122 __u8 tcpi_probes; 123 __u8 tcpi_backoff; 124 __u8 tcpi_options; 125 __u8 tcpi_snd_wscale : 4, tcpi_rcv_wscale : 4; 126 127 __u32 tcpi_rto; 128 __u32 tcpi_ato; 129 __u32 tcpi_snd_mss; 130 __u32 tcpi_rcv_mss; 131 132 __u32 tcpi_unacked; 133 __u32 tcpi_sacked; 134 __u32 tcpi_lost; 135 __u32 tcpi_retrans; 136 __u32 tcpi_fackets; 137 138 /* Times. */ 139 __u32 tcpi_last_data_sent; 140 __u32 tcpi_last_ack_sent; /* Not remembered, sorry. */ 141 __u32 tcpi_last_data_recv; 142 __u32 tcpi_last_ack_recv; 143 144 /* Metrics. */ 145 __u32 tcpi_pmtu; 146 __u32 tcpi_rcv_ssthresh; 147 __u32 tcpi_rtt; 148 __u32 tcpi_rttvar; 149 __u32 tcpi_snd_ssthresh; 150 __u32 tcpi_snd_cwnd; 151 __u32 tcpi_advmss; 152 __u32 tcpi_reordering; 153 154 __u32 tcpi_rcv_rtt; 155 __u32 tcpi_rcv_space; 156 157 __u32 tcpi_total_retrans; 158}; 159 160#ifdef __KERNEL__ 161 162#include <linux/skbuff.h> 163#include <linux/dmaengine.h> 164#include <net/sock.h> 165#include <net/inet_connection_sock.h> 166#include <net/inet_timewait_sock.h> 167 168/* This defines a selective acknowledgement block. */ 169struct tcp_sack_block_wire { 170 __be32 start_seq; 171 __be32 end_seq; 172}; 173 174struct tcp_sack_block { 175 __u32 start_seq; 176 __u32 end_seq; 177}; 178 179struct tcp_options_received { 180/* PAWS/RTTM data */ 181 long ts_recent_stamp;/* Time we stored ts_recent (for aging) */ 182 __u32 ts_recent; /* Time stamp to echo next */ 183 __u32 rcv_tsval; /* Time stamp value */ 184 __u32 rcv_tsecr; /* Time stamp echo reply */ 185 __u16 saw_tstamp : 1, /* Saw TIMESTAMP on last packet */ 186 tstamp_ok : 1, /* TIMESTAMP seen on SYN packet */ 187 dsack : 1, /* D-SACK is scheduled */ 188 wscale_ok : 1, /* Wscale seen on SYN packet */ 189 sack_ok : 4, /* SACK seen on SYN packet */ 190 snd_wscale : 4, /* Window scaling received from sender */ 191 rcv_wscale : 4; /* Window scaling to send to receiver */ 192/* SACKs data */ 193 __u8 eff_sacks; /* Size of SACK array to send with next packet */ 194 __u8 num_sacks; /* Number of SACK blocks */ 195 __u16 user_mss; /* mss requested by user in ioctl */ 196 __u16 mss_clamp; /* Maximal mss, negotiated at connection setup */ 197}; 198 199struct tcp_request_sock { 200 struct inet_request_sock req; 201 __u32 rcv_isn; 202 __u32 snt_isn; 203}; 204 205static inline struct tcp_request_sock *tcp_rsk(const struct request_sock *req) 206{ 207 return (struct tcp_request_sock *)req; 208} 209 210struct tcp_sock { 211 /* inet_connection_sock has to be the first member of tcp_sock */ 212 struct inet_connection_sock inet_conn; 213 int tcp_header_len; /* Bytes of tcp header to send */ 214 215/* 216 * Header prediction flags 217 * 0x5?10 << 16 + snd_wnd in net byte order 218 */ 219 __be32 pred_flags; 220 221/* 222 * RFC793 variables by their proper names. This means you can 223 * read the code and the spec side by side (and laugh ...) 224 * See RFC793 and RFC1122. The RFC writes these in capitals. 225 */ 226 __u32 rcv_nxt; /* What we want to receive next */ 227 __u32 snd_nxt; /* Next sequence we send */ 228 229 __u32 snd_una; /* First byte we want an ack for */ 230 __u32 snd_sml; /* Last byte of the most recently transmitted small packet */ 231 __u32 rcv_tstamp; /* timestamp of last received ACK (for keepalives) */ 232 __u32 lsndtime; /* timestamp of last sent data packet (for restart window) */ 233 234 /* Data for direct copy to user */ 235 struct { 236 struct sk_buff_head prequeue; 237 struct task_struct *task; 238 struct iovec *iov; 239 int memory; 240 int len; 241#ifdef CONFIG_NET_DMA 242 /* members for async copy */ 243 struct dma_chan *dma_chan; 244 int wakeup; 245 struct dma_pinned_list *pinned_list; 246 dma_cookie_t dma_cookie; 247#endif 248 } ucopy; 249 250 __u32 snd_wl1; /* Sequence for window update */ 251 __u32 snd_wnd; /* The window we expect to receive */ 252 __u32 max_window; /* Maximal window ever seen from peer */ 253 __u32 mss_cache; /* Cached effective mss, not including SACKS */ 254 __u16 xmit_size_goal; /* Goal for segmenting output packets */ 255 /* XXX Two bytes hole, try to pack */ 256 257 __u32 window_clamp; /* Maximal window to advertise */ 258 __u32 rcv_ssthresh; /* Current window clamp */ 259 260 __u32 frto_highmark; /* snd_nxt when RTO occurred */ 261 __u8 reordering; /* Packet reordering metric. */ 262 __u8 frto_counter; /* Number of new acks after RTO */ 263 __u8 nonagle; /* Disable Nagle algorithm? */ 264 __u8 keepalive_probes; /* num of allowed keep alive probes */ 265 266/* RTT measurement */ 267 __u32 srtt; /* smoothed round trip time << 3 */ 268 __u32 mdev; /* medium deviation */ 269 __u32 mdev_max; /* maximal mdev for the last rtt period */ 270 __u32 rttvar; /* smoothed mdev_max */ 271 __u32 rtt_seq; /* sequence number to update rttvar */ 272 273 __u32 packets_out; /* Packets which are "in flight" */ 274 __u32 left_out; /* Packets which leaved network */ 275 __u32 retrans_out; /* Retransmitted packets out */ 276/* 277 * Options received (usually on last packet, some only on SYN packets). 278 */ 279 struct tcp_options_received rx_opt; 280 281/* 282 * Slow start and congestion control (see also Nagle, and Karn & Partridge) 283 */ 284 __u32 snd_ssthresh; /* Slow start size threshold */ 285 __u32 snd_cwnd; /* Sending congestion window */ 286 __u16 snd_cwnd_cnt; /* Linear increase counter */ 287 __u16 snd_cwnd_clamp; /* Do not allow snd_cwnd to grow above this */ 288 __u32 snd_cwnd_used; 289 __u32 snd_cwnd_stamp; 290 291 struct sk_buff_head out_of_order_queue; /* Out of order segments go here */ 292 293 __u32 rcv_wnd; /* Current receiver window */ 294 __u32 rcv_wup; /* rcv_nxt on last window update sent */ 295 __u32 write_seq; /* Tail(+1) of data held in tcp send buffer */ 296 __u32 pushed_seq; /* Last pushed seq, required to talk to windows */ 297 __u32 copied_seq; /* Head of yet unread data */ 298 299/* SACKs data */ 300 struct tcp_sack_block duplicate_sack[1]; /* D-SACK block */ 301 struct tcp_sack_block selective_acks[4]; /* The SACKS themselves*/ 302 303 struct tcp_sack_block recv_sack_cache[4]; 304 305 /* from STCP, retrans queue hinting */ 306 struct sk_buff* lost_skb_hint; 307 308 struct sk_buff *scoreboard_skb_hint; 309 struct sk_buff *retransmit_skb_hint; 310 struct sk_buff *forward_skb_hint; 311 struct sk_buff *fastpath_skb_hint; 312 313 int fastpath_cnt_hint; 314 int lost_cnt_hint; 315 int retransmit_cnt_hint; 316 int forward_cnt_hint; 317 318 __u16 advmss; /* Advertised MSS */ 319 __u16 prior_ssthresh; /* ssthresh saved at recovery start */ 320 __u32 lost_out; /* Lost packets */ 321 __u32 sacked_out; /* SACK'd packets */ 322 __u32 fackets_out; /* FACK'd packets */ 323 __u32 high_seq; /* snd_nxt at onset of congestion */ 324 325 __u32 retrans_stamp; /* Timestamp of the last retransmit, 326 * also used in SYN-SENT to remember stamp of 327 * the first SYN. */ 328 __u32 undo_marker; /* tracking retrans started here. */ 329 int undo_retrans; /* number of undoable retransmissions. */ 330 __u32 urg_seq; /* Seq of received urgent pointer */ 331 __u16 urg_data; /* Saved octet of OOB data and control flags */ 332 __u8 urg_mode; /* In urgent mode */ 333 __u8 ecn_flags; /* ECN status bits. */ 334 __u32 snd_up; /* Urgent pointer */ 335 336 __u32 total_retrans; /* Total retransmits for entire connection */ 337 __u32 bytes_acked; /* Appropriate Byte Counting - RFC3465 */ 338 339 unsigned int keepalive_time; /* time before keep alive takes place */ 340 unsigned int keepalive_intvl; /* time interval between keep alive probes */ 341 int linger2; 342 343 unsigned long last_synq_overflow; 344 345 __u32 tso_deferred; 346 347/* Receiver side RTT estimation */ 348 struct { 349 __u32 rtt; 350 __u32 seq; 351 __u32 time; 352 } rcv_rtt_est; 353 354/* Receiver queue space */ 355 struct { 356 int space; 357 __u32 seq; 358 __u32 time; 359 } rcvq_space; 360 361/* TCP-specific MTU probe information. */ 362 struct { 363 __u32 probe_seq_start; 364 __u32 probe_seq_end; 365 } mtu_probe; 366}; 367 368static inline struct tcp_sock *tcp_sk(const struct sock *sk) 369{ 370 return (struct tcp_sock *)sk; 371} 372 373struct tcp_timewait_sock { 374 struct inet_timewait_sock tw_sk; 375 __u32 tw_rcv_nxt; 376 __u32 tw_snd_nxt; 377 __u32 tw_rcv_wnd; 378 __u32 tw_ts_recent; 379 long tw_ts_recent_stamp; 380}; 381 382static inline struct tcp_timewait_sock *tcp_twsk(const struct sock *sk) 383{ 384 return (struct tcp_timewait_sock *)sk; 385} 386 387#endif 388 389#endif /* _LINUX_TCP_H */