hc
2023-12-02 57e32c52610e6a560beda60bf33c48f9f42306d5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/* 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,
               struct nlattr *bc);
 
   int        (*dump_one)(struct sk_buff *in_skb,
                   const struct nlmsghdr *nlh,
                   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 inet_connection_sock;
int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk,
             struct sk_buff *skb, const struct inet_diag_req_v2 *req,
             struct user_namespace *user_ns,
             u32 pid, u32 seq, u16 nlmsg_flags,
             const struct nlmsghdr *unlh, 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,
            struct nlattr *bc);
int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo,
               struct sk_buff *in_skb, const struct nlmsghdr *nlh,
               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 */
}
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_ */