Linux Audio

Check our new training course

Loading...
v6.13.7
 1/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */
 2#ifndef FLOW_DISSECTOR_LOAD
 3#define FLOW_DISSECTOR_LOAD
 4
 5#include <bpf/bpf.h>
 6#include <bpf/libbpf.h>
 7#include "testing_helpers.h"
 8
 9static inline int bpf_flow_load(struct bpf_object **obj,
10				const char *path,
11				const char *prog_name,
12				const char *map_name,
13				const char *keys_map_name,
14				int *prog_fd,
15				int *keys_fd)
16{
17	struct bpf_program *prog, *main_prog;
18	struct bpf_map *prog_array, *keys;
19	int prog_array_fd;
20	int ret, fd, i;
21
22	ret = bpf_prog_test_load(path, BPF_PROG_TYPE_FLOW_DISSECTOR, obj,
23			    prog_fd);
24	if (ret)
25		return ret;
26
27	main_prog = bpf_object__find_program_by_name(*obj, prog_name);
28	if (!main_prog)
29		return -1;
30
31	*prog_fd = bpf_program__fd(main_prog);
32	if (*prog_fd < 0)
33		return -1;
34
35	prog_array = bpf_object__find_map_by_name(*obj, map_name);
36	if (!prog_array)
37		return -1;
38
39	prog_array_fd = bpf_map__fd(prog_array);
40	if (prog_array_fd < 0)
41		return -1;
42
43	if (keys_map_name && keys_fd) {
44		keys = bpf_object__find_map_by_name(*obj, keys_map_name);
45		if (!keys)
46			return -1;
47
48		*keys_fd = bpf_map__fd(keys);
49		if (*keys_fd < 0)
50			return -1;
51	}
52
53	i = 0;
54	bpf_object__for_each_program(prog, *obj) {
55		fd = bpf_program__fd(prog);
56		if (fd < 0)
57			return fd;
58
59		if (fd != *prog_fd) {
60			bpf_map_update_elem(prog_array_fd, &i, &fd, BPF_ANY);
61			++i;
62		}
63	}
64
65	return 0;
66}
67
68#endif /* FLOW_DISSECTOR_LOAD */
v5.9
 1/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */
 2#ifndef FLOW_DISSECTOR_LOAD
 3#define FLOW_DISSECTOR_LOAD
 4
 5#include <bpf/bpf.h>
 6#include <bpf/libbpf.h>
 
 7
 8static inline int bpf_flow_load(struct bpf_object **obj,
 9				const char *path,
10				const char *section_name,
11				const char *map_name,
12				const char *keys_map_name,
13				int *prog_fd,
14				int *keys_fd)
15{
16	struct bpf_program *prog, *main_prog;
17	struct bpf_map *prog_array, *keys;
18	int prog_array_fd;
19	int ret, fd, i;
20
21	ret = bpf_prog_load(path, BPF_PROG_TYPE_FLOW_DISSECTOR, obj,
22			    prog_fd);
23	if (ret)
24		return ret;
25
26	main_prog = bpf_object__find_program_by_title(*obj, section_name);
27	if (!main_prog)
28		return -1;
29
30	*prog_fd = bpf_program__fd(main_prog);
31	if (*prog_fd < 0)
32		return -1;
33
34	prog_array = bpf_object__find_map_by_name(*obj, map_name);
35	if (!prog_array)
36		return -1;
37
38	prog_array_fd = bpf_map__fd(prog_array);
39	if (prog_array_fd < 0)
40		return -1;
41
42	if (keys_map_name && keys_fd) {
43		keys = bpf_object__find_map_by_name(*obj, keys_map_name);
44		if (!keys)
45			return -1;
46
47		*keys_fd = bpf_map__fd(keys);
48		if (*keys_fd < 0)
49			return -1;
50	}
51
52	i = 0;
53	bpf_object__for_each_program(prog, *obj) {
54		fd = bpf_program__fd(prog);
55		if (fd < 0)
56			return fd;
57
58		if (fd != *prog_fd) {
59			bpf_map_update_elem(prog_array_fd, &i, &fd, BPF_ANY);
60			++i;
61		}
62	}
63
64	return 0;
65}
66
67#endif /* FLOW_DISSECTOR_LOAD */