• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /****************************************************************************
2  ****************************************************************************
3  ***
4  ***   This header was automatically generated from a Linux kernel header
5  ***   of the same name, to make information necessary for userspace to
6  ***   call into the kernel available to libc.  It contains only constants,
7  ***   structures, and macros generated from the original header, and thus,
8  ***   contains no copyrightable information.
9  ***
10  ***   To edit the content of this header, modify the corresponding
11  ***   source file (e.g. under external/kernel-headers/original/) then
12  ***   run bionic/libc/kernel/tools/update_all.py
13  ***
14  ***   Any manual change here will be lost the next time this script will
15  ***   be run. You've been warned!
16  ***
17  ****************************************************************************
18  ****************************************************************************/
19 #ifndef _UAPI_LINUX_TCP_H
20 #define _UAPI_LINUX_TCP_H
21 #include <linux/types.h>
22 #include <asm/byteorder.h>
23 #include <linux/socket.h>
24 struct tcphdr {
25   __be16 source;
26   __be16 dest;
27   __be32 seq;
28   __be32 ack_seq;
29 #ifdef __LITTLE_ENDIAN_BITFIELD
30   __u16 res1 : 4, doff : 4, fin : 1, syn : 1, rst : 1, psh : 1, ack : 1, urg : 1, ece : 1, cwr : 1;
31 #elif defined(__BIG_ENDIAN_BITFIELD)
32   __u16 doff : 4, res1 : 4, cwr : 1, ece : 1, urg : 1, ack : 1, psh : 1, rst : 1, syn : 1, fin : 1;
33 #else
34 #error "Adjust your <asm/byteorder.h> defines"
35 #endif
36   __be16 window;
37   __sum16 check;
38   __be16 urg_ptr;
39 };
40 union tcp_word_hdr {
41   struct tcphdr hdr;
42   __be32 words[5];
43 };
44 #define tcp_flag_word(tp) (((union tcp_word_hdr *) (tp))->words[3])
45 enum {
46   TCP_FLAG_CWR = __constant_cpu_to_be32(0x00800000),
47   TCP_FLAG_ECE = __constant_cpu_to_be32(0x00400000),
48   TCP_FLAG_URG = __constant_cpu_to_be32(0x00200000),
49   TCP_FLAG_ACK = __constant_cpu_to_be32(0x00100000),
50   TCP_FLAG_PSH = __constant_cpu_to_be32(0x00080000),
51   TCP_FLAG_RST = __constant_cpu_to_be32(0x00040000),
52   TCP_FLAG_SYN = __constant_cpu_to_be32(0x00020000),
53   TCP_FLAG_FIN = __constant_cpu_to_be32(0x00010000),
54   TCP_RESERVED_BITS = __constant_cpu_to_be32(0x0F000000),
55   TCP_DATA_OFFSET = __constant_cpu_to_be32(0xF0000000)
56 };
57 #define TCP_MSS_DEFAULT 536U
58 #define TCP_MSS_DESIRED 1220U
59 #define TCP_NODELAY 1
60 #define TCP_MAXSEG 2
61 #define TCP_CORK 3
62 #define TCP_KEEPIDLE 4
63 #define TCP_KEEPINTVL 5
64 #define TCP_KEEPCNT 6
65 #define TCP_SYNCNT 7
66 #define TCP_LINGER2 8
67 #define TCP_DEFER_ACCEPT 9
68 #define TCP_WINDOW_CLAMP 10
69 #define TCP_INFO 11
70 #define TCP_QUICKACK 12
71 #define TCP_CONGESTION 13
72 #define TCP_MD5SIG 14
73 #define TCP_THIN_LINEAR_TIMEOUTS 16
74 #define TCP_THIN_DUPACK 17
75 #define TCP_USER_TIMEOUT 18
76 #define TCP_REPAIR 19
77 #define TCP_REPAIR_QUEUE 20
78 #define TCP_QUEUE_SEQ 21
79 #define TCP_REPAIR_OPTIONS 22
80 #define TCP_FASTOPEN 23
81 #define TCP_TIMESTAMP 24
82 #define TCP_NOTSENT_LOWAT 25
83 #define TCP_CC_INFO 26
84 #define TCP_SAVE_SYN 27
85 #define TCP_SAVED_SYN 28
86 #define TCP_REPAIR_WINDOW 29
87 #define TCP_FASTOPEN_CONNECT 30
88 #define TCP_ULP 31
89 #define TCP_MD5SIG_EXT 32
90 #define TCP_FASTOPEN_KEY 33
91 #define TCP_FASTOPEN_NO_COOKIE 34
92 #define TCP_ZEROCOPY_RECEIVE 35
93 #define TCP_INQ 36
94 #define TCP_CM_INQ TCP_INQ
95 #define TCP_REPAIR_ON 1
96 #define TCP_REPAIR_OFF 0
97 #define TCP_REPAIR_OFF_NO_WP - 1
98 struct tcp_repair_opt {
99   __u32 opt_code;
100   __u32 opt_val;
101 };
102 struct tcp_repair_window {
103   __u32 snd_wl1;
104   __u32 snd_wnd;
105   __u32 max_window;
106   __u32 rcv_wnd;
107   __u32 rcv_wup;
108 };
109 enum {
110   TCP_NO_QUEUE,
111   TCP_RECV_QUEUE,
112   TCP_SEND_QUEUE,
113   TCP_QUEUES_NR,
114 };
115 #define TCPI_OPT_TIMESTAMPS 1
116 #define TCPI_OPT_SACK 2
117 #define TCPI_OPT_WSCALE 4
118 #define TCPI_OPT_ECN 8
119 #define TCPI_OPT_ECN_SEEN 16
120 #define TCPI_OPT_SYN_DATA 32
121 enum tcp_ca_state {
122   TCP_CA_Open = 0,
123 #define TCPF_CA_Open (1 << TCP_CA_Open)
124   TCP_CA_Disorder = 1,
125 #define TCPF_CA_Disorder (1 << TCP_CA_Disorder)
126   TCP_CA_CWR = 2,
127 #define TCPF_CA_CWR (1 << TCP_CA_CWR)
128   TCP_CA_Recovery = 3,
129 #define TCPF_CA_Recovery (1 << TCP_CA_Recovery)
130   TCP_CA_Loss = 4
131 #define TCPF_CA_Loss (1 << TCP_CA_Loss)
132 };
133 struct tcp_info {
134   __u8 tcpi_state;
135   __u8 tcpi_ca_state;
136   __u8 tcpi_retransmits;
137   __u8 tcpi_probes;
138   __u8 tcpi_backoff;
139   __u8 tcpi_options;
140   __u8 tcpi_snd_wscale : 4, tcpi_rcv_wscale : 4;
141   __u8 tcpi_delivery_rate_app_limited : 1;
142   __u32 tcpi_rto;
143   __u32 tcpi_ato;
144   __u32 tcpi_snd_mss;
145   __u32 tcpi_rcv_mss;
146   __u32 tcpi_unacked;
147   __u32 tcpi_sacked;
148   __u32 tcpi_lost;
149   __u32 tcpi_retrans;
150   __u32 tcpi_fackets;
151   __u32 tcpi_last_data_sent;
152   __u32 tcpi_last_ack_sent;
153   __u32 tcpi_last_data_recv;
154   __u32 tcpi_last_ack_recv;
155   __u32 tcpi_pmtu;
156   __u32 tcpi_rcv_ssthresh;
157   __u32 tcpi_rtt;
158   __u32 tcpi_rttvar;
159   __u32 tcpi_snd_ssthresh;
160   __u32 tcpi_snd_cwnd;
161   __u32 tcpi_advmss;
162   __u32 tcpi_reordering;
163   __u32 tcpi_rcv_rtt;
164   __u32 tcpi_rcv_space;
165   __u32 tcpi_total_retrans;
166   __u64 tcpi_pacing_rate;
167   __u64 tcpi_max_pacing_rate;
168   __u64 tcpi_bytes_acked;
169   __u64 tcpi_bytes_received;
170   __u32 tcpi_segs_out;
171   __u32 tcpi_segs_in;
172   __u32 tcpi_notsent_bytes;
173   __u32 tcpi_min_rtt;
174   __u32 tcpi_data_segs_in;
175   __u32 tcpi_data_segs_out;
176   __u64 tcpi_delivery_rate;
177   __u64 tcpi_busy_time;
178   __u64 tcpi_rwnd_limited;
179   __u64 tcpi_sndbuf_limited;
180   __u32 tcpi_delivered;
181   __u32 tcpi_delivered_ce;
182   __u64 tcpi_bytes_sent;
183   __u64 tcpi_bytes_retrans;
184   __u32 tcpi_dsack_dups;
185   __u32 tcpi_reord_seen;
186 };
187 enum {
188   TCP_NLA_PAD,
189   TCP_NLA_BUSY,
190   TCP_NLA_RWND_LIMITED,
191   TCP_NLA_SNDBUF_LIMITED,
192   TCP_NLA_DATA_SEGS_OUT,
193   TCP_NLA_TOTAL_RETRANS,
194   TCP_NLA_PACING_RATE,
195   TCP_NLA_DELIVERY_RATE,
196   TCP_NLA_SND_CWND,
197   TCP_NLA_REORDERING,
198   TCP_NLA_MIN_RTT,
199   TCP_NLA_RECUR_RETRANS,
200   TCP_NLA_DELIVERY_RATE_APP_LMT,
201   TCP_NLA_SNDQ_SIZE,
202   TCP_NLA_CA_STATE,
203   TCP_NLA_SND_SSTHRESH,
204   TCP_NLA_DELIVERED,
205   TCP_NLA_DELIVERED_CE,
206   TCP_NLA_BYTES_SENT,
207   TCP_NLA_BYTES_RETRANS,
208   TCP_NLA_DSACK_DUPS,
209   TCP_NLA_REORD_SEEN,
210   TCP_NLA_SRTT,
211 };
212 #define TCP_MD5SIG_MAXKEYLEN 80
213 #define TCP_MD5SIG_FLAG_PREFIX 1
214 struct tcp_md5sig {
215   struct sockaddr_storage tcpm_addr;
216   __u8 tcpm_flags;
217   __u8 tcpm_prefixlen;
218   __u16 tcpm_keylen;
219   __u32 __tcpm_pad;
220   __u8 tcpm_key[TCP_MD5SIG_MAXKEYLEN];
221 };
222 struct tcp_diag_md5sig {
223   __u8 tcpm_family;
224   __u8 tcpm_prefixlen;
225   __u16 tcpm_keylen;
226   __be32 tcpm_addr[4];
227   __u8 tcpm_key[TCP_MD5SIG_MAXKEYLEN];
228 };
229 struct tcp_zerocopy_receive {
230   __u64 address;
231   __u32 length;
232   __u32 recv_skip_hint;
233 };
234 #endif
235