blob: 86a5055cdfad6689f4db9b1b818c0eae31b77fdf [file] [log] [blame]
Dave Marchevsky6ac22d02021-10-11 01:20:30 -07001/* SPDX-License-Identifier: (LGPL-2.1 OR BSD-2-Clause) */
2
3#ifndef __PERF_BPF_UTILS_H
4#define __PERF_BPF_UTILS_H
5
6#define ptr_to_u64(ptr) ((__u64)(unsigned long)(ptr))
7
8#ifdef HAVE_LIBBPF_SUPPORT
9
10#include <bpf/libbpf.h>
11
12/*
13 * Get bpf_prog_info in continuous memory
14 *
15 * struct bpf_prog_info has multiple arrays. The user has option to choose
16 * arrays to fetch from kernel. The following APIs provide an uniform way to
17 * fetch these data. All arrays in bpf_prog_info are stored in a single
18 * continuous memory region. This makes it easy to store the info in a
19 * file.
20 *
21 * Before writing perf_bpil to files, it is necessary to
22 * translate pointers in bpf_prog_info to offsets. Helper functions
23 * bpil_addr_to_offs() and bpil_offs_to_addr()
24 * are introduced to switch between pointers and offsets.
25 *
26 * Examples:
27 * # To fetch map_ids and prog_tags:
28 * __u64 arrays = (1UL << PERF_BPIL_MAP_IDS) |
29 * (1UL << PERF_BPIL_PROG_TAGS);
30 * struct perf_bpil *info_linear =
31 * get_bpf_prog_info_linear(fd, arrays);
32 *
33 * # To save data in file
34 * bpil_addr_to_offs(info_linear);
35 * write(f, info_linear, sizeof(*info_linear) + info_linear->data_len);
36 *
37 * # To read data from file
38 * read(f, info_linear, <proper_size>);
39 * bpil_offs_to_addr(info_linear);
40 */
41enum perf_bpil_array_types {
42 PERF_BPIL_FIRST_ARRAY = 0,
43 PERF_BPIL_JITED_INSNS = 0,
44 PERF_BPIL_XLATED_INSNS,
45 PERF_BPIL_MAP_IDS,
46 PERF_BPIL_JITED_KSYMS,
47 PERF_BPIL_JITED_FUNC_LENS,
48 PERF_BPIL_FUNC_INFO,
49 PERF_BPIL_LINE_INFO,
50 PERF_BPIL_JITED_LINE_INFO,
51 PERF_BPIL_PROG_TAGS,
52 PERF_BPIL_LAST_ARRAY,
53};
54
55struct perf_bpil {
56 /* size of struct bpf_prog_info, when the tool is compiled */
57 __u32 info_len;
58 /* total bytes allocated for data, round up to 8 bytes */
59 __u32 data_len;
60 /* which arrays are included in data */
61 __u64 arrays;
62 struct bpf_prog_info info;
63 __u8 data[];
64};
65
66struct perf_bpil *
67get_bpf_prog_info_linear(int fd, __u64 arrays);
68
69void
70bpil_addr_to_offs(struct perf_bpil *info_linear);
71
72void
73bpil_offs_to_addr(struct perf_bpil *info_linear);
74
75#endif /* HAVE_LIBBPF_SUPPORT */
76#endif /* __PERF_BPF_UTILS_H */