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_TX_DELAY 37
96 #define TCP_REPAIR_ON 1
97 #define TCP_REPAIR_OFF 0
98 #define TCP_REPAIR_OFF_NO_WP - 1
99 struct tcp_repair_opt {
100   __u32 opt_code;
101   __u32 opt_val;
102 };
103 struct tcp_repair_window {
104   __u32 snd_wl1;
105   __u32 snd_wnd;
106   __u32 max_window;
107   __u32 rcv_wnd;
108   __u32 rcv_wup;
109 };
110 enum {
111   TCP_NO_QUEUE,
112   TCP_RECV_QUEUE,
113   TCP_SEND_QUEUE,
114   TCP_QUEUES_NR,
115 };
116 enum tcp_fastopen_client_fail {
117   TFO_STATUS_UNSPEC,
118   TFO_COOKIE_UNAVAILABLE,
119   TFO_DATA_NOT_ACKED,
120   TFO_SYN_RETRANSMITTED,
121 };
122 #define TCPI_OPT_TIMESTAMPS 1
123 #define TCPI_OPT_SACK 2
124 #define TCPI_OPT_WSCALE 4
125 #define TCPI_OPT_ECN 8
126 #define TCPI_OPT_ECN_SEEN 16
127 #define TCPI_OPT_SYN_DATA 32
128 enum tcp_ca_state {
129   TCP_CA_Open = 0,
130 #define TCPF_CA_Open (1 << TCP_CA_Open)
131   TCP_CA_Disorder = 1,
132 #define TCPF_CA_Disorder (1 << TCP_CA_Disorder)
133   TCP_CA_CWR = 2,
134 #define TCPF_CA_CWR (1 << TCP_CA_CWR)
135   TCP_CA_Recovery = 3,
136 #define TCPF_CA_Recovery (1 << TCP_CA_Recovery)
137   TCP_CA_Loss = 4
138 #define TCPF_CA_Loss (1 << TCP_CA_Loss)
139 };
140 struct tcp_info {
141   __u8 tcpi_state;
142   __u8 tcpi_ca_state;
143   __u8 tcpi_retransmits;
144   __u8 tcpi_probes;
145   __u8 tcpi_backoff;
146   __u8 tcpi_options;
147   __u8 tcpi_snd_wscale : 4, tcpi_rcv_wscale : 4;
148   __u8 tcpi_delivery_rate_app_limited : 1, tcpi_fastopen_client_fail : 2;
149   __u32 tcpi_rto;
150   __u32 tcpi_ato;
151   __u32 tcpi_snd_mss;
152   __u32 tcpi_rcv_mss;
153   __u32 tcpi_unacked;
154   __u32 tcpi_sacked;
155   __u32 tcpi_lost;
156   __u32 tcpi_retrans;
157   __u32 tcpi_fackets;
158   __u32 tcpi_last_data_sent;
159   __u32 tcpi_last_ack_sent;
160   __u32 tcpi_last_data_recv;
161   __u32 tcpi_last_ack_recv;
162   __u32 tcpi_pmtu;
163   __u32 tcpi_rcv_ssthresh;
164   __u32 tcpi_rtt;
165   __u32 tcpi_rttvar;
166   __u32 tcpi_snd_ssthresh;
167   __u32 tcpi_snd_cwnd;
168   __u32 tcpi_advmss;
169   __u32 tcpi_reordering;
170   __u32 tcpi_rcv_rtt;
171   __u32 tcpi_rcv_space;
172   __u32 tcpi_total_retrans;
173   __u64 tcpi_pacing_rate;
174   __u64 tcpi_max_pacing_rate;
175   __u64 tcpi_bytes_acked;
176   __u64 tcpi_bytes_received;
177   __u32 tcpi_segs_out;
178   __u32 tcpi_segs_in;
179   __u32 tcpi_notsent_bytes;
180   __u32 tcpi_min_rtt;
181   __u32 tcpi_data_segs_in;
182   __u32 tcpi_data_segs_out;
183   __u64 tcpi_delivery_rate;
184   __u64 tcpi_busy_time;
185   __u64 tcpi_rwnd_limited;
186   __u64 tcpi_sndbuf_limited;
187   __u32 tcpi_delivered;
188   __u32 tcpi_delivered_ce;
189   __u64 tcpi_bytes_sent;
190   __u64 tcpi_bytes_retrans;
191   __u32 tcpi_dsack_dups;
192   __u32 tcpi_reord_seen;
193   __u32 tcpi_rcv_ooopack;
194   __u32 tcpi_snd_wnd;
195 };
196 enum {
197   TCP_NLA_PAD,
198   TCP_NLA_BUSY,
199   TCP_NLA_RWND_LIMITED,
200   TCP_NLA_SNDBUF_LIMITED,
201   TCP_NLA_DATA_SEGS_OUT,
202   TCP_NLA_TOTAL_RETRANS,
203   TCP_NLA_PACING_RATE,
204   TCP_NLA_DELIVERY_RATE,
205   TCP_NLA_SND_CWND,
206   TCP_NLA_REORDERING,
207   TCP_NLA_MIN_RTT,
208   TCP_NLA_RECUR_RETRANS,
209   TCP_NLA_DELIVERY_RATE_APP_LMT,
210   TCP_NLA_SNDQ_SIZE,
211   TCP_NLA_CA_STATE,
212   TCP_NLA_SND_SSTHRESH,
213   TCP_NLA_DELIVERED,
214   TCP_NLA_DELIVERED_CE,
215   TCP_NLA_BYTES_SENT,
216   TCP_NLA_BYTES_RETRANS,
217   TCP_NLA_DSACK_DUPS,
218   TCP_NLA_REORD_SEEN,
219   TCP_NLA_SRTT,
220   TCP_NLA_TIMEOUT_REHASH,
221   TCP_NLA_BYTES_NOTSENT,
222 };
223 #define TCP_MD5SIG_MAXKEYLEN 80
224 #define TCP_MD5SIG_FLAG_PREFIX 0x1
225 #define TCP_MD5SIG_FLAG_IFINDEX 0x2
226 struct tcp_md5sig {
227   struct sockaddr_storage tcpm_addr;
228   __u8 tcpm_flags;
229   __u8 tcpm_prefixlen;
230   __u16 tcpm_keylen;
231   int tcpm_ifindex;
232   __u8 tcpm_key[TCP_MD5SIG_MAXKEYLEN];
233 };
234 struct tcp_diag_md5sig {
235   __u8 tcpm_family;
236   __u8 tcpm_prefixlen;
237   __u16 tcpm_keylen;
238   __be32 tcpm_addr[4];
239   __u8 tcpm_key[TCP_MD5SIG_MAXKEYLEN];
240 };
241 struct tcp_zerocopy_receive {
242   __u64 address;
243   __u32 length;
244   __u32 recv_skip_hint;
245   __u32 inq;
246   __s32 err;
247 };
248 #endif
249