1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ 2*4882a593Smuzhiyun #ifndef _UAPI_INET_DIAG_H_ 3*4882a593Smuzhiyun #define _UAPI_INET_DIAG_H_ 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun #include <linux/types.h> 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun /* Just some random number */ 8*4882a593Smuzhiyun #define TCPDIAG_GETSOCK 18 9*4882a593Smuzhiyun #define DCCPDIAG_GETSOCK 19 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #define INET_DIAG_GETSOCK_MAX 24 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun /* Socket identity */ 14*4882a593Smuzhiyun struct inet_diag_sockid { 15*4882a593Smuzhiyun __be16 idiag_sport; 16*4882a593Smuzhiyun __be16 idiag_dport; 17*4882a593Smuzhiyun __be32 idiag_src[4]; 18*4882a593Smuzhiyun __be32 idiag_dst[4]; 19*4882a593Smuzhiyun __u32 idiag_if; 20*4882a593Smuzhiyun __u32 idiag_cookie[2]; 21*4882a593Smuzhiyun #define INET_DIAG_NOCOOKIE (~0U) 22*4882a593Smuzhiyun }; 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun /* Request structure */ 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun struct inet_diag_req { 27*4882a593Smuzhiyun __u8 idiag_family; /* Family of addresses. */ 28*4882a593Smuzhiyun __u8 idiag_src_len; 29*4882a593Smuzhiyun __u8 idiag_dst_len; 30*4882a593Smuzhiyun __u8 idiag_ext; /* Query extended information */ 31*4882a593Smuzhiyun 32*4882a593Smuzhiyun struct inet_diag_sockid id; 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun __u32 idiag_states; /* States to dump */ 35*4882a593Smuzhiyun __u32 idiag_dbs; /* Tables to dump (NI) */ 36*4882a593Smuzhiyun }; 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun struct inet_diag_req_v2 { 39*4882a593Smuzhiyun __u8 sdiag_family; 40*4882a593Smuzhiyun __u8 sdiag_protocol; 41*4882a593Smuzhiyun __u8 idiag_ext; 42*4882a593Smuzhiyun __u8 pad; 43*4882a593Smuzhiyun __u32 idiag_states; 44*4882a593Smuzhiyun struct inet_diag_sockid id; 45*4882a593Smuzhiyun }; 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun /* 48*4882a593Smuzhiyun * SOCK_RAW sockets require the underlied protocol to be 49*4882a593Smuzhiyun * additionally specified so we can use @pad member for 50*4882a593Smuzhiyun * this, but we can't rename it because userspace programs 51*4882a593Smuzhiyun * still may depend on this name. Instead lets use another 52*4882a593Smuzhiyun * structure definition as an alias for struct 53*4882a593Smuzhiyun * @inet_diag_req_v2. 54*4882a593Smuzhiyun */ 55*4882a593Smuzhiyun struct inet_diag_req_raw { 56*4882a593Smuzhiyun __u8 sdiag_family; 57*4882a593Smuzhiyun __u8 sdiag_protocol; 58*4882a593Smuzhiyun __u8 idiag_ext; 59*4882a593Smuzhiyun __u8 sdiag_raw_protocol; 60*4882a593Smuzhiyun __u32 idiag_states; 61*4882a593Smuzhiyun struct inet_diag_sockid id; 62*4882a593Smuzhiyun }; 63*4882a593Smuzhiyun 64*4882a593Smuzhiyun enum { 65*4882a593Smuzhiyun INET_DIAG_REQ_NONE, 66*4882a593Smuzhiyun INET_DIAG_REQ_BYTECODE, 67*4882a593Smuzhiyun INET_DIAG_REQ_SK_BPF_STORAGES, 68*4882a593Smuzhiyun INET_DIAG_REQ_PROTOCOL, 69*4882a593Smuzhiyun __INET_DIAG_REQ_MAX, 70*4882a593Smuzhiyun }; 71*4882a593Smuzhiyun 72*4882a593Smuzhiyun #define INET_DIAG_REQ_MAX (__INET_DIAG_REQ_MAX - 1) 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun /* Bytecode is sequence of 4 byte commands followed by variable arguments. 75*4882a593Smuzhiyun * All the commands identified by "code" are conditional jumps forward: 76*4882a593Smuzhiyun * to offset cc+"yes" or to offset cc+"no". "yes" is supposed to be 77*4882a593Smuzhiyun * length of the command and its arguments. 78*4882a593Smuzhiyun */ 79*4882a593Smuzhiyun 80*4882a593Smuzhiyun struct inet_diag_bc_op { 81*4882a593Smuzhiyun unsigned char code; 82*4882a593Smuzhiyun unsigned char yes; 83*4882a593Smuzhiyun unsigned short no; 84*4882a593Smuzhiyun }; 85*4882a593Smuzhiyun 86*4882a593Smuzhiyun enum { 87*4882a593Smuzhiyun INET_DIAG_BC_NOP, 88*4882a593Smuzhiyun INET_DIAG_BC_JMP, 89*4882a593Smuzhiyun INET_DIAG_BC_S_GE, 90*4882a593Smuzhiyun INET_DIAG_BC_S_LE, 91*4882a593Smuzhiyun INET_DIAG_BC_D_GE, 92*4882a593Smuzhiyun INET_DIAG_BC_D_LE, 93*4882a593Smuzhiyun INET_DIAG_BC_AUTO, 94*4882a593Smuzhiyun INET_DIAG_BC_S_COND, 95*4882a593Smuzhiyun INET_DIAG_BC_D_COND, 96*4882a593Smuzhiyun INET_DIAG_BC_DEV_COND, /* u32 ifindex */ 97*4882a593Smuzhiyun INET_DIAG_BC_MARK_COND, 98*4882a593Smuzhiyun INET_DIAG_BC_S_EQ, 99*4882a593Smuzhiyun INET_DIAG_BC_D_EQ, 100*4882a593Smuzhiyun INET_DIAG_BC_CGROUP_COND, /* u64 cgroup v2 ID */ 101*4882a593Smuzhiyun }; 102*4882a593Smuzhiyun 103*4882a593Smuzhiyun struct inet_diag_hostcond { 104*4882a593Smuzhiyun __u8 family; 105*4882a593Smuzhiyun __u8 prefix_len; 106*4882a593Smuzhiyun int port; 107*4882a593Smuzhiyun __be32 addr[0]; 108*4882a593Smuzhiyun }; 109*4882a593Smuzhiyun 110*4882a593Smuzhiyun struct inet_diag_markcond { 111*4882a593Smuzhiyun __u32 mark; 112*4882a593Smuzhiyun __u32 mask; 113*4882a593Smuzhiyun }; 114*4882a593Smuzhiyun 115*4882a593Smuzhiyun /* Base info structure. It contains socket identity (addrs/ports/cookie) 116*4882a593Smuzhiyun * and, alas, the information shown by netstat. */ 117*4882a593Smuzhiyun struct inet_diag_msg { 118*4882a593Smuzhiyun __u8 idiag_family; 119*4882a593Smuzhiyun __u8 idiag_state; 120*4882a593Smuzhiyun __u8 idiag_timer; 121*4882a593Smuzhiyun __u8 idiag_retrans; 122*4882a593Smuzhiyun 123*4882a593Smuzhiyun struct inet_diag_sockid id; 124*4882a593Smuzhiyun 125*4882a593Smuzhiyun __u32 idiag_expires; 126*4882a593Smuzhiyun __u32 idiag_rqueue; 127*4882a593Smuzhiyun __u32 idiag_wqueue; 128*4882a593Smuzhiyun __u32 idiag_uid; 129*4882a593Smuzhiyun __u32 idiag_inode; 130*4882a593Smuzhiyun }; 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun /* Extensions */ 133*4882a593Smuzhiyun 134*4882a593Smuzhiyun enum { 135*4882a593Smuzhiyun INET_DIAG_NONE, 136*4882a593Smuzhiyun INET_DIAG_MEMINFO, 137*4882a593Smuzhiyun INET_DIAG_INFO, 138*4882a593Smuzhiyun INET_DIAG_VEGASINFO, 139*4882a593Smuzhiyun INET_DIAG_CONG, 140*4882a593Smuzhiyun INET_DIAG_TOS, 141*4882a593Smuzhiyun INET_DIAG_TCLASS, 142*4882a593Smuzhiyun INET_DIAG_SKMEMINFO, 143*4882a593Smuzhiyun INET_DIAG_SHUTDOWN, 144*4882a593Smuzhiyun 145*4882a593Smuzhiyun /* 146*4882a593Smuzhiyun * Next extenstions cannot be requested in struct inet_diag_req_v2: 147*4882a593Smuzhiyun * its field idiag_ext has only 8 bits. 148*4882a593Smuzhiyun */ 149*4882a593Smuzhiyun 150*4882a593Smuzhiyun INET_DIAG_DCTCPINFO, /* request as INET_DIAG_VEGASINFO */ 151*4882a593Smuzhiyun INET_DIAG_PROTOCOL, /* response attribute only */ 152*4882a593Smuzhiyun INET_DIAG_SKV6ONLY, 153*4882a593Smuzhiyun INET_DIAG_LOCALS, 154*4882a593Smuzhiyun INET_DIAG_PEERS, 155*4882a593Smuzhiyun INET_DIAG_PAD, 156*4882a593Smuzhiyun INET_DIAG_MARK, /* only with CAP_NET_ADMIN */ 157*4882a593Smuzhiyun INET_DIAG_BBRINFO, /* request as INET_DIAG_VEGASINFO */ 158*4882a593Smuzhiyun INET_DIAG_CLASS_ID, /* request as INET_DIAG_TCLASS */ 159*4882a593Smuzhiyun INET_DIAG_MD5SIG, 160*4882a593Smuzhiyun INET_DIAG_ULP_INFO, 161*4882a593Smuzhiyun INET_DIAG_SK_BPF_STORAGES, 162*4882a593Smuzhiyun INET_DIAG_CGROUP_ID, 163*4882a593Smuzhiyun INET_DIAG_SOCKOPT, 164*4882a593Smuzhiyun __INET_DIAG_MAX, 165*4882a593Smuzhiyun }; 166*4882a593Smuzhiyun 167*4882a593Smuzhiyun #define INET_DIAG_MAX (__INET_DIAG_MAX - 1) 168*4882a593Smuzhiyun 169*4882a593Smuzhiyun enum { 170*4882a593Smuzhiyun INET_ULP_INFO_UNSPEC, 171*4882a593Smuzhiyun INET_ULP_INFO_NAME, 172*4882a593Smuzhiyun INET_ULP_INFO_TLS, 173*4882a593Smuzhiyun INET_ULP_INFO_MPTCP, 174*4882a593Smuzhiyun __INET_ULP_INFO_MAX, 175*4882a593Smuzhiyun }; 176*4882a593Smuzhiyun #define INET_ULP_INFO_MAX (__INET_ULP_INFO_MAX - 1) 177*4882a593Smuzhiyun 178*4882a593Smuzhiyun /* INET_DIAG_MEM */ 179*4882a593Smuzhiyun 180*4882a593Smuzhiyun struct inet_diag_meminfo { 181*4882a593Smuzhiyun __u32 idiag_rmem; 182*4882a593Smuzhiyun __u32 idiag_wmem; 183*4882a593Smuzhiyun __u32 idiag_fmem; 184*4882a593Smuzhiyun __u32 idiag_tmem; 185*4882a593Smuzhiyun }; 186*4882a593Smuzhiyun 187*4882a593Smuzhiyun /* INET_DIAG_SOCKOPT */ 188*4882a593Smuzhiyun 189*4882a593Smuzhiyun struct inet_diag_sockopt { 190*4882a593Smuzhiyun __u8 recverr:1, 191*4882a593Smuzhiyun is_icsk:1, 192*4882a593Smuzhiyun freebind:1, 193*4882a593Smuzhiyun hdrincl:1, 194*4882a593Smuzhiyun mc_loop:1, 195*4882a593Smuzhiyun transparent:1, 196*4882a593Smuzhiyun mc_all:1, 197*4882a593Smuzhiyun nodefrag:1; 198*4882a593Smuzhiyun __u8 bind_address_no_port:1, 199*4882a593Smuzhiyun recverr_rfc4884:1, 200*4882a593Smuzhiyun defer_connect:1, 201*4882a593Smuzhiyun unused:5; 202*4882a593Smuzhiyun }; 203*4882a593Smuzhiyun 204*4882a593Smuzhiyun /* INET_DIAG_VEGASINFO */ 205*4882a593Smuzhiyun 206*4882a593Smuzhiyun struct tcpvegas_info { 207*4882a593Smuzhiyun __u32 tcpv_enabled; 208*4882a593Smuzhiyun __u32 tcpv_rttcnt; 209*4882a593Smuzhiyun __u32 tcpv_rtt; 210*4882a593Smuzhiyun __u32 tcpv_minrtt; 211*4882a593Smuzhiyun }; 212*4882a593Smuzhiyun 213*4882a593Smuzhiyun /* INET_DIAG_DCTCPINFO */ 214*4882a593Smuzhiyun 215*4882a593Smuzhiyun struct tcp_dctcp_info { 216*4882a593Smuzhiyun __u16 dctcp_enabled; 217*4882a593Smuzhiyun __u16 dctcp_ce_state; 218*4882a593Smuzhiyun __u32 dctcp_alpha; 219*4882a593Smuzhiyun __u32 dctcp_ab_ecn; 220*4882a593Smuzhiyun __u32 dctcp_ab_tot; 221*4882a593Smuzhiyun }; 222*4882a593Smuzhiyun 223*4882a593Smuzhiyun /* INET_DIAG_BBRINFO */ 224*4882a593Smuzhiyun 225*4882a593Smuzhiyun struct tcp_bbr_info { 226*4882a593Smuzhiyun /* u64 bw: max-filtered BW (app throughput) estimate in Byte per sec: */ 227*4882a593Smuzhiyun __u32 bbr_bw_lo; /* lower 32 bits of bw */ 228*4882a593Smuzhiyun __u32 bbr_bw_hi; /* upper 32 bits of bw */ 229*4882a593Smuzhiyun __u32 bbr_min_rtt; /* min-filtered RTT in uSec */ 230*4882a593Smuzhiyun __u32 bbr_pacing_gain; /* pacing gain shifted left 8 bits */ 231*4882a593Smuzhiyun __u32 bbr_cwnd_gain; /* cwnd gain shifted left 8 bits */ 232*4882a593Smuzhiyun }; 233*4882a593Smuzhiyun 234*4882a593Smuzhiyun union tcp_cc_info { 235*4882a593Smuzhiyun struct tcpvegas_info vegas; 236*4882a593Smuzhiyun struct tcp_dctcp_info dctcp; 237*4882a593Smuzhiyun struct tcp_bbr_info bbr; 238*4882a593Smuzhiyun }; 239*4882a593Smuzhiyun #endif /* _UAPI_INET_DIAG_H_ */ 240