Linux kernel mirror (for testing)
git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel
os
linux
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __PERF_EVLIST_H
3#define __PERF_EVLIST_H 1
4
5#include <linux/compiler.h>
6#include <linux/kernel.h>
7#include <linux/refcount.h>
8#include <linux/list.h>
9#include <api/fd/array.h>
10#include <internal/evlist.h>
11#include <internal/evsel.h>
12#include "events_stats.h"
13#include "evsel.h"
14#include <pthread.h>
15#include <signal.h>
16#include <unistd.h>
17
18struct pollfd;
19struct thread_map;
20struct perf_cpu_map;
21struct record_opts;
22
23/*
24 * State machine of bkw_mmap_state:
25 *
26 * .________________(forbid)_____________.
27 * | V
28 * NOTREADY --(0)--> RUNNING --(1)--> DATA_PENDING --(2)--> EMPTY
29 * ^ ^ | ^ |
30 * | |__(forbid)____/ |___(forbid)___/|
31 * | |
32 * \_________________(3)_______________/
33 *
34 * NOTREADY : Backward ring buffers are not ready
35 * RUNNING : Backward ring buffers are recording
36 * DATA_PENDING : We are required to collect data from backward ring buffers
37 * EMPTY : We have collected data from backward ring buffers.
38 *
39 * (0): Setup backward ring buffer
40 * (1): Pause ring buffers for reading
41 * (2): Read from ring buffers
42 * (3): Resume ring buffers for recording
43 */
44enum bkw_mmap_state {
45 BKW_MMAP_NOTREADY,
46 BKW_MMAP_RUNNING,
47 BKW_MMAP_DATA_PENDING,
48 BKW_MMAP_EMPTY,
49};
50
51struct evlist {
52 struct perf_evlist core;
53 int nr_groups;
54 bool enabled;
55 int id_pos;
56 int is_pos;
57 u64 combined_sample_type;
58 enum bkw_mmap_state bkw_mmap_state;
59 struct {
60 int cork_fd;
61 pid_t pid;
62 } workload;
63 struct mmap *mmap;
64 struct mmap *overwrite_mmap;
65 struct evsel *selected;
66 struct events_stats stats;
67 struct perf_env *env;
68 void (*trace_event_sample_raw)(struct evlist *evlist,
69 union perf_event *event,
70 struct perf_sample *sample);
71 u64 first_sample_time;
72 u64 last_sample_time;
73 struct {
74 pthread_t th;
75 volatile int done;
76 } thread;
77};
78
79struct evsel_str_handler {
80 const char *name;
81 void *handler;
82};
83
84struct evlist *evlist__new(void);
85struct evlist *perf_evlist__new_default(void);
86struct evlist *perf_evlist__new_dummy(void);
87void evlist__init(struct evlist *evlist, struct perf_cpu_map *cpus,
88 struct perf_thread_map *threads);
89void evlist__exit(struct evlist *evlist);
90void evlist__delete(struct evlist *evlist);
91
92void evlist__add(struct evlist *evlist, struct evsel *entry);
93void evlist__remove(struct evlist *evlist, struct evsel *evsel);
94
95int __perf_evlist__add_default(struct evlist *evlist, bool precise);
96
97static inline int perf_evlist__add_default(struct evlist *evlist)
98{
99 return __perf_evlist__add_default(evlist, true);
100}
101
102int __perf_evlist__add_default_attrs(struct evlist *evlist,
103 struct perf_event_attr *attrs, size_t nr_attrs);
104
105#define perf_evlist__add_default_attrs(evlist, array) \
106 __perf_evlist__add_default_attrs(evlist, array, ARRAY_SIZE(array))
107
108int perf_evlist__add_dummy(struct evlist *evlist);
109
110int perf_evlist__add_sb_event(struct evlist *evlist,
111 struct perf_event_attr *attr,
112 evsel__sb_cb_t cb,
113 void *data);
114void evlist__set_cb(struct evlist *evlist, evsel__sb_cb_t cb, void *data);
115int perf_evlist__start_sb_thread(struct evlist *evlist,
116 struct target *target);
117void perf_evlist__stop_sb_thread(struct evlist *evlist);
118
119int perf_evlist__add_newtp(struct evlist *evlist,
120 const char *sys, const char *name, void *handler);
121
122int __evlist__set_tracepoints_handlers(struct evlist *evlist,
123 const struct evsel_str_handler *assocs,
124 size_t nr_assocs);
125
126#define evlist__set_tracepoints_handlers(evlist, array) \
127 __evlist__set_tracepoints_handlers(evlist, array, ARRAY_SIZE(array))
128
129void __perf_evlist__set_sample_bit(struct evlist *evlist,
130 enum perf_event_sample_format bit);
131void __perf_evlist__reset_sample_bit(struct evlist *evlist,
132 enum perf_event_sample_format bit);
133
134#define perf_evlist__set_sample_bit(evlist, bit) \
135 __perf_evlist__set_sample_bit(evlist, PERF_SAMPLE_##bit)
136
137#define perf_evlist__reset_sample_bit(evlist, bit) \
138 __perf_evlist__reset_sample_bit(evlist, PERF_SAMPLE_##bit)
139
140int perf_evlist__set_tp_filter(struct evlist *evlist, const char *filter);
141int perf_evlist__set_tp_filter_pid(struct evlist *evlist, pid_t pid);
142int perf_evlist__set_tp_filter_pids(struct evlist *evlist, size_t npids, pid_t *pids);
143
144int perf_evlist__append_tp_filter(struct evlist *evlist, const char *filter);
145
146int perf_evlist__append_tp_filter_pid(struct evlist *evlist, pid_t pid);
147int perf_evlist__append_tp_filter_pids(struct evlist *evlist, size_t npids, pid_t *pids);
148
149struct evsel *
150perf_evlist__find_tracepoint_by_id(struct evlist *evlist, int id);
151
152struct evsel *
153perf_evlist__find_tracepoint_by_name(struct evlist *evlist,
154 const char *name);
155
156int evlist__add_pollfd(struct evlist *evlist, int fd);
157int evlist__filter_pollfd(struct evlist *evlist, short revents_and_mask);
158
159int evlist__poll(struct evlist *evlist, int timeout);
160
161struct evsel *perf_evlist__id2evsel(struct evlist *evlist, u64 id);
162struct evsel *perf_evlist__id2evsel_strict(struct evlist *evlist,
163 u64 id);
164
165struct perf_sample_id *perf_evlist__id2sid(struct evlist *evlist, u64 id);
166
167void perf_evlist__toggle_bkw_mmap(struct evlist *evlist, enum bkw_mmap_state state);
168
169void evlist__mmap_consume(struct evlist *evlist, int idx);
170
171int evlist__open(struct evlist *evlist);
172void evlist__close(struct evlist *evlist);
173
174struct callchain_param;
175
176void perf_evlist__set_id_pos(struct evlist *evlist);
177void perf_evlist__config(struct evlist *evlist, struct record_opts *opts,
178 struct callchain_param *callchain);
179int record_opts__config(struct record_opts *opts);
180
181int perf_evlist__prepare_workload(struct evlist *evlist,
182 struct target *target,
183 const char *argv[], bool pipe_output,
184 void (*exec_error)(int signo, siginfo_t *info,
185 void *ucontext));
186int perf_evlist__start_workload(struct evlist *evlist);
187
188struct option;
189
190int __perf_evlist__parse_mmap_pages(unsigned int *mmap_pages, const char *str);
191int perf_evlist__parse_mmap_pages(const struct option *opt,
192 const char *str,
193 int unset);
194
195unsigned long perf_event_mlock_kb_in_pages(void);
196
197int evlist__mmap_ex(struct evlist *evlist, unsigned int pages,
198 unsigned int auxtrace_pages,
199 bool auxtrace_overwrite, int nr_cblocks,
200 int affinity, int flush, int comp_level);
201int evlist__mmap(struct evlist *evlist, unsigned int pages);
202void evlist__munmap(struct evlist *evlist);
203
204size_t evlist__mmap_size(unsigned long pages);
205
206void evlist__disable(struct evlist *evlist);
207void evlist__enable(struct evlist *evlist);
208void perf_evlist__toggle_enable(struct evlist *evlist);
209
210int perf_evlist__enable_event_idx(struct evlist *evlist,
211 struct evsel *evsel, int idx);
212
213void perf_evlist__set_selected(struct evlist *evlist,
214 struct evsel *evsel);
215
216int perf_evlist__create_maps(struct evlist *evlist, struct target *target);
217int perf_evlist__apply_filters(struct evlist *evlist, struct evsel **err_evsel);
218
219void __perf_evlist__set_leader(struct list_head *list);
220void perf_evlist__set_leader(struct evlist *evlist);
221
222u64 __perf_evlist__combined_sample_type(struct evlist *evlist);
223u64 perf_evlist__combined_sample_type(struct evlist *evlist);
224u64 perf_evlist__combined_branch_type(struct evlist *evlist);
225bool perf_evlist__sample_id_all(struct evlist *evlist);
226u16 perf_evlist__id_hdr_size(struct evlist *evlist);
227
228int perf_evlist__parse_sample(struct evlist *evlist, union perf_event *event,
229 struct perf_sample *sample);
230
231int perf_evlist__parse_sample_timestamp(struct evlist *evlist,
232 union perf_event *event,
233 u64 *timestamp);
234
235bool perf_evlist__valid_sample_type(struct evlist *evlist);
236bool perf_evlist__valid_sample_id_all(struct evlist *evlist);
237bool perf_evlist__valid_read_format(struct evlist *evlist);
238
239void perf_evlist__splice_list_tail(struct evlist *evlist,
240 struct list_head *list);
241
242static inline bool perf_evlist__empty(struct evlist *evlist)
243{
244 return list_empty(&evlist->core.entries);
245}
246
247static inline struct evsel *evlist__first(struct evlist *evlist)
248{
249 struct perf_evsel *evsel = perf_evlist__first(&evlist->core);
250
251 return container_of(evsel, struct evsel, core);
252}
253
254static inline struct evsel *evlist__last(struct evlist *evlist)
255{
256 struct perf_evsel *evsel = perf_evlist__last(&evlist->core);
257
258 return container_of(evsel, struct evsel, core);
259}
260
261int perf_evlist__strerror_open(struct evlist *evlist, int err, char *buf, size_t size);
262int perf_evlist__strerror_mmap(struct evlist *evlist, int err, char *buf, size_t size);
263
264bool perf_evlist__can_select_event(struct evlist *evlist, const char *str);
265void perf_evlist__to_front(struct evlist *evlist,
266 struct evsel *move_evsel);
267
268/**
269 * __evlist__for_each_entry - iterate thru all the evsels
270 * @list: list_head instance to iterate
271 * @evsel: struct evsel iterator
272 */
273#define __evlist__for_each_entry(list, evsel) \
274 list_for_each_entry(evsel, list, core.node)
275
276/**
277 * evlist__for_each_entry - iterate thru all the evsels
278 * @evlist: evlist instance to iterate
279 * @evsel: struct evsel iterator
280 */
281#define evlist__for_each_entry(evlist, evsel) \
282 __evlist__for_each_entry(&(evlist)->core.entries, evsel)
283
284/**
285 * __evlist__for_each_entry_continue - continue iteration thru all the evsels
286 * @list: list_head instance to iterate
287 * @evsel: struct evsel iterator
288 */
289#define __evlist__for_each_entry_continue(list, evsel) \
290 list_for_each_entry_continue(evsel, list, core.node)
291
292/**
293 * evlist__for_each_entry_continue - continue iteration thru all the evsels
294 * @evlist: evlist instance to iterate
295 * @evsel: struct evsel iterator
296 */
297#define evlist__for_each_entry_continue(evlist, evsel) \
298 __evlist__for_each_entry_continue(&(evlist)->core.entries, evsel)
299
300/**
301 * __evlist__for_each_entry_reverse - iterate thru all the evsels in reverse order
302 * @list: list_head instance to iterate
303 * @evsel: struct evsel iterator
304 */
305#define __evlist__for_each_entry_reverse(list, evsel) \
306 list_for_each_entry_reverse(evsel, list, core.node)
307
308/**
309 * evlist__for_each_entry_reverse - iterate thru all the evsels in reverse order
310 * @evlist: evlist instance to iterate
311 * @evsel: struct evsel iterator
312 */
313#define evlist__for_each_entry_reverse(evlist, evsel) \
314 __evlist__for_each_entry_reverse(&(evlist)->core.entries, evsel)
315
316/**
317 * __evlist__for_each_entry_safe - safely iterate thru all the evsels
318 * @list: list_head instance to iterate
319 * @tmp: struct evsel temp iterator
320 * @evsel: struct evsel iterator
321 */
322#define __evlist__for_each_entry_safe(list, tmp, evsel) \
323 list_for_each_entry_safe(evsel, tmp, list, core.node)
324
325/**
326 * evlist__for_each_entry_safe - safely iterate thru all the evsels
327 * @evlist: evlist instance to iterate
328 * @evsel: struct evsel iterator
329 * @tmp: struct evsel temp iterator
330 */
331#define evlist__for_each_entry_safe(evlist, tmp, evsel) \
332 __evlist__for_each_entry_safe(&(evlist)->core.entries, tmp, evsel)
333
334#define evlist__for_each_cpu(evlist, index, cpu) \
335 evlist__cpu_iter_start(evlist); \
336 perf_cpu_map__for_each_cpu (cpu, index, (evlist)->core.all_cpus)
337
338struct evsel *perf_evlist__get_tracking_event(struct evlist *evlist);
339void perf_evlist__set_tracking_event(struct evlist *evlist,
340 struct evsel *tracking_evsel);
341
342void evlist__cpu_iter_start(struct evlist *evlist);
343bool evsel__cpu_iter_skip(struct evsel *ev, int cpu);
344bool evsel__cpu_iter_skip_no_inc(struct evsel *ev, int cpu);
345
346struct evsel *
347perf_evlist__find_evsel_by_str(struct evlist *evlist, const char *str);
348
349struct evsel *perf_evlist__event2evsel(struct evlist *evlist,
350 union perf_event *event);
351
352bool perf_evlist__exclude_kernel(struct evlist *evlist);
353
354void perf_evlist__force_leader(struct evlist *evlist);
355
356struct evsel *perf_evlist__reset_weak_group(struct evlist *evlist,
357 struct evsel *evsel,
358 bool close);
359#endif /* __PERF_EVLIST_H */