mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-10 07:44:23 +08:00
fe993c6468
Right now we incorrectly return 'ret' which is always zero at that point. Signed-off-by: Stanislav Fomichev <sdf@google.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
68 lines
1.3 KiB
C
68 lines
1.3 KiB
C
/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */
|
|
#ifndef FLOW_DISSECTOR_LOAD
|
|
#define FLOW_DISSECTOR_LOAD
|
|
|
|
#include <bpf/bpf.h>
|
|
#include <bpf/libbpf.h>
|
|
|
|
static inline int bpf_flow_load(struct bpf_object **obj,
|
|
const char *path,
|
|
const char *section_name,
|
|
const char *map_name,
|
|
const char *keys_map_name,
|
|
int *prog_fd,
|
|
int *keys_fd)
|
|
{
|
|
struct bpf_program *prog, *main_prog;
|
|
struct bpf_map *prog_array, *keys;
|
|
int prog_array_fd;
|
|
int ret, fd, i;
|
|
|
|
ret = bpf_prog_load(path, BPF_PROG_TYPE_FLOW_DISSECTOR, obj,
|
|
prog_fd);
|
|
if (ret)
|
|
return ret;
|
|
|
|
main_prog = bpf_object__find_program_by_title(*obj, section_name);
|
|
if (!main_prog)
|
|
return -1;
|
|
|
|
*prog_fd = bpf_program__fd(main_prog);
|
|
if (*prog_fd < 0)
|
|
return -1;
|
|
|
|
prog_array = bpf_object__find_map_by_name(*obj, map_name);
|
|
if (!prog_array)
|
|
return -1;
|
|
|
|
prog_array_fd = bpf_map__fd(prog_array);
|
|
if (prog_array_fd < 0)
|
|
return -1;
|
|
|
|
if (keys_map_name && keys_fd) {
|
|
keys = bpf_object__find_map_by_name(*obj, keys_map_name);
|
|
if (!keys)
|
|
return -1;
|
|
|
|
*keys_fd = bpf_map__fd(keys);
|
|
if (*keys_fd < 0)
|
|
return -1;
|
|
}
|
|
|
|
i = 0;
|
|
bpf_object__for_each_program(prog, *obj) {
|
|
fd = bpf_program__fd(prog);
|
|
if (fd < 0)
|
|
return fd;
|
|
|
|
if (fd != *prog_fd) {
|
|
bpf_map_update_elem(prog_array_fd, &i, &fd, BPF_ANY);
|
|
++i;
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
#endif /* FLOW_DISSECTOR_LOAD */
|