| /* SPDX-License-Identifier: GPL-2.0 */ |
| #ifndef _INET_DIAG_H_ |
| #define _INET_DIAG_H_ 1 |
| |
| #include <net/netlink.h> |
| #include <uapi/linux/inet_diag.h> |
| |
| struct inet_hashinfo; |
| |
| struct inet_diag_handler { |
| void (*dump)(struct sk_buff *skb, |
| struct netlink_callback *cb, |
| const struct inet_diag_req_v2 *r); |
| |
| int (*dump_one)(struct netlink_callback *cb, |
| const struct inet_diag_req_v2 *req); |
| |
| void (*idiag_get_info)(struct sock *sk, |
| struct inet_diag_msg *r, |
| void *info); |
| |
| int (*idiag_get_aux)(struct sock *sk, |
| bool net_admin, |
| struct sk_buff *skb); |
| |
| size_t (*idiag_get_aux_size)(struct sock *sk, |
| bool net_admin); |
| |
| int (*destroy)(struct sk_buff *in_skb, |
| const struct inet_diag_req_v2 *req); |
| |
| __u16 idiag_type; |
| __u16 idiag_info_size; |
| }; |
| |
| struct bpf_sk_storage_diag; |
| struct inet_diag_dump_data { |
| struct nlattr *req_nlas[__INET_DIAG_REQ_MAX]; |
| #define inet_diag_nla_bc req_nlas[INET_DIAG_REQ_BYTECODE] |
| #define inet_diag_nla_bpf_stgs req_nlas[INET_DIAG_REQ_SK_BPF_STORAGES] |
| |
| struct bpf_sk_storage_diag *bpf_stg_diag; |
| }; |
| |
| struct inet_connection_sock; |
| int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk, |
| struct sk_buff *skb, struct netlink_callback *cb, |
| const struct inet_diag_req_v2 *req, |
| u16 nlmsg_flags, bool net_admin); |
| void inet_diag_dump_icsk(struct inet_hashinfo *h, struct sk_buff *skb, |
| struct netlink_callback *cb, |
| const struct inet_diag_req_v2 *r); |
| int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo, |
| struct netlink_callback *cb, |
| const struct inet_diag_req_v2 *req); |
| |
| struct sock *inet_diag_find_one_icsk(struct net *net, |
| struct inet_hashinfo *hashinfo, |
| const struct inet_diag_req_v2 *req); |
| |
| int inet_diag_bc_sk(const struct nlattr *_bc, struct sock *sk); |
| |
| void inet_diag_msg_common_fill(struct inet_diag_msg *r, struct sock *sk); |
| |
| static inline size_t inet_diag_msg_attrs_size(void) |
| { |
| return nla_total_size(1) /* INET_DIAG_SHUTDOWN */ |
| + nla_total_size(1) /* INET_DIAG_TOS */ |
| #if IS_ENABLED(CONFIG_IPV6) |
| + nla_total_size(1) /* INET_DIAG_TCLASS */ |
| + nla_total_size(1) /* INET_DIAG_SKV6ONLY */ |
| #endif |
| + nla_total_size(4) /* INET_DIAG_MARK */ |
| + nla_total_size(4) /* INET_DIAG_CLASS_ID */ |
| #ifdef CONFIG_SOCK_CGROUP_DATA |
| + nla_total_size_64bit(sizeof(u64)) /* INET_DIAG_CGROUP_ID */ |
| #endif |
| + nla_total_size(sizeof(struct inet_diag_sockopt)) |
| /* INET_DIAG_SOCKOPT */ |
| ; |
| } |
| int inet_diag_msg_attrs_fill(struct sock *sk, struct sk_buff *skb, |
| struct inet_diag_msg *r, int ext, |
| struct user_namespace *user_ns, bool net_admin); |
| |
| extern int inet_diag_register(const struct inet_diag_handler *handler); |
| extern void inet_diag_unregister(const struct inet_diag_handler *handler); |
| #endif /* _INET_DIAG_H_ */ |