77 lines
2.1 KiB
C
77 lines
2.1 KiB
C
|
/* 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 */
|