blob: 78972a149dff1224438d5065185317f29e3bf23f [file] [log] [blame]
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -03001#ifndef _INET_DIAG_H_
2#define _INET_DIAG_H_ 1
Linus Torvalds1da177e2005-04-16 15:20:36 -07003
Jaswinder Singh Rajput2df005b2009-01-30 21:42:47 +05304#include <linux/types.h>
5
Linus Torvalds1da177e2005-04-16 15:20:36 -07006/* Just some random number */
7#define TCPDIAG_GETSOCK 18
Arnaldo Carvalho de Melo540722f2005-08-10 05:54:28 -03008#define DCCPDIAG_GETSOCK 19
Pavel Emelyanov8d341722011-12-06 07:57:06 +00009#define SOCK_DIAG_BY_FAMILY 20
Linus Torvalds1da177e2005-04-16 15:20:36 -070010
Arnaldo Carvalho de Melo4f5736c2005-08-12 09:27:49 -030011#define INET_DIAG_GETSOCK_MAX 24
12
Linus Torvalds1da177e2005-04-16 15:20:36 -070013/* Socket identity */
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030014struct inet_diag_sockid {
Al Viro9f855292006-09-27 18:44:30 -070015 __be16 idiag_sport;
16 __be16 idiag_dport;
17 __be32 idiag_src[4];
18 __be32 idiag_dst[4];
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030019 __u32 idiag_if;
20 __u32 idiag_cookie[2];
21#define INET_DIAG_NOCOOKIE (~0U)
Linus Torvalds1da177e2005-04-16 15:20:36 -070022};
23
24/* Request structure */
25
Pavel Emelyanov126fdc32011-12-06 07:58:21 +000026struct inet_diag_req_compat {
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030027 __u8 idiag_family; /* Family of addresses. */
28 __u8 idiag_src_len;
29 __u8 idiag_dst_len;
30 __u8 idiag_ext; /* Query extended information */
Linus Torvalds1da177e2005-04-16 15:20:36 -070031
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030032 struct inet_diag_sockid id;
Linus Torvalds1da177e2005-04-16 15:20:36 -070033
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030034 __u32 idiag_states; /* States to dump */
35 __u32 idiag_dbs; /* Tables to dump (NI) */
Linus Torvalds1da177e2005-04-16 15:20:36 -070036};
37
Pavel Emelyanov126fdc32011-12-06 07:58:21 +000038struct inet_diag_req {
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
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030047enum {
48 INET_DIAG_REQ_NONE,
49 INET_DIAG_REQ_BYTECODE,
Linus Torvalds1da177e2005-04-16 15:20:36 -070050};
51
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030052#define INET_DIAG_REQ_MAX INET_DIAG_REQ_BYTECODE
Linus Torvalds1da177e2005-04-16 15:20:36 -070053
54/* Bytecode is sequence of 4 byte commands followed by variable arguments.
55 * All the commands identified by "code" are conditional jumps forward:
56 * to offset cc+"yes" or to offset cc+"no". "yes" is supposed to be
57 * length of the command and its arguments.
58 */
59
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030060struct inet_diag_bc_op {
Linus Torvalds1da177e2005-04-16 15:20:36 -070061 unsigned char code;
62 unsigned char yes;
63 unsigned short no;
64};
65
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030066enum {
67 INET_DIAG_BC_NOP,
68 INET_DIAG_BC_JMP,
69 INET_DIAG_BC_S_GE,
70 INET_DIAG_BC_S_LE,
71 INET_DIAG_BC_D_GE,
72 INET_DIAG_BC_D_LE,
73 INET_DIAG_BC_AUTO,
74 INET_DIAG_BC_S_COND,
75 INET_DIAG_BC_D_COND,
Linus Torvalds1da177e2005-04-16 15:20:36 -070076};
77
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030078struct inet_diag_hostcond {
Linus Torvalds1da177e2005-04-16 15:20:36 -070079 __u8 family;
80 __u8 prefix_len;
81 int port;
Al Viro9f855292006-09-27 18:44:30 -070082 __be32 addr[0];
Linus Torvalds1da177e2005-04-16 15:20:36 -070083};
84
85/* Base info structure. It contains socket identity (addrs/ports/cookie)
86 * and, alas, the information shown by netstat. */
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030087struct inet_diag_msg {
88 __u8 idiag_family;
89 __u8 idiag_state;
90 __u8 idiag_timer;
91 __u8 idiag_retrans;
Linus Torvalds1da177e2005-04-16 15:20:36 -070092
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030093 struct inet_diag_sockid id;
Linus Torvalds1da177e2005-04-16 15:20:36 -070094
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -030095 __u32 idiag_expires;
96 __u32 idiag_rqueue;
97 __u32 idiag_wqueue;
98 __u32 idiag_uid;
99 __u32 idiag_inode;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100};
101
102/* Extensions */
103
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -0300104enum {
105 INET_DIAG_NONE,
106 INET_DIAG_MEMINFO,
107 INET_DIAG_INFO,
108 INET_DIAG_VEGASINFO,
109 INET_DIAG_CONG,
Murali Raja3ceca742011-10-12 09:00:35 +0000110 INET_DIAG_TOS,
Maciej Żenczykowski06236ac2011-11-07 14:23:11 +0000111 INET_DIAG_TCLASS,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700112};
113
Maciej Żenczykowski06236ac2011-11-07 14:23:11 +0000114#define INET_DIAG_MAX INET_DIAG_TCLASS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700115
116
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -0300117/* INET_DIAG_MEM */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700118
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -0300119struct inet_diag_meminfo {
120 __u32 idiag_rmem;
121 __u32 idiag_wmem;
122 __u32 idiag_fmem;
123 __u32 idiag_tmem;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700124};
125
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -0300126/* INET_DIAG_VEGASINFO */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700127
128struct tcpvegas_info {
129 __u32 tcpv_enabled;
130 __u32 tcpv_rttcnt;
131 __u32 tcpv_rtt;
132 __u32 tcpv_minrtt;
133};
134
Arnaldo Carvalho de Melo4f5736c2005-08-12 09:27:49 -0300135#ifdef __KERNEL__
136struct sock;
137struct inet_hashinfo;
Pavel Emelyanov8d07d152011-12-09 06:22:44 +0000138struct nlattr;
Pavel Emelyanov3c4d05c2011-12-09 06:23:00 +0000139struct nlmsghdr;
140struct sk_buff;
Pavel Emelyanov1942c512011-12-09 06:23:18 +0000141struct netlink_callback;
Arnaldo Carvalho de Melo4f5736c2005-08-12 09:27:49 -0300142
143struct inet_diag_handler {
Pavel Emelyanov1942c512011-12-09 06:23:18 +0000144 void (*dump)(struct sk_buff *skb,
145 struct netlink_callback *cb,
146 struct inet_diag_req *r,
147 struct nlattr *bc);
148
149 int (*dump_one)(struct sk_buff *in_skb,
150 const struct nlmsghdr *nlh,
151 struct inet_diag_req *req);
152
Arnaldo Carvalho de Melo4f5736c2005-08-12 09:27:49 -0300153 void (*idiag_get_info)(struct sock *sk,
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -0300154 struct inet_diag_msg *r,
Arnaldo Carvalho de Melo4f5736c2005-08-12 09:27:49 -0300155 void *info);
Arnaldo Carvalho de Melo4f5736c2005-08-12 09:27:49 -0300156 __u16 idiag_type;
157};
158
Pavel Emelyanov3c4d05c2011-12-09 06:23:00 +0000159struct inet_connection_sock;
160int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk,
161 struct sk_buff *skb, struct inet_diag_req *req,
162 u32 pid, u32 seq, u16 nlmsg_flags,
163 const struct nlmsghdr *unlh);
Pavel Emelyanov1942c512011-12-09 06:23:18 +0000164void inet_diag_dump_icsk(struct inet_hashinfo *h, struct sk_buff *skb,
165 struct netlink_callback *cb, struct inet_diag_req *r,
166 struct nlattr *bc);
167int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo,
168 struct sk_buff *in_skb, const struct nlmsghdr *nlh,
169 struct inet_diag_req *req);
170
Pavel Emelyanov8d07d152011-12-09 06:22:44 +0000171int inet_diag_bc_sk(const struct nlattr *_bc, struct sock *sk);
Pavel Emelyanovb005ab42011-12-09 06:21:53 +0000172int inet_diag_check_cookie(struct sock *sk, struct inet_diag_req *req);
173
Arnaldo Carvalho de Melo4f5736c2005-08-12 09:27:49 -0300174extern int inet_diag_register(const struct inet_diag_handler *handler);
175extern void inet_diag_unregister(const struct inet_diag_handler *handler);
176#endif /* __KERNEL__ */
177
Arnaldo Carvalho de Melo73c1f4a2005-08-12 12:51:49 -0300178#endif /* _INET_DIAG_H_ */