mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-02 18:54:10 +08:00
1ed4d92458
This patch adds INET_DIAG support to bpf_sk_storage. 1. Although this series adds bpf_sk_storage diag capability to inet sk, bpf_sk_storage is in general applicable to all fullsock. Hence, the bpf_sk_storage logic will operate on SK_DIAG_* nlattr. The caller will pass in its specific nesting nlattr (e.g. INET_DIAG_*) as the argument. 2. The request will be like: INET_DIAG_REQ_SK_BPF_STORAGES (nla_nest) (defined in latter patch) SK_DIAG_BPF_STORAGE_REQ_MAP_FD (nla_put_u32) SK_DIAG_BPF_STORAGE_REQ_MAP_FD (nla_put_u32) ...... Considering there could have multiple bpf_sk_storages in a sk, instead of reusing INET_DIAG_INFO ("ss -i"), the user can select some specific bpf_sk_storage to dump by specifying an array of SK_DIAG_BPF_STORAGE_REQ_MAP_FD. If no SK_DIAG_BPF_STORAGE_REQ_MAP_FD is specified (i.e. an empty INET_DIAG_REQ_SK_BPF_STORAGES), it will dump all bpf_sk_storages of a sk. 3. The reply will be like: INET_DIAG_BPF_SK_STORAGES (nla_nest) (defined in latter patch) SK_DIAG_BPF_STORAGE (nla_nest) SK_DIAG_BPF_STORAGE_MAP_ID (nla_put_u32) SK_DIAG_BPF_STORAGE_MAP_VALUE (nla_reserve_64bit) SK_DIAG_BPF_STORAGE (nla_nest) SK_DIAG_BPF_STORAGE_MAP_ID (nla_put_u32) SK_DIAG_BPF_STORAGE_MAP_VALUE (nla_reserve_64bit) ...... 4. Unlike other INET_DIAG info of a sk which is pretty static, the size required to dump the bpf_sk_storage(s) of a sk is dynamic as the system adding more bpf_sk_storage_map. It is hard to set a static min_dump_alloc size. Hence, this series learns it at the runtime and adjust the cb->min_dump_alloc as it iterates all sk(s) of a system. The "unsigned int *res_diag_size" in bpf_sk_storage_diag_put() is for this purpose. The next patch will update the cb->min_dump_alloc as it iterates the sk(s). Signed-off-by: Martin KaFai Lau <kafai@fb.com> Signed-off-by: Alexei Starovoitov <ast@kernel.org> Acked-by: Song Liu <songliubraving@fb.com> Link: https://lore.kernel.org/bpf/20200225230421.1975729-1-kafai@fb.com
66 lines
1.3 KiB
C
66 lines
1.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
|
#ifndef _UAPI__SOCK_DIAG_H__
|
|
#define _UAPI__SOCK_DIAG_H__
|
|
|
|
#include <linux/types.h>
|
|
|
|
#define SOCK_DIAG_BY_FAMILY 20
|
|
#define SOCK_DESTROY 21
|
|
|
|
struct sock_diag_req {
|
|
__u8 sdiag_family;
|
|
__u8 sdiag_protocol;
|
|
};
|
|
|
|
enum {
|
|
SK_MEMINFO_RMEM_ALLOC,
|
|
SK_MEMINFO_RCVBUF,
|
|
SK_MEMINFO_WMEM_ALLOC,
|
|
SK_MEMINFO_SNDBUF,
|
|
SK_MEMINFO_FWD_ALLOC,
|
|
SK_MEMINFO_WMEM_QUEUED,
|
|
SK_MEMINFO_OPTMEM,
|
|
SK_MEMINFO_BACKLOG,
|
|
SK_MEMINFO_DROPS,
|
|
|
|
SK_MEMINFO_VARS,
|
|
};
|
|
|
|
enum sknetlink_groups {
|
|
SKNLGRP_NONE,
|
|
SKNLGRP_INET_TCP_DESTROY,
|
|
SKNLGRP_INET_UDP_DESTROY,
|
|
SKNLGRP_INET6_TCP_DESTROY,
|
|
SKNLGRP_INET6_UDP_DESTROY,
|
|
__SKNLGRP_MAX,
|
|
};
|
|
#define SKNLGRP_MAX (__SKNLGRP_MAX - 1)
|
|
|
|
enum {
|
|
SK_DIAG_BPF_STORAGE_REQ_NONE,
|
|
SK_DIAG_BPF_STORAGE_REQ_MAP_FD,
|
|
__SK_DIAG_BPF_STORAGE_REQ_MAX,
|
|
};
|
|
|
|
#define SK_DIAG_BPF_STORAGE_REQ_MAX (__SK_DIAG_BPF_STORAGE_REQ_MAX - 1)
|
|
|
|
enum {
|
|
SK_DIAG_BPF_STORAGE_REP_NONE,
|
|
SK_DIAG_BPF_STORAGE,
|
|
__SK_DIAG_BPF_STORAGE_REP_MAX,
|
|
};
|
|
|
|
#define SK_DIAB_BPF_STORAGE_REP_MAX (__SK_DIAG_BPF_STORAGE_REP_MAX - 1)
|
|
|
|
enum {
|
|
SK_DIAG_BPF_STORAGE_NONE,
|
|
SK_DIAG_BPF_STORAGE_PAD,
|
|
SK_DIAG_BPF_STORAGE_MAP_ID,
|
|
SK_DIAG_BPF_STORAGE_MAP_VALUE,
|
|
__SK_DIAG_BPF_STORAGE_MAX,
|
|
};
|
|
|
|
#define SK_DIAG_BPF_STORAGE_MAX (__SK_DIAG_BPF_STORAGE_MAX - 1)
|
|
|
|
#endif /* _UAPI__SOCK_DIAG_H__ */
|