perf top: Split -G and --call-graph
[deliverable/linux.git] / tools / perf / util / evlist.h
CommitLineData
361c99a6
ACM
1#ifndef __PERF_EVLIST_H
2#define __PERF_EVLIST_H 1
3
4#include <linux/list.h>
50d08e47 5#include <stdio.h>
70db7533 6#include "../perf.h"
04391deb 7#include "event.h"
0c21f736 8#include "evsel.h"
50d08e47 9#include "util.h"
35b9d88e 10#include <unistd.h>
361c99a6 11
5c581041 12struct pollfd;
f8a95309
ACM
13struct thread_map;
14struct cpu_map;
0f82ebc4 15struct perf_record_opts;
5c581041 16
70db7533
ACM
17#define PERF_EVLIST__HLIST_BITS 8
18#define PERF_EVLIST__HLIST_SIZE (1 << PERF_EVLIST__HLIST_BITS)
19
0479b8b9
DA
20struct perf_mmap {
21 void *base;
22 int mask;
23 unsigned int prev;
24 union perf_event event_copy;
25};
26
361c99a6
ACM
27struct perf_evlist {
28 struct list_head entries;
70db7533 29 struct hlist_head heads[PERF_EVLIST__HLIST_SIZE];
361c99a6 30 int nr_entries;
97f63e4a 31 int nr_groups;
5c581041 32 int nr_fds;
aece948f 33 int nr_mmaps;
70db7533 34 int mmap_len;
75562573
AH
35 int id_pos;
36 int is_pos;
37 u64 combined_sample_type;
35b9d88e
ACM
38 struct {
39 int cork_fd;
40 pid_t pid;
41 } workload;
7bb41152 42 bool overwrite;
70db7533 43 struct perf_mmap *mmap;
5c581041 44 struct pollfd *pollfd;
7e2ed097
ACM
45 struct thread_map *threads;
46 struct cpu_map *cpus;
81cce8de 47 struct perf_evsel *selected;
361c99a6
ACM
48};
49
ee29be62
ACM
50struct perf_evsel_str_handler {
51 const char *name;
52 void *handler;
53};
54
334fe7a3 55struct perf_evlist *perf_evlist__new(void);
7e2ed097
ACM
56void perf_evlist__init(struct perf_evlist *evlist, struct cpu_map *cpus,
57 struct thread_map *threads);
ef1d1af2 58void perf_evlist__exit(struct perf_evlist *evlist);
361c99a6
ACM
59void perf_evlist__delete(struct perf_evlist *evlist);
60
61void perf_evlist__add(struct perf_evlist *evlist, struct perf_evsel *entry);
62int perf_evlist__add_default(struct perf_evlist *evlist);
79695e1b
ACM
63int __perf_evlist__add_default_attrs(struct perf_evlist *evlist,
64 struct perf_event_attr *attrs, size_t nr_attrs);
e60fc847 65
79695e1b
ACM
66#define perf_evlist__add_default_attrs(evlist, array) \
67 __perf_evlist__add_default_attrs(evlist, array, ARRAY_SIZE(array))
361c99a6 68
39876e7d
ACM
69int perf_evlist__add_newtp(struct perf_evlist *evlist,
70 const char *sys, const char *name, void *handler);
71
745cefc5
ACM
72int perf_evlist__set_filter(struct perf_evlist *evlist, const char *filter);
73
da378962
ACM
74struct perf_evsel *
75perf_evlist__find_tracepoint_by_id(struct perf_evlist *evlist, int id);
76
a2f2804a
DA
77struct perf_evsel *
78perf_evlist__find_tracepoint_by_name(struct perf_evlist *evlist,
79 const char *name);
80
a91e5431
ACM
81void perf_evlist__id_add(struct perf_evlist *evlist, struct perf_evsel *evsel,
82 int cpu, int thread, u64 id);
3d3b5e95 83
70082dd9 84void perf_evlist__add_pollfd(struct perf_evlist *evlist, int fd);
5c581041 85
70db7533
ACM
86struct perf_evsel *perf_evlist__id2evsel(struct perf_evlist *evlist, u64 id);
87
932a3594
JO
88struct perf_sample_id *perf_evlist__id2sid(struct perf_evlist *evlist, u64 id);
89
aece948f 90union perf_event *perf_evlist__mmap_read(struct perf_evlist *self, int idx);
04391deb 91
6a4bb04c 92int perf_evlist__open(struct perf_evlist *evlist);
a74b4b66 93void perf_evlist__close(struct perf_evlist *evlist);
727ab04e 94
75562573
AH
95void perf_evlist__set_id_pos(struct perf_evlist *evlist);
96bool perf_can_sample_identifier(void);
f77a9518
ACM
97void perf_evlist__config(struct perf_evlist *evlist,
98 struct perf_record_opts *opts);
0f82ebc4 99
35b9d88e 100int perf_evlist__prepare_workload(struct perf_evlist *evlist,
6ef73ec4 101 struct perf_target *target,
55e162ea
NK
102 const char *argv[], bool pipe_output,
103 bool want_signal);
35b9d88e
ACM
104int perf_evlist__start_workload(struct perf_evlist *evlist);
105
50a682ce
ACM
106int perf_evlist__mmap(struct perf_evlist *evlist, unsigned int pages,
107 bool overwrite);
7e2ed097
ACM
108void perf_evlist__munmap(struct perf_evlist *evlist);
109
4152ab37 110void perf_evlist__disable(struct perf_evlist *evlist);
764e16a3 111void perf_evlist__enable(struct perf_evlist *evlist);
4152ab37 112
395c3070
AH
113int perf_evlist__disable_event(struct perf_evlist *evlist,
114 struct perf_evsel *evsel);
115int perf_evlist__enable_event(struct perf_evlist *evlist,
116 struct perf_evsel *evsel);
117
81cce8de
ACM
118void perf_evlist__set_selected(struct perf_evlist *evlist,
119 struct perf_evsel *evsel);
120
7e2ed097
ACM
121static inline void perf_evlist__set_maps(struct perf_evlist *evlist,
122 struct cpu_map *cpus,
123 struct thread_map *threads)
124{
125 evlist->cpus = cpus;
126 evlist->threads = threads;
127}
128
b809ac10
NK
129int perf_evlist__create_maps(struct perf_evlist *evlist,
130 struct perf_target *target);
7e2ed097 131void perf_evlist__delete_maps(struct perf_evlist *evlist);
1491a632 132int perf_evlist__apply_filters(struct perf_evlist *evlist);
f8a95309 133
63dab225
ACM
134void __perf_evlist__set_leader(struct list_head *list);
135void perf_evlist__set_leader(struct perf_evlist *evlist);
136
9ede473c 137u64 perf_evlist__read_format(struct perf_evlist *evlist);
75562573
AH
138u64 __perf_evlist__combined_sample_type(struct perf_evlist *evlist);
139u64 perf_evlist__combined_sample_type(struct perf_evlist *evlist);
0c21f736
ACM
140bool perf_evlist__sample_id_all(struct perf_evlist *evlist);
141u16 perf_evlist__id_hdr_size(struct perf_evlist *evlist);
74429964 142
a3f698fe 143int perf_evlist__parse_sample(struct perf_evlist *evlist, union perf_event *event,
0807d2d8 144 struct perf_sample *sample);
cb0b29e0 145
0c21f736
ACM
146bool perf_evlist__valid_sample_type(struct perf_evlist *evlist);
147bool perf_evlist__valid_sample_id_all(struct perf_evlist *evlist);
9ede473c 148bool perf_evlist__valid_read_format(struct perf_evlist *evlist);
0529bc1f
JO
149
150void perf_evlist__splice_list_tail(struct perf_evlist *evlist,
151 struct list_head *list,
152 int nr_entries);
0c21f736
ACM
153
154static inline struct perf_evsel *perf_evlist__first(struct perf_evlist *evlist)
155{
156 return list_entry(evlist->entries.next, struct perf_evsel, node);
157}
158
159static inline struct perf_evsel *perf_evlist__last(struct perf_evlist *evlist)
160{
161 return list_entry(evlist->entries.prev, struct perf_evsel, node);
162}
78f067b3
ACM
163
164size_t perf_evlist__fprintf(struct perf_evlist *evlist, FILE *fp);
0479b8b9
DA
165
166static inline unsigned int perf_mmap__read_head(struct perf_mmap *mm)
167{
168 struct perf_event_mmap_page *pc = mm->base;
169 int head = pc->data_head;
170 rmb();
171 return head;
172}
173
174static inline void perf_mmap__write_tail(struct perf_mmap *md,
175 unsigned long tail)
176{
177 struct perf_event_mmap_page *pc = md->base;
178
179 /*
180 * ensure all reads are done before we write the tail out.
181 */
182 /* mb(); */
183 pc->data_tail = tail;
184}
185
361c99a6 186#endif /* __PERF_EVLIST_H */
This page took 0.098734 seconds and 5 git commands to generate.