inet_diag.h (2801B)
1/* SPDX-License-Identifier: GPL-2.0 */ 2#ifndef _INET_DIAG_H_ 3#define _INET_DIAG_H_ 1 4 5#include <net/netlink.h> 6#include <uapi/linux/inet_diag.h> 7 8struct inet_hashinfo; 9 10struct inet_diag_handler { 11 void (*dump)(struct sk_buff *skb, 12 struct netlink_callback *cb, 13 const struct inet_diag_req_v2 *r); 14 15 int (*dump_one)(struct netlink_callback *cb, 16 const struct inet_diag_req_v2 *req); 17 18 void (*idiag_get_info)(struct sock *sk, 19 struct inet_diag_msg *r, 20 void *info); 21 22 int (*idiag_get_aux)(struct sock *sk, 23 bool net_admin, 24 struct sk_buff *skb); 25 26 size_t (*idiag_get_aux_size)(struct sock *sk, 27 bool net_admin); 28 29 int (*destroy)(struct sk_buff *in_skb, 30 const struct inet_diag_req_v2 *req); 31 32 __u16 idiag_type; 33 __u16 idiag_info_size; 34}; 35 36struct bpf_sk_storage_diag; 37struct inet_diag_dump_data { 38 struct nlattr *req_nlas[__INET_DIAG_REQ_MAX]; 39#define inet_diag_nla_bc req_nlas[INET_DIAG_REQ_BYTECODE] 40#define inet_diag_nla_bpf_stgs req_nlas[INET_DIAG_REQ_SK_BPF_STORAGES] 41 42 struct bpf_sk_storage_diag *bpf_stg_diag; 43}; 44 45struct inet_connection_sock; 46int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk, 47 struct sk_buff *skb, struct netlink_callback *cb, 48 const struct inet_diag_req_v2 *req, 49 u16 nlmsg_flags, bool net_admin); 50void inet_diag_dump_icsk(struct inet_hashinfo *h, struct sk_buff *skb, 51 struct netlink_callback *cb, 52 const struct inet_diag_req_v2 *r); 53int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo, 54 struct netlink_callback *cb, 55 const struct inet_diag_req_v2 *req); 56 57struct sock *inet_diag_find_one_icsk(struct net *net, 58 struct inet_hashinfo *hashinfo, 59 const struct inet_diag_req_v2 *req); 60 61int inet_diag_bc_sk(const struct nlattr *_bc, struct sock *sk); 62 63void inet_diag_msg_common_fill(struct inet_diag_msg *r, struct sock *sk); 64 65static inline size_t inet_diag_msg_attrs_size(void) 66{ 67 return nla_total_size(1) /* INET_DIAG_SHUTDOWN */ 68 + nla_total_size(1) /* INET_DIAG_TOS */ 69#if IS_ENABLED(CONFIG_IPV6) 70 + nla_total_size(1) /* INET_DIAG_TCLASS */ 71 + nla_total_size(1) /* INET_DIAG_SKV6ONLY */ 72#endif 73 + nla_total_size(4) /* INET_DIAG_MARK */ 74 + nla_total_size(4) /* INET_DIAG_CLASS_ID */ 75#ifdef CONFIG_SOCK_CGROUP_DATA 76 + nla_total_size_64bit(sizeof(u64)) /* INET_DIAG_CGROUP_ID */ 77#endif 78 + nla_total_size(sizeof(struct inet_diag_sockopt)) 79 /* INET_DIAG_SOCKOPT */ 80 ; 81} 82int inet_diag_msg_attrs_fill(struct sock *sk, struct sk_buff *skb, 83 struct inet_diag_msg *r, int ext, 84 struct user_namespace *user_ns, bool net_admin); 85 86extern int inet_diag_register(const struct inet_diag_handler *handler); 87extern void inet_diag_unregister(const struct inet_diag_handler *handler); 88#endif /* _INET_DIAG_H_ */