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