Contributors: 11
| Author |
Tokens |
Token Proportion |
Commits |
Commit Proportion |
| Jiri Olsa |
85 |
28.91% |
5 |
20.83% |
| Yonghong Song |
73 |
24.83% |
5 |
20.83% |
| Alexei Starovoitov |
43 |
14.63% |
4 |
16.67% |
| Rong Tao |
33 |
11.22% |
1 |
4.17% |
| Andrii Nakryiko |
22 |
7.48% |
3 |
12.50% |
| Brendan Gregg |
18 |
6.12% |
1 |
4.17% |
| Hao Luo |
10 |
3.40% |
1 |
4.17% |
| Menglong Dong |
6 |
2.04% |
1 |
4.17% |
| Jakub Kiciński |
2 |
0.68% |
1 |
4.17% |
| Greg Kroah-Hartman |
1 |
0.34% |
1 |
4.17% |
| Toke Höiland-Jörgensen |
1 |
0.34% |
1 |
4.17% |
| Total |
294 |
|
24 |
|
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __TRACE_HELPER_H
#define __TRACE_HELPER_H
#include <bpf/libbpf.h>
#define __ALIGN_MASK(x, mask) (((x)+(mask))&~(mask))
#define ALIGN(x, a) __ALIGN_MASK(x, (typeof(x))(a)-1)
struct ksym {
long addr;
char *name;
};
struct ksyms;
typedef int (*ksym_cmp_t)(const void *p1, const void *p2);
typedef int (*ksym_search_cmp_t)(const void *p1, const struct ksym *p2);
int load_kallsyms(void);
struct ksym *ksym_search(long key);
long ksym_get_addr(const char *name);
struct ksyms *load_kallsyms_local(void);
struct ksym *ksym_search_local(struct ksyms *ksyms, long key);
long ksym_get_addr_local(struct ksyms *ksyms, const char *name);
void free_kallsyms_local(struct ksyms *ksyms);
struct ksyms *load_kallsyms_custom_local(ksym_cmp_t cmp_cb);
struct ksym *search_kallsyms_custom_local(struct ksyms *ksyms, const void *p1,
ksym_search_cmp_t cmp_cb);
/* open kallsyms and find addresses on the fly, faster than load + search. */
int kallsyms_find(const char *sym, unsigned long long *addr);
void read_trace_pipe(void);
int read_trace_pipe_iter(void (*cb)(const char *str, void *data),
void *data, int iter);
ssize_t get_uprobe_offset(const void *addr);
ssize_t get_rel_offset(uintptr_t addr);
int read_build_id(const char *path, char *build_id, size_t size);
int bpf_get_ksyms(char ***symsp, size_t *cntp, bool kernel);
int bpf_get_addrs(unsigned long **addrsp, size_t *cntp, bool kernel);
#endif