Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __LIBPERF_INTERNAL_EVLIST_H
3#define __LIBPERF_INTERNAL_EVLIST_H
4
5#include <linux/list.h>
6#include <api/fd/array.h>
7#include <internal/cpumap.h>
8#include <internal/evsel.h>
9
10#define PERF_EVLIST__HLIST_BITS 8
11#define PERF_EVLIST__HLIST_SIZE (1 << PERF_EVLIST__HLIST_BITS)
12
13struct perf_cpu_map;
14struct perf_thread_map;
15struct perf_mmap_param;
16
17struct perf_evlist {
18 struct list_head entries;
19 int nr_entries;
20 bool has_user_cpus;
21 bool needs_map_propagation;
22 /**
23 * The cpus passed from the command line or all online CPUs by
24 * default.
25 */
26 struct perf_cpu_map *user_requested_cpus;
27 /** The union of all evsel cpu maps. */
28 struct perf_cpu_map *all_cpus;
29 struct perf_thread_map *threads;
30 int nr_mmaps;
31 size_t mmap_len;
32 struct fdarray pollfd;
33 struct hlist_head heads[PERF_EVLIST__HLIST_SIZE];
34 struct perf_mmap *mmap;
35 struct perf_mmap *mmap_ovw;
36 struct perf_mmap *mmap_first;
37 struct perf_mmap *mmap_ovw_first;
38};
39
40typedef void
41(*perf_evlist_mmap__cb_idx_t)(struct perf_evlist*, struct perf_evsel*,
42 struct perf_mmap_param*, int);
43typedef struct perf_mmap*
44(*perf_evlist_mmap__cb_get_t)(struct perf_evlist*, bool, int);
45typedef int
46(*perf_evlist_mmap__cb_mmap_t)(struct perf_mmap*, struct perf_mmap_param*, int, struct perf_cpu);
47
48struct perf_evlist_mmap_ops {
49 perf_evlist_mmap__cb_idx_t idx;
50 perf_evlist_mmap__cb_get_t get;
51 perf_evlist_mmap__cb_mmap_t mmap;
52};
53
54int perf_evlist__alloc_pollfd(struct perf_evlist *evlist);
55int perf_evlist__add_pollfd(struct perf_evlist *evlist, int fd,
56 void *ptr, short revent, enum fdarray_flags flags);
57
58int perf_evlist__mmap_ops(struct perf_evlist *evlist,
59 struct perf_evlist_mmap_ops *ops,
60 struct perf_mmap_param *mp);
61
62void perf_evlist__init(struct perf_evlist *evlist);
63void perf_evlist__exit(struct perf_evlist *evlist);
64
65/**
66 * __perf_evlist__for_each_entry - iterate thru all the evsels
67 * @list: list_head instance to iterate
68 * @evsel: struct perf_evsel iterator
69 */
70#define __perf_evlist__for_each_entry(list, evsel) \
71 list_for_each_entry(evsel, list, node)
72
73/**
74 * evlist__for_each_entry - iterate thru all the evsels
75 * @evlist: perf_evlist instance to iterate
76 * @evsel: struct perf_evsel iterator
77 */
78#define perf_evlist__for_each_entry(evlist, evsel) \
79 __perf_evlist__for_each_entry(&(evlist)->entries, evsel)
80
81/**
82 * __perf_evlist__for_each_entry_reverse - iterate thru all the evsels in reverse order
83 * @list: list_head instance to iterate
84 * @evsel: struct evsel iterator
85 */
86#define __perf_evlist__for_each_entry_reverse(list, evsel) \
87 list_for_each_entry_reverse(evsel, list, node)
88
89/**
90 * perf_evlist__for_each_entry_reverse - iterate thru all the evsels in reverse order
91 * @evlist: evlist instance to iterate
92 * @evsel: struct evsel iterator
93 */
94#define perf_evlist__for_each_entry_reverse(evlist, evsel) \
95 __perf_evlist__for_each_entry_reverse(&(evlist)->entries, evsel)
96
97/**
98 * __perf_evlist__for_each_entry_safe - safely iterate thru all the evsels
99 * @list: list_head instance to iterate
100 * @tmp: struct evsel temp iterator
101 * @evsel: struct evsel iterator
102 */
103#define __perf_evlist__for_each_entry_safe(list, tmp, evsel) \
104 list_for_each_entry_safe(evsel, tmp, list, node)
105
106/**
107 * perf_evlist__for_each_entry_safe - safely iterate thru all the evsels
108 * @evlist: evlist instance to iterate
109 * @evsel: struct evsel iterator
110 * @tmp: struct evsel temp iterator
111 */
112#define perf_evlist__for_each_entry_safe(evlist, tmp, evsel) \
113 __perf_evlist__for_each_entry_safe(&(evlist)->entries, tmp, evsel)
114
115static inline struct perf_evsel *perf_evlist__first(struct perf_evlist *evlist)
116{
117 return list_entry(evlist->entries.next, struct perf_evsel, node);
118}
119
120static inline struct perf_evsel *perf_evlist__last(struct perf_evlist *evlist)
121{
122 return list_entry(evlist->entries.prev, struct perf_evsel, node);
123}
124
125u64 perf_evlist__read_format(struct perf_evlist *evlist);
126
127void perf_evlist__id_add(struct perf_evlist *evlist,
128 struct perf_evsel *evsel,
129 int cpu, int thread, u64 id);
130
131int perf_evlist__id_add_fd(struct perf_evlist *evlist,
132 struct perf_evsel *evsel,
133 int cpu, int thread, int fd);
134
135void perf_evlist__reset_id_hash(struct perf_evlist *evlist);
136
137void __perf_evlist__set_leader(struct list_head *list, struct perf_evsel *leader);
138
139void perf_evlist__go_system_wide(struct perf_evlist *evlist, struct perf_evsel *evsel);
140#endif /* __LIBPERF_INTERNAL_EVLIST_H */
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __LIBPERF_INTERNAL_EVLIST_H
3#define __LIBPERF_INTERNAL_EVLIST_H
4
5#include <linux/list.h>
6#include <api/fd/array.h>
7#include <internal/evsel.h>
8
9#define PERF_EVLIST__HLIST_BITS 8
10#define PERF_EVLIST__HLIST_SIZE (1 << PERF_EVLIST__HLIST_BITS)
11
12struct perf_cpu_map;
13struct perf_thread_map;
14struct perf_mmap_param;
15
16struct perf_evlist {
17 struct list_head entries;
18 int nr_entries;
19 int nr_groups;
20 bool has_user_cpus;
21 struct perf_cpu_map *cpus;
22 struct perf_cpu_map *all_cpus;
23 struct perf_thread_map *threads;
24 int nr_mmaps;
25 size_t mmap_len;
26 struct fdarray pollfd;
27 struct hlist_head heads[PERF_EVLIST__HLIST_SIZE];
28 struct perf_mmap *mmap;
29 struct perf_mmap *mmap_ovw;
30 struct perf_mmap *mmap_first;
31 struct perf_mmap *mmap_ovw_first;
32};
33
34typedef void
35(*perf_evlist_mmap__cb_idx_t)(struct perf_evlist*, struct perf_mmap_param*, int, bool);
36typedef struct perf_mmap*
37(*perf_evlist_mmap__cb_get_t)(struct perf_evlist*, bool, int);
38typedef int
39(*perf_evlist_mmap__cb_mmap_t)(struct perf_mmap*, struct perf_mmap_param*, int, int);
40
41struct perf_evlist_mmap_ops {
42 perf_evlist_mmap__cb_idx_t idx;
43 perf_evlist_mmap__cb_get_t get;
44 perf_evlist_mmap__cb_mmap_t mmap;
45};
46
47int perf_evlist__alloc_pollfd(struct perf_evlist *evlist);
48int perf_evlist__add_pollfd(struct perf_evlist *evlist, int fd,
49 void *ptr, short revent, enum fdarray_flags flags);
50
51int perf_evlist__mmap_ops(struct perf_evlist *evlist,
52 struct perf_evlist_mmap_ops *ops,
53 struct perf_mmap_param *mp);
54
55void perf_evlist__init(struct perf_evlist *evlist);
56void perf_evlist__exit(struct perf_evlist *evlist);
57
58/**
59 * __perf_evlist__for_each_entry - iterate thru all the evsels
60 * @list: list_head instance to iterate
61 * @evsel: struct perf_evsel iterator
62 */
63#define __perf_evlist__for_each_entry(list, evsel) \
64 list_for_each_entry(evsel, list, node)
65
66/**
67 * evlist__for_each_entry - iterate thru all the evsels
68 * @evlist: perf_evlist instance to iterate
69 * @evsel: struct perf_evsel iterator
70 */
71#define perf_evlist__for_each_entry(evlist, evsel) \
72 __perf_evlist__for_each_entry(&(evlist)->entries, evsel)
73
74/**
75 * __perf_evlist__for_each_entry_reverse - iterate thru all the evsels in reverse order
76 * @list: list_head instance to iterate
77 * @evsel: struct evsel iterator
78 */
79#define __perf_evlist__for_each_entry_reverse(list, evsel) \
80 list_for_each_entry_reverse(evsel, list, node)
81
82/**
83 * perf_evlist__for_each_entry_reverse - iterate thru all the evsels in reverse order
84 * @evlist: evlist instance to iterate
85 * @evsel: struct evsel iterator
86 */
87#define perf_evlist__for_each_entry_reverse(evlist, evsel) \
88 __perf_evlist__for_each_entry_reverse(&(evlist)->entries, evsel)
89
90/**
91 * __perf_evlist__for_each_entry_safe - safely iterate thru all the evsels
92 * @list: list_head instance to iterate
93 * @tmp: struct evsel temp iterator
94 * @evsel: struct evsel iterator
95 */
96#define __perf_evlist__for_each_entry_safe(list, tmp, evsel) \
97 list_for_each_entry_safe(evsel, tmp, list, node)
98
99/**
100 * perf_evlist__for_each_entry_safe - safely iterate thru all the evsels
101 * @evlist: evlist instance to iterate
102 * @evsel: struct evsel iterator
103 * @tmp: struct evsel temp iterator
104 */
105#define perf_evlist__for_each_entry_safe(evlist, tmp, evsel) \
106 __perf_evlist__for_each_entry_safe(&(evlist)->entries, tmp, evsel)
107
108static inline struct perf_evsel *perf_evlist__first(struct perf_evlist *evlist)
109{
110 return list_entry(evlist->entries.next, struct perf_evsel, node);
111}
112
113static inline struct perf_evsel *perf_evlist__last(struct perf_evlist *evlist)
114{
115 return list_entry(evlist->entries.prev, struct perf_evsel, node);
116}
117
118u64 perf_evlist__read_format(struct perf_evlist *evlist);
119
120void perf_evlist__id_add(struct perf_evlist *evlist,
121 struct perf_evsel *evsel,
122 int cpu, int thread, u64 id);
123
124int perf_evlist__id_add_fd(struct perf_evlist *evlist,
125 struct perf_evsel *evsel,
126 int cpu, int thread, int fd);
127
128void perf_evlist__reset_id_hash(struct perf_evlist *evlist);
129
130void __perf_evlist__set_leader(struct list_head *list);
131#endif /* __LIBPERF_INTERNAL_EVLIST_H */