xref: /linux-6.15/include/linux/inet_diag.h (revision db591469)
1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
2a8c2190eSArnaldo Carvalho de Melo #ifndef _INET_DIAG_H_
3a8c2190eSArnaldo Carvalho de Melo #define _INET_DIAG_H_ 1
4a8c2190eSArnaldo Carvalho de Melo 
583f73c5bSDmitry Yakunin #include <net/netlink.h>
6607ca46eSDavid Howells #include <uapi/linux/inet_diag.h>
72df005b7SJaswinder Singh Rajput 
8a8c2190eSArnaldo Carvalho de Melo struct inet_hashinfo;
9a8c2190eSArnaldo Carvalho de Melo 
10a8c2190eSArnaldo Carvalho de Melo struct inet_diag_handler {
11*db591469SEric Dumazet 	struct module	*owner;
121942c518SPavel Emelyanov 	void		(*dump)(struct sk_buff *skb,
131942c518SPavel Emelyanov 				struct netlink_callback *cb,
140df6d328SMartin KaFai Lau 				const struct inet_diag_req_v2 *r);
151942c518SPavel Emelyanov 
165682d393SMartin KaFai Lau 	int		(*dump_one)(struct netlink_callback *cb,
1734160ea3SEric Dumazet 				    const struct inet_diag_req_v2 *req);
181942c518SPavel Emelyanov 
19a8c2190eSArnaldo Carvalho de Melo 	void		(*idiag_get_info)(struct sock *sk,
20a8c2190eSArnaldo Carvalho de Melo 					  struct inet_diag_msg *r,
21a8c2190eSArnaldo Carvalho de Melo 					  void *info);
226eb5d2e0SLorenzo Colitti 
23b37e8840SIvan Delalande 	int		(*idiag_get_aux)(struct sock *sk,
24b37e8840SIvan Delalande 					 bool net_admin,
25b37e8840SIvan Delalande 					 struct sk_buff *skb);
26b37e8840SIvan Delalande 
27b37e8840SIvan Delalande 	size_t		(*idiag_get_aux_size)(struct sock *sk,
28b37e8840SIvan Delalande 					      bool net_admin);
29b37e8840SIvan Delalande 
306eb5d2e0SLorenzo Colitti 	int		(*destroy)(struct sk_buff *in_skb,
316eb5d2e0SLorenzo Colitti 				   const struct inet_diag_req_v2 *req);
326eb5d2e0SLorenzo Colitti 
33a8c2190eSArnaldo Carvalho de Melo 	__u16		idiag_type;
343fd22af8SCraig Gallek 	__u16		idiag_info_size;
35a8c2190eSArnaldo Carvalho de Melo };
36a8c2190eSArnaldo Carvalho de Melo 
37085c20caSMartin KaFai Lau struct bpf_sk_storage_diag;
380df6d328SMartin KaFai Lau struct inet_diag_dump_data {
390df6d328SMartin KaFai Lau 	struct nlattr *req_nlas[__INET_DIAG_REQ_MAX];
400df6d328SMartin KaFai Lau #define inet_diag_nla_bc req_nlas[INET_DIAG_REQ_BYTECODE]
41085c20caSMartin KaFai Lau #define inet_diag_nla_bpf_stgs req_nlas[INET_DIAG_REQ_SK_BPF_STORAGES]
42085c20caSMartin KaFai Lau 
43085c20caSMartin KaFai Lau 	struct bpf_sk_storage_diag *bpf_stg_diag;
440df6d328SMartin KaFai Lau };
450df6d328SMartin KaFai Lau 
463c4d05c8SPavel Emelyanov struct inet_connection_sock;
473c4d05c8SPavel Emelyanov int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk,
485682d393SMartin KaFai Lau 		      struct sk_buff *skb, struct netlink_callback *cb,
495682d393SMartin KaFai Lau 		      const struct inet_diag_req_v2 *req,
505682d393SMartin KaFai Lau 		      u16 nlmsg_flags, bool net_admin);
511942c518SPavel Emelyanov void inet_diag_dump_icsk(struct inet_hashinfo *h, struct sk_buff *skb,
5234160ea3SEric Dumazet 			 struct netlink_callback *cb,
530df6d328SMartin KaFai Lau 			 const struct inet_diag_req_v2 *r);
541942c518SPavel Emelyanov int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo,
555682d393SMartin KaFai Lau 			    struct netlink_callback *cb,
5634160ea3SEric Dumazet 			    const struct inet_diag_req_v2 *req);
571942c518SPavel Emelyanov 
58b613f56eSLorenzo Colitti struct sock *inet_diag_find_one_icsk(struct net *net,
59b613f56eSLorenzo Colitti 				     struct inet_hashinfo *hashinfo,
60b613f56eSLorenzo Colitti 				     const struct inet_diag_req_v2 *req);
61b613f56eSLorenzo Colitti 
628d07d151SPavel Emelyanov int inet_diag_bc_sk(const struct nlattr *_bc, struct sock *sk);
63b005ab4eSPavel Emelyanov 
64c3ec5e5cSBen Dooks void inet_diag_msg_common_fill(struct inet_diag_msg *r, struct sock *sk);
65c3ec5e5cSBen Dooks 
inet_diag_msg_attrs_size(void)6683f73c5bSDmitry Yakunin static inline size_t inet_diag_msg_attrs_size(void)
6783f73c5bSDmitry Yakunin {
6883f73c5bSDmitry Yakunin 	return	  nla_total_size(1)  /* INET_DIAG_SHUTDOWN */
6983f73c5bSDmitry Yakunin 		+ nla_total_size(1)  /* INET_DIAG_TOS */
7083f73c5bSDmitry Yakunin #if IS_ENABLED(CONFIG_IPV6)
7183f73c5bSDmitry Yakunin 		+ nla_total_size(1)  /* INET_DIAG_TCLASS */
7283f73c5bSDmitry Yakunin 		+ nla_total_size(1)  /* INET_DIAG_SKV6ONLY */
7383f73c5bSDmitry Yakunin #endif
7483f73c5bSDmitry Yakunin 		+ nla_total_size(4)  /* INET_DIAG_MARK */
756e3a401fSDmitry Yakunin 		+ nla_total_size(4)  /* INET_DIAG_CLASS_ID */
766e3a401fSDmitry Yakunin #ifdef CONFIG_SOCK_CGROUP_DATA
776e3a401fSDmitry Yakunin 		+ nla_total_size_64bit(sizeof(u64))  /* INET_DIAG_CGROUP_ID */
786e3a401fSDmitry Yakunin #endif
79c1077616SWei Wang 		+ nla_total_size(sizeof(struct inet_diag_sockopt))
80c1077616SWei Wang 						     /* INET_DIAG_SOCKOPT */
816e3a401fSDmitry Yakunin 		;
8283f73c5bSDmitry Yakunin }
83c3ec5e5cSBen Dooks int inet_diag_msg_attrs_fill(struct sock *sk, struct sk_buff *skb,
84c3ec5e5cSBen Dooks 			     struct inet_diag_msg *r, int ext,
85d545cacaSLorenzo Colitti 			     struct user_namespace *user_ns, bool net_admin);
86c3ec5e5cSBen Dooks 
87a8c2190eSArnaldo Carvalho de Melo extern int  inet_diag_register(const struct inet_diag_handler *handler);
88a8c2190eSArnaldo Carvalho de Melo extern void inet_diag_unregister(const struct inet_diag_handler *handler);
89a8c2190eSArnaldo Carvalho de Melo #endif /* _INET_DIAG_H_ */
90