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