Contributors: 20
Author |
Tokens |
Token Proportion |
Commits |
Commit Proportion |
Pavel Emelyanov |
126 |
28.64% |
8 |
22.22% |
Arnaldo Carvalho de Melo |
83 |
18.86% |
3 |
8.33% |
Xin Long |
47 |
10.68% |
1 |
2.78% |
Martin KaFai Lau |
38 |
8.64% |
3 |
8.33% |
Lorenzo Colitti |
30 |
6.82% |
3 |
8.33% |
Dmitry Yakunin |
29 |
6.59% |
2 |
5.56% |
Ivan Delalande |
22 |
5.00% |
1 |
2.78% |
Eric Dumazet |
11 |
2.50% |
2 |
5.56% |
Herbert Xu |
10 |
2.27% |
2 |
5.56% |
Linus Torvalds |
8 |
1.82% |
1 |
2.78% |
Eric W. Biedermann |
6 |
1.36% |
1 |
2.78% |
Linus Torvalds (pre-git) |
6 |
1.36% |
1 |
2.78% |
Cyrill V. Gorcunov |
5 |
1.14% |
1 |
2.78% |
Jaswinder Singh Rajput |
4 |
0.91% |
1 |
2.78% |
Ben Dooks |
4 |
0.91% |
1 |
2.78% |
Wei Wang |
4 |
0.91% |
1 |
2.78% |
Craig Gallek |
3 |
0.68% |
1 |
2.78% |
Konstantin Khlebnikov |
2 |
0.45% |
1 |
2.78% |
David Howells |
1 |
0.23% |
1 |
2.78% |
Greg Kroah-Hartman |
1 |
0.23% |
1 |
2.78% |
Total |
440 |
|
36 |
|
/* 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_ */