| /* SPDX-License-Identifier: (LGPL-2.1 OR BSD-2-Clause) */ |
| |
| #ifndef __PERF_BPF_UTILS_H |
| #define __PERF_BPF_UTILS_H |
| |
| #define ptr_to_u64(ptr) ((__u64)(unsigned long)(ptr)) |
| |
| #ifdef HAVE_LIBBPF_SUPPORT |
| |
| #include <bpf/libbpf.h> |
| |
| /* |
| * Get bpf_prog_info in continuous memory |
| * |
| * struct bpf_prog_info has multiple arrays. The user has option to choose |
| * arrays to fetch from kernel. The following APIs provide an uniform way to |
| * fetch these data. All arrays in bpf_prog_info are stored in a single |
| * continuous memory region. This makes it easy to store the info in a |
| * file. |
| * |
| * Before writing perf_bpil to files, it is necessary to |
| * translate pointers in bpf_prog_info to offsets. Helper functions |
| * bpil_addr_to_offs() and bpil_offs_to_addr() |
| * are introduced to switch between pointers and offsets. |
| * |
| * Examples: |
| * # To fetch map_ids and prog_tags: |
| * __u64 arrays = (1UL << PERF_BPIL_MAP_IDS) | |
| * (1UL << PERF_BPIL_PROG_TAGS); |
| * struct perf_bpil *info_linear = |
| * get_bpf_prog_info_linear(fd, arrays); |
| * |
| * # To save data in file |
| * bpil_addr_to_offs(info_linear); |
| * write(f, info_linear, sizeof(*info_linear) + info_linear->data_len); |
| * |
| * # To read data from file |
| * read(f, info_linear, <proper_size>); |
| * bpil_offs_to_addr(info_linear); |
| */ |
| enum perf_bpil_array_types { |
| PERF_BPIL_FIRST_ARRAY = 0, |
| PERF_BPIL_JITED_INSNS = 0, |
| PERF_BPIL_XLATED_INSNS, |
| PERF_BPIL_MAP_IDS, |
| PERF_BPIL_JITED_KSYMS, |
| PERF_BPIL_JITED_FUNC_LENS, |
| PERF_BPIL_FUNC_INFO, |
| PERF_BPIL_LINE_INFO, |
| PERF_BPIL_JITED_LINE_INFO, |
| PERF_BPIL_PROG_TAGS, |
| PERF_BPIL_LAST_ARRAY, |
| }; |
| |
| struct perf_bpil { |
| /* size of struct bpf_prog_info, when the tool is compiled */ |
| __u32 info_len; |
| /* total bytes allocated for data, round up to 8 bytes */ |
| __u32 data_len; |
| /* which arrays are included in data */ |
| __u64 arrays; |
| struct bpf_prog_info info; |
| __u8 data[]; |
| }; |
| |
| struct perf_bpil * |
| get_bpf_prog_info_linear(int fd, __u64 arrays); |
| |
| void |
| bpil_addr_to_offs(struct perf_bpil *info_linear); |
| |
| void |
| bpil_offs_to_addr(struct perf_bpil *info_linear); |
| |
| #endif /* HAVE_LIBBPF_SUPPORT */ |
| #endif /* __PERF_BPF_UTILS_H */ |