1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
/* SPDX-License-Identifier: GPL-2.0 */ #ifndef __PERF_BPF_COUNTER_H #define __PERF_BPF_COUNTER_H 1 #include <linux/list.h> struct evsel; struct target; struct bpf_counter; typedef int (*bpf_counter_evsel_op)(struct evsel *evsel); typedef int (*bpf_counter_evsel_target_op)(struct evsel *evsel, struct target *target); typedef int (*bpf_counter_evsel_install_pe_op)(struct evsel *evsel, int cpu, int fd); struct bpf_counter_ops { bpf_counter_evsel_target_op load; bpf_counter_evsel_op enable; bpf_counter_evsel_op disable; bpf_counter_evsel_op read; bpf_counter_evsel_op destroy; bpf_counter_evsel_install_pe_op install_pe; }; struct bpf_counter { void *skel; struct list_head list; }; #ifdef HAVE_BPF_SKEL int bpf_counter__load(struct evsel *evsel, struct target *target); int bpf_counter__enable(struct evsel *evsel); int bpf_counter__disable(struct evsel *evsel); int bpf_counter__read(struct evsel *evsel); void bpf_counter__destroy(struct evsel *evsel); int bpf_counter__install_pe(struct evsel *evsel, int cpu, int fd); #else /* HAVE_BPF_SKEL */ #include <linux/err.h> static inline int bpf_counter__load(struct evsel *evsel __maybe_unused, struct target *target __maybe_unused) { return 0; } static inline int bpf_counter__enable(struct evsel *evsel __maybe_unused) { return 0; } static inline int bpf_counter__disable(struct evsel *evsel __maybe_unused) { return 0; } static inline int bpf_counter__read(struct evsel *evsel __maybe_unused) { return -EAGAIN; } static inline void bpf_counter__destroy(struct evsel *evsel __maybe_unused) { } static inline int bpf_counter__install_pe(struct evsel *evsel __maybe_unused, int cpu __maybe_unused, int fd __maybe_unused) { return 0; } #endif /* HAVE_BPF_SKEL */ #endif /* __PERF_BPF_COUNTER_H */