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.14.15
 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 = NULL;
27	bpf_object__for_each_program(prog, *obj) {
28		if (strcmp(section_name, bpf_program__section_name(prog)) == 0) {
29			main_prog = prog;
30			break;
31		}
32	}
33	if (!main_prog)
34		return -1;
35
36	*prog_fd = bpf_program__fd(main_prog);
37	if (*prog_fd < 0)
38		return -1;
39
40	prog_array = bpf_object__find_map_by_name(*obj, map_name);
41	if (!prog_array)
42		return -1;
43
44	prog_array_fd = bpf_map__fd(prog_array);
45	if (prog_array_fd < 0)
46		return -1;
47
48	if (keys_map_name && keys_fd) {
49		keys = bpf_object__find_map_by_name(*obj, keys_map_name);
50		if (!keys)
51			return -1;
52
53		*keys_fd = bpf_map__fd(keys);
54		if (*keys_fd < 0)
55			return -1;
56	}
57
58	i = 0;
59	bpf_object__for_each_program(prog, *obj) {
60		fd = bpf_program__fd(prog);
61		if (fd < 0)
62			return fd;
63
64		if (fd != *prog_fd) {
65			bpf_map_update_elem(prog_array_fd, &i, &fd, BPF_ANY);
66			++i;
67		}
68	}
69
70	return 0;
71}
72
73#endif /* FLOW_DISSECTOR_LOAD */