Commit 37891cea authored by Andrii Nakryiko's avatar Andrii Nakryiko Committed by Alexei Starovoitov

libbpf: add BPF token support to bpf_map_create() API

Add ability to provide token_fd for BPF_MAP_CREATE command through
bpf_map_create() API.
Signed-off-by: default avatarAndrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/r/20231130185229.2688956-14-andrii@kernel.orgSigned-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
parent ecd43514
...@@ -169,7 +169,7 @@ int bpf_map_create(enum bpf_map_type map_type, ...@@ -169,7 +169,7 @@ int bpf_map_create(enum bpf_map_type map_type,
__u32 max_entries, __u32 max_entries,
const struct bpf_map_create_opts *opts) const struct bpf_map_create_opts *opts)
{ {
const size_t attr_sz = offsetofend(union bpf_attr, map_extra); const size_t attr_sz = offsetofend(union bpf_attr, map_token_fd);
union bpf_attr attr; union bpf_attr attr;
int fd; int fd;
...@@ -198,6 +198,8 @@ int bpf_map_create(enum bpf_map_type map_type, ...@@ -198,6 +198,8 @@ int bpf_map_create(enum bpf_map_type map_type,
attr.numa_node = OPTS_GET(opts, numa_node, 0); attr.numa_node = OPTS_GET(opts, numa_node, 0);
attr.map_ifindex = OPTS_GET(opts, map_ifindex, 0); attr.map_ifindex = OPTS_GET(opts, map_ifindex, 0);
attr.map_token_fd = OPTS_GET(opts, token_fd, 0);
fd = sys_bpf_fd(BPF_MAP_CREATE, &attr, attr_sz); fd = sys_bpf_fd(BPF_MAP_CREATE, &attr, attr_sz);
return libbpf_err_errno(fd); return libbpf_err_errno(fd);
} }
......
...@@ -51,8 +51,11 @@ struct bpf_map_create_opts { ...@@ -51,8 +51,11 @@ struct bpf_map_create_opts {
__u32 numa_node; __u32 numa_node;
__u32 map_ifindex; __u32 map_ifindex;
__u32 token_fd;
size_t :0;
}; };
#define bpf_map_create_opts__last_field map_ifindex #define bpf_map_create_opts__last_field token_fd
LIBBPF_API int bpf_map_create(enum bpf_map_type map_type, LIBBPF_API int bpf_map_create(enum bpf_map_type map_type,
const char *map_name, const char *map_name,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment