xref: /openbmc/linux/tools/perf/tests/parse-events.c (revision ddd83c9717ef8204f17cc63d6dcb5053d472caee)
1945aea22SJiri Olsa 
2945aea22SJiri Olsa #include "parse-events.h"
3945aea22SJiri Olsa #include "evsel.h"
4945aea22SJiri Olsa #include "evlist.h"
5cd0cfad7SBorislav Petkov #include <api/fs/fs.h>
6c81251e8SJiri Olsa #include "tests.h"
784f5d36fSJiri Olsa #include "debug.h"
8f0b9abfbSIngo Molnar #include <linux/hw_breakpoint.h>
94605eab3SJiri Olsa #include <api/fs/fs.h>
10945aea22SJiri Olsa 
11945aea22SJiri Olsa #define PERF_TP_SAMPLE_TYPE (PERF_SAMPLE_RAW | PERF_SAMPLE_TIME | \
12945aea22SJiri Olsa 			     PERF_SAMPLE_CPU | PERF_SAMPLE_PERIOD)
13945aea22SJiri Olsa 
14945aea22SJiri Olsa static int test__checkevent_tracepoint(struct perf_evlist *evlist)
15945aea22SJiri Olsa {
16945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
17945aea22SJiri Olsa 
18945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
198d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong number of groups", 0 == evlist->nr_groups);
20945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
21945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_type",
22945aea22SJiri Olsa 		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
23945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
24945aea22SJiri Olsa 	return 0;
25945aea22SJiri Olsa }
26945aea22SJiri Olsa 
27945aea22SJiri Olsa static int test__checkevent_tracepoint_multi(struct perf_evlist *evlist)
28945aea22SJiri Olsa {
29945aea22SJiri Olsa 	struct perf_evsel *evsel;
30945aea22SJiri Olsa 
31945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", evlist->nr_entries > 1);
328d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong number of groups", 0 == evlist->nr_groups);
33945aea22SJiri Olsa 
340050f7aaSArnaldo Carvalho de Melo 	evlist__for_each(evlist, evsel) {
35945aea22SJiri Olsa 		TEST_ASSERT_VAL("wrong type",
36945aea22SJiri Olsa 			PERF_TYPE_TRACEPOINT == evsel->attr.type);
37945aea22SJiri Olsa 		TEST_ASSERT_VAL("wrong sample_type",
38945aea22SJiri Olsa 			PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
39945aea22SJiri Olsa 		TEST_ASSERT_VAL("wrong sample_period",
40945aea22SJiri Olsa 			1 == evsel->attr.sample_period);
41945aea22SJiri Olsa 	}
42945aea22SJiri Olsa 	return 0;
43945aea22SJiri Olsa }
44945aea22SJiri Olsa 
45945aea22SJiri Olsa static int test__checkevent_raw(struct perf_evlist *evlist)
46945aea22SJiri Olsa {
47945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
48945aea22SJiri Olsa 
49945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
50945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
51945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 0x1a == evsel->attr.config);
52945aea22SJiri Olsa 	return 0;
53945aea22SJiri Olsa }
54945aea22SJiri Olsa 
55945aea22SJiri Olsa static int test__checkevent_numeric(struct perf_evlist *evlist)
56945aea22SJiri Olsa {
57945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
58945aea22SJiri Olsa 
59945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
60945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
61945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
62945aea22SJiri Olsa 	return 0;
63945aea22SJiri Olsa }
64945aea22SJiri Olsa 
65945aea22SJiri Olsa static int test__checkevent_symbolic_name(struct perf_evlist *evlist)
66945aea22SJiri Olsa {
67945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
68945aea22SJiri Olsa 
69945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
70945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
71945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
72945aea22SJiri Olsa 			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
73945aea22SJiri Olsa 	return 0;
74945aea22SJiri Olsa }
75945aea22SJiri Olsa 
76945aea22SJiri Olsa static int test__checkevent_symbolic_name_config(struct perf_evlist *evlist)
77945aea22SJiri Olsa {
78945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
79945aea22SJiri Olsa 
80945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
81945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
82945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
83945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
84ee4c7588SJiri Olsa 	/*
85ee4c7588SJiri Olsa 	 * The period value gets configured within perf_evlist__config,
86ee4c7588SJiri Olsa 	 * while this test executes only parse events method.
87ee4c7588SJiri Olsa 	 */
88945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong period",
89ee4c7588SJiri Olsa 			0 == evsel->attr.sample_period);
90945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config1",
91945aea22SJiri Olsa 			0 == evsel->attr.config1);
92945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config2",
93945aea22SJiri Olsa 			1 == evsel->attr.config2);
94945aea22SJiri Olsa 	return 0;
95945aea22SJiri Olsa }
96945aea22SJiri Olsa 
97945aea22SJiri Olsa static int test__checkevent_symbolic_alias(struct perf_evlist *evlist)
98945aea22SJiri Olsa {
99945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
100945aea22SJiri Olsa 
101945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
102945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_SOFTWARE == evsel->attr.type);
103945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
104945aea22SJiri Olsa 			PERF_COUNT_SW_PAGE_FAULTS == evsel->attr.config);
105945aea22SJiri Olsa 	return 0;
106945aea22SJiri Olsa }
107945aea22SJiri Olsa 
108945aea22SJiri Olsa static int test__checkevent_genhw(struct perf_evlist *evlist)
109945aea22SJiri Olsa {
110945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
111945aea22SJiri Olsa 
112945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
113945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HW_CACHE == evsel->attr.type);
114945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", (1 << 16) == evsel->attr.config);
115945aea22SJiri Olsa 	return 0;
116945aea22SJiri Olsa }
117945aea22SJiri Olsa 
118945aea22SJiri Olsa static int test__checkevent_breakpoint(struct perf_evlist *evlist)
119945aea22SJiri Olsa {
120945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
121945aea22SJiri Olsa 
122945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
123945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
124945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
125945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_type", (HW_BREAKPOINT_R | HW_BREAKPOINT_W) ==
126945aea22SJiri Olsa 					 evsel->attr.bp_type);
127945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_len", HW_BREAKPOINT_LEN_4 ==
128945aea22SJiri Olsa 					evsel->attr.bp_len);
129945aea22SJiri Olsa 	return 0;
130945aea22SJiri Olsa }
131945aea22SJiri Olsa 
132945aea22SJiri Olsa static int test__checkevent_breakpoint_x(struct perf_evlist *evlist)
133945aea22SJiri Olsa {
134945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
135945aea22SJiri Olsa 
136945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
137945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
138945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
139945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_type",
140945aea22SJiri Olsa 			HW_BREAKPOINT_X == evsel->attr.bp_type);
141945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_len", sizeof(long) == evsel->attr.bp_len);
142945aea22SJiri Olsa 	return 0;
143945aea22SJiri Olsa }
144945aea22SJiri Olsa 
145945aea22SJiri Olsa static int test__checkevent_breakpoint_r(struct perf_evlist *evlist)
146945aea22SJiri Olsa {
147945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
148945aea22SJiri Olsa 
149945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
150945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type",
151945aea22SJiri Olsa 			PERF_TYPE_BREAKPOINT == evsel->attr.type);
152945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
153945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_type",
154945aea22SJiri Olsa 			HW_BREAKPOINT_R == evsel->attr.bp_type);
155945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_len",
156945aea22SJiri Olsa 			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
157945aea22SJiri Olsa 	return 0;
158945aea22SJiri Olsa }
159945aea22SJiri Olsa 
160945aea22SJiri Olsa static int test__checkevent_breakpoint_w(struct perf_evlist *evlist)
161945aea22SJiri Olsa {
162945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
163945aea22SJiri Olsa 
164945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
165945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type",
166945aea22SJiri Olsa 			PERF_TYPE_BREAKPOINT == evsel->attr.type);
167945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
168945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_type",
169945aea22SJiri Olsa 			HW_BREAKPOINT_W == evsel->attr.bp_type);
170945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_len",
171945aea22SJiri Olsa 			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
172945aea22SJiri Olsa 	return 0;
173945aea22SJiri Olsa }
174945aea22SJiri Olsa 
175945aea22SJiri Olsa static int test__checkevent_breakpoint_rw(struct perf_evlist *evlist)
176945aea22SJiri Olsa {
177945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
178945aea22SJiri Olsa 
179945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
180945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type",
181945aea22SJiri Olsa 			PERF_TYPE_BREAKPOINT == evsel->attr.type);
182945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
183945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_type",
184945aea22SJiri Olsa 		(HW_BREAKPOINT_R|HW_BREAKPOINT_W) == evsel->attr.bp_type);
185945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong bp_len",
186945aea22SJiri Olsa 			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
187945aea22SJiri Olsa 	return 0;
188945aea22SJiri Olsa }
189945aea22SJiri Olsa 
190945aea22SJiri Olsa static int test__checkevent_tracepoint_modifier(struct perf_evlist *evlist)
191945aea22SJiri Olsa {
192945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
193945aea22SJiri Olsa 
194945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
195945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
196945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
197945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
198945aea22SJiri Olsa 
199945aea22SJiri Olsa 	return test__checkevent_tracepoint(evlist);
200945aea22SJiri Olsa }
201945aea22SJiri Olsa 
202945aea22SJiri Olsa static int
203945aea22SJiri Olsa test__checkevent_tracepoint_multi_modifier(struct perf_evlist *evlist)
204945aea22SJiri Olsa {
205945aea22SJiri Olsa 	struct perf_evsel *evsel;
206945aea22SJiri Olsa 
207945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", evlist->nr_entries > 1);
208945aea22SJiri Olsa 
2090050f7aaSArnaldo Carvalho de Melo 	evlist__for_each(evlist, evsel) {
210945aea22SJiri Olsa 		TEST_ASSERT_VAL("wrong exclude_user",
211945aea22SJiri Olsa 				!evsel->attr.exclude_user);
212945aea22SJiri Olsa 		TEST_ASSERT_VAL("wrong exclude_kernel",
213945aea22SJiri Olsa 				evsel->attr.exclude_kernel);
214945aea22SJiri Olsa 		TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
215945aea22SJiri Olsa 		TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
216945aea22SJiri Olsa 	}
217945aea22SJiri Olsa 
218945aea22SJiri Olsa 	return test__checkevent_tracepoint_multi(evlist);
219945aea22SJiri Olsa }
220945aea22SJiri Olsa 
221945aea22SJiri Olsa static int test__checkevent_raw_modifier(struct perf_evlist *evlist)
222945aea22SJiri Olsa {
223945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
224945aea22SJiri Olsa 
225945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
226945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
227945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
228945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
229945aea22SJiri Olsa 
230945aea22SJiri Olsa 	return test__checkevent_raw(evlist);
231945aea22SJiri Olsa }
232945aea22SJiri Olsa 
233945aea22SJiri Olsa static int test__checkevent_numeric_modifier(struct perf_evlist *evlist)
234945aea22SJiri Olsa {
235945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
236945aea22SJiri Olsa 
237945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
238945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
239945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
240945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
241945aea22SJiri Olsa 
242945aea22SJiri Olsa 	return test__checkevent_numeric(evlist);
243945aea22SJiri Olsa }
244945aea22SJiri Olsa 
245945aea22SJiri Olsa static int test__checkevent_symbolic_name_modifier(struct perf_evlist *evlist)
246945aea22SJiri Olsa {
247945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
248945aea22SJiri Olsa 
249945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
250945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
251945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
252945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
253945aea22SJiri Olsa 
254945aea22SJiri Olsa 	return test__checkevent_symbolic_name(evlist);
255945aea22SJiri Olsa }
256945aea22SJiri Olsa 
257945aea22SJiri Olsa static int test__checkevent_exclude_host_modifier(struct perf_evlist *evlist)
258945aea22SJiri Olsa {
259945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
260945aea22SJiri Olsa 
261945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
262945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
263945aea22SJiri Olsa 
264945aea22SJiri Olsa 	return test__checkevent_symbolic_name(evlist);
265945aea22SJiri Olsa }
266945aea22SJiri Olsa 
267945aea22SJiri Olsa static int test__checkevent_exclude_guest_modifier(struct perf_evlist *evlist)
268945aea22SJiri Olsa {
269945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
270945aea22SJiri Olsa 
271945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
272945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
273945aea22SJiri Olsa 
274945aea22SJiri Olsa 	return test__checkevent_symbolic_name(evlist);
275945aea22SJiri Olsa }
276945aea22SJiri Olsa 
277945aea22SJiri Olsa static int test__checkevent_symbolic_alias_modifier(struct perf_evlist *evlist)
278945aea22SJiri Olsa {
279945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
280945aea22SJiri Olsa 
281945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
282945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
283945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
284945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
285945aea22SJiri Olsa 
286945aea22SJiri Olsa 	return test__checkevent_symbolic_alias(evlist);
287945aea22SJiri Olsa }
288945aea22SJiri Olsa 
289945aea22SJiri Olsa static int test__checkevent_genhw_modifier(struct perf_evlist *evlist)
290945aea22SJiri Olsa {
291945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
292945aea22SJiri Olsa 
293945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
294945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
295945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
296945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
297945aea22SJiri Olsa 
298945aea22SJiri Olsa 	return test__checkevent_genhw(evlist);
299945aea22SJiri Olsa }
300945aea22SJiri Olsa 
301a1e12da4SJiri Olsa static int test__checkevent_exclude_idle_modifier(struct perf_evlist *evlist)
302a1e12da4SJiri Olsa {
303a1e12da4SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
304a1e12da4SJiri Olsa 
305a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude idle", evsel->attr.exclude_idle);
306a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
307a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
308a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
309a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
310a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
311a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
312a1e12da4SJiri Olsa 
313a1e12da4SJiri Olsa 	return test__checkevent_symbolic_name(evlist);
314a1e12da4SJiri Olsa }
315a1e12da4SJiri Olsa 
316a1e12da4SJiri Olsa static int test__checkevent_exclude_idle_modifier_1(struct perf_evlist *evlist)
317a1e12da4SJiri Olsa {
318a1e12da4SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
319a1e12da4SJiri Olsa 
320a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude idle", evsel->attr.exclude_idle);
321a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
322a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
323a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
324a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
325a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
326a1e12da4SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
327a1e12da4SJiri Olsa 
328a1e12da4SJiri Olsa 	return test__checkevent_symbolic_name(evlist);
329a1e12da4SJiri Olsa }
330a1e12da4SJiri Olsa 
331945aea22SJiri Olsa static int test__checkevent_breakpoint_modifier(struct perf_evlist *evlist)
332945aea22SJiri Olsa {
333945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
334945aea22SJiri Olsa 
335945aea22SJiri Olsa 
336945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
337945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
338945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
339945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
340945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong name",
341945aea22SJiri Olsa 			!strcmp(perf_evsel__name(evsel), "mem:0:u"));
342945aea22SJiri Olsa 
343945aea22SJiri Olsa 	return test__checkevent_breakpoint(evlist);
344945aea22SJiri Olsa }
345945aea22SJiri Olsa 
346945aea22SJiri Olsa static int test__checkevent_breakpoint_x_modifier(struct perf_evlist *evlist)
347945aea22SJiri Olsa {
348945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
349945aea22SJiri Olsa 
350945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
351945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
352945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
353945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
354945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong name",
355945aea22SJiri Olsa 			!strcmp(perf_evsel__name(evsel), "mem:0:x:k"));
356945aea22SJiri Olsa 
357945aea22SJiri Olsa 	return test__checkevent_breakpoint_x(evlist);
358945aea22SJiri Olsa }
359945aea22SJiri Olsa 
360945aea22SJiri Olsa static int test__checkevent_breakpoint_r_modifier(struct perf_evlist *evlist)
361945aea22SJiri Olsa {
362945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
363945aea22SJiri Olsa 
364945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
365945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
366945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
367945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
368945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong name",
369945aea22SJiri Olsa 			!strcmp(perf_evsel__name(evsel), "mem:0:r:hp"));
370945aea22SJiri Olsa 
371945aea22SJiri Olsa 	return test__checkevent_breakpoint_r(evlist);
372945aea22SJiri Olsa }
373945aea22SJiri Olsa 
374945aea22SJiri Olsa static int test__checkevent_breakpoint_w_modifier(struct perf_evlist *evlist)
375945aea22SJiri Olsa {
376945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
377945aea22SJiri Olsa 
378945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
379945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
380945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
381945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
382945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong name",
383945aea22SJiri Olsa 			!strcmp(perf_evsel__name(evsel), "mem:0:w:up"));
384945aea22SJiri Olsa 
385945aea22SJiri Olsa 	return test__checkevent_breakpoint_w(evlist);
386945aea22SJiri Olsa }
387945aea22SJiri Olsa 
388945aea22SJiri Olsa static int test__checkevent_breakpoint_rw_modifier(struct perf_evlist *evlist)
389945aea22SJiri Olsa {
390945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
391945aea22SJiri Olsa 
392945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
393945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
394945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
395945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
396945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong name",
397945aea22SJiri Olsa 			!strcmp(perf_evsel__name(evsel), "mem:0:rw:kp"));
398945aea22SJiri Olsa 
399945aea22SJiri Olsa 	return test__checkevent_breakpoint_rw(evlist);
400945aea22SJiri Olsa }
401945aea22SJiri Olsa 
402945aea22SJiri Olsa static int test__checkevent_pmu(struct perf_evlist *evlist)
403945aea22SJiri Olsa {
404945aea22SJiri Olsa 
405945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
406945aea22SJiri Olsa 
407945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
408945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
409945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",    10 == evsel->attr.config);
410945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config1",    1 == evsel->attr.config1);
411945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config2",    3 == evsel->attr.config2);
412ee4c7588SJiri Olsa 	/*
413ee4c7588SJiri Olsa 	 * The period value gets configured within perf_evlist__config,
414ee4c7588SJiri Olsa 	 * while this test executes only parse events method.
415ee4c7588SJiri Olsa 	 */
416ee4c7588SJiri Olsa 	TEST_ASSERT_VAL("wrong period",     0 == evsel->attr.sample_period);
417945aea22SJiri Olsa 
418945aea22SJiri Olsa 	return 0;
419945aea22SJiri Olsa }
420945aea22SJiri Olsa 
421945aea22SJiri Olsa static int test__checkevent_list(struct perf_evlist *evlist)
422945aea22SJiri Olsa {
423945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
424945aea22SJiri Olsa 
425945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
426945aea22SJiri Olsa 
427945aea22SJiri Olsa 	/* r1 */
428945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
429945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
430945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config1", 0 == evsel->attr.config1);
431945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config2", 0 == evsel->attr.config2);
432945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
433945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
434945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
435945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
436945aea22SJiri Olsa 
43743f322b4SRiku Voipio 	/* syscalls:sys_enter_openat:k */
438945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
439945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
440945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_type",
441945aea22SJiri Olsa 		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
442945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
443945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
444945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
445945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
446945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
447945aea22SJiri Olsa 
448945aea22SJiri Olsa 	/* 1:1:hp */
449945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
450945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
451945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
452945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
453945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
454945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
455945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
456945aea22SJiri Olsa 
457945aea22SJiri Olsa 	return 0;
458945aea22SJiri Olsa }
459945aea22SJiri Olsa 
460945aea22SJiri Olsa static int test__checkevent_pmu_name(struct perf_evlist *evlist)
461945aea22SJiri Olsa {
462945aea22SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
463945aea22SJiri Olsa 
464945aea22SJiri Olsa 	/* cpu/config=1,name=krava/u */
465945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
466945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
467945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",  1 == evsel->attr.config);
468945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong name", !strcmp(perf_evsel__name(evsel), "krava"));
469945aea22SJiri Olsa 
470945aea22SJiri Olsa 	/* cpu/config=2/u" */
471945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
472945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
473945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
474945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",  2 == evsel->attr.config);
475945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong name",
476945aea22SJiri Olsa 			!strcmp(perf_evsel__name(evsel), "cpu/config=2/u"));
477945aea22SJiri Olsa 
478945aea22SJiri Olsa 	return 0;
479945aea22SJiri Olsa }
480945aea22SJiri Olsa 
48171ef150eSKan Liang static int test__checkevent_pmu_partial_time_callgraph(struct perf_evlist *evlist)
48271ef150eSKan Liang {
48371ef150eSKan Liang 	struct perf_evsel *evsel = perf_evlist__first(evlist);
48471ef150eSKan Liang 
48571ef150eSKan Liang 	/* cpu/config=1,call-graph=fp,time,period=100000/ */
48671ef150eSKan Liang 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
48771ef150eSKan Liang 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
48871ef150eSKan Liang 	TEST_ASSERT_VAL("wrong config",  1 == evsel->attr.config);
48971ef150eSKan Liang 	/*
49071ef150eSKan Liang 	 * The period, time and callgraph value gets configured
49171ef150eSKan Liang 	 * within perf_evlist__config,
49271ef150eSKan Liang 	 * while this test executes only parse events method.
49371ef150eSKan Liang 	 */
49471ef150eSKan Liang 	TEST_ASSERT_VAL("wrong period",     0 == evsel->attr.sample_period);
49571ef150eSKan Liang 	TEST_ASSERT_VAL("wrong callgraph",  !(PERF_SAMPLE_CALLCHAIN & evsel->attr.sample_type));
49671ef150eSKan Liang 	TEST_ASSERT_VAL("wrong time",  !(PERF_SAMPLE_TIME & evsel->attr.sample_type));
49771ef150eSKan Liang 
49871ef150eSKan Liang 	/* cpu/config=2,call-graph=no,time=0,period=2000/ */
49971ef150eSKan Liang 	evsel = perf_evsel__next(evsel);
50071ef150eSKan Liang 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
50171ef150eSKan Liang 	TEST_ASSERT_VAL("wrong config",  2 == evsel->attr.config);
50271ef150eSKan Liang 	/*
50371ef150eSKan Liang 	 * The period, time and callgraph value gets configured
50471ef150eSKan Liang 	 * within perf_evlist__config,
50571ef150eSKan Liang 	 * while this test executes only parse events method.
50671ef150eSKan Liang 	 */
50771ef150eSKan Liang 	TEST_ASSERT_VAL("wrong period",     0 == evsel->attr.sample_period);
50871ef150eSKan Liang 	TEST_ASSERT_VAL("wrong callgraph",  !(PERF_SAMPLE_CALLCHAIN & evsel->attr.sample_type));
50971ef150eSKan Liang 	TEST_ASSERT_VAL("wrong time",  !(PERF_SAMPLE_TIME & evsel->attr.sample_type));
51071ef150eSKan Liang 
51171ef150eSKan Liang 	return 0;
51271ef150eSKan Liang }
51371ef150eSKan Liang 
514945aea22SJiri Olsa static int test__checkevent_pmu_events(struct perf_evlist *evlist)
515945aea22SJiri Olsa {
5169a354cdcSArnaldo Carvalho de Melo 	struct perf_evsel *evsel = perf_evlist__first(evlist);
517945aea22SJiri Olsa 
518945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
519945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
520945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user",
521945aea22SJiri Olsa 			!evsel->attr.exclude_user);
522945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel",
523945aea22SJiri Olsa 			evsel->attr.exclude_kernel);
524945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
525945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
526c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
527945aea22SJiri Olsa 
528945aea22SJiri Olsa 	return 0;
529945aea22SJiri Olsa }
530945aea22SJiri Olsa 
531ffe59788SKan Liang 
532ffe59788SKan Liang static int test__checkevent_pmu_events_mix(struct perf_evlist *evlist)
533ffe59788SKan Liang {
534ffe59788SKan Liang 	struct perf_evsel *evsel = perf_evlist__first(evlist);
535ffe59788SKan Liang 
536ffe59788SKan Liang 	/* pmu-event:u */
537ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
538ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong exclude_user",
539ffe59788SKan Liang 			!evsel->attr.exclude_user);
540ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong exclude_kernel",
541ffe59788SKan Liang 			evsel->attr.exclude_kernel);
542ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
543ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
544ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
545ffe59788SKan Liang 
546ffe59788SKan Liang 	/* cpu/pmu-event/u*/
547ffe59788SKan Liang 	evsel = perf_evsel__next(evsel);
548ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
549ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
550ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong exclude_user",
551ffe59788SKan Liang 			!evsel->attr.exclude_user);
552ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong exclude_kernel",
553ffe59788SKan Liang 			evsel->attr.exclude_kernel);
554ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
555ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
556ffe59788SKan Liang 	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
557ffe59788SKan Liang 
558ffe59788SKan Liang 	return 0;
559ffe59788SKan Liang }
560ffe59788SKan Liang 
561945aea22SJiri Olsa static int test__checkterms_simple(struct list_head *terms)
562945aea22SJiri Olsa {
5636cee6cd3SArnaldo Carvalho de Melo 	struct parse_events_term *term;
564945aea22SJiri Olsa 
565945aea22SJiri Olsa 	/* config=10 */
5666cee6cd3SArnaldo Carvalho de Melo 	term = list_entry(terms->next, struct parse_events_term, list);
567945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type term",
568945aea22SJiri Olsa 			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG);
569945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type val",
570945aea22SJiri Olsa 			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
571945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong val", term->val.num == 10);
572945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", !term->config);
573945aea22SJiri Olsa 
574945aea22SJiri Olsa 	/* config1 */
5756cee6cd3SArnaldo Carvalho de Melo 	term = list_entry(term->list.next, struct parse_events_term, list);
576945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type term",
577945aea22SJiri Olsa 			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG1);
578945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type val",
579945aea22SJiri Olsa 			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
580945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong val", term->val.num == 1);
581945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", !term->config);
582945aea22SJiri Olsa 
583945aea22SJiri Olsa 	/* config2=3 */
5846cee6cd3SArnaldo Carvalho de Melo 	term = list_entry(term->list.next, struct parse_events_term, list);
585945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type term",
586945aea22SJiri Olsa 			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG2);
587945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type val",
588945aea22SJiri Olsa 			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
589945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong val", term->val.num == 3);
590945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", !term->config);
591945aea22SJiri Olsa 
592945aea22SJiri Olsa 	/* umask=1*/
5936cee6cd3SArnaldo Carvalho de Melo 	term = list_entry(term->list.next, struct parse_events_term, list);
594945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type term",
595945aea22SJiri Olsa 			term->type_term == PARSE_EVENTS__TERM_TYPE_USER);
596945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type val",
597945aea22SJiri Olsa 			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
598945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong val", term->val.num == 1);
599945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", !strcmp(term->config, "umask"));
600945aea22SJiri Olsa 
601945aea22SJiri Olsa 	return 0;
602945aea22SJiri Olsa }
603945aea22SJiri Olsa 
604945aea22SJiri Olsa static int test__group1(struct perf_evlist *evlist)
605945aea22SJiri Olsa {
606945aea22SJiri Olsa 	struct perf_evsel *evsel, *leader;
607945aea22SJiri Olsa 
608945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
6098d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
610945aea22SJiri Olsa 
611945aea22SJiri Olsa 	/* instructions:k */
612945aea22SJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
613945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
614945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
615945aea22SJiri Olsa 			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
616945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
617945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
618945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
619945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
620945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
621945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
622823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
6238d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
6248d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
625a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
626945aea22SJiri Olsa 
627945aea22SJiri Olsa 	/* cycles:upp */
628945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
629945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
630945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
631945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
632945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
633945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
634945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
635945aea22SJiri Olsa 	/* use of precise requires exclude_guest */
636945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
637945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
638945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 2);
639945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
6408d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
641a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
642945aea22SJiri Olsa 
643945aea22SJiri Olsa 	return 0;
644945aea22SJiri Olsa }
645945aea22SJiri Olsa 
646945aea22SJiri Olsa static int test__group2(struct perf_evlist *evlist)
647945aea22SJiri Olsa {
648945aea22SJiri Olsa 	struct perf_evsel *evsel, *leader;
649945aea22SJiri Olsa 
650945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
6518d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
652945aea22SJiri Olsa 
653945aea22SJiri Olsa 	/* faults + :ku modifier */
654945aea22SJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
655945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_SOFTWARE == evsel->attr.type);
656945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
657945aea22SJiri Olsa 			PERF_COUNT_SW_PAGE_FAULTS == evsel->attr.config);
658945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
659945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
660945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
661945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
662945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
663945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
664823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
6658d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
6668d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
667a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
668945aea22SJiri Olsa 
669945aea22SJiri Olsa 	/* cache-references + :u modifier */
670945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
671945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
672945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
673945aea22SJiri Olsa 			PERF_COUNT_HW_CACHE_REFERENCES == evsel->attr.config);
674945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
675945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
676945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
6775a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
678945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
679945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
680945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
6818d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
682a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
683945aea22SJiri Olsa 
684945aea22SJiri Olsa 	/* cycles:k */
685945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
686945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
687945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
688945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
689945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
690945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
691945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
692945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
693945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
694945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
695823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
696a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
697945aea22SJiri Olsa 
698945aea22SJiri Olsa 	return 0;
699945aea22SJiri Olsa }
700945aea22SJiri Olsa 
701945aea22SJiri Olsa static int test__group3(struct perf_evlist *evlist __maybe_unused)
702945aea22SJiri Olsa {
703945aea22SJiri Olsa 	struct perf_evsel *evsel, *leader;
704945aea22SJiri Olsa 
705945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 5 == evlist->nr_entries);
7068d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong number of groups", 2 == evlist->nr_groups);
707945aea22SJiri Olsa 
70843f322b4SRiku Voipio 	/* group1 syscalls:sys_enter_openat:H */
709945aea22SJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
710945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
711945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_type",
712945aea22SJiri Olsa 		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
713945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
714945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
715945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
716945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
717945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
718945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
719945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
720823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
721945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong group name",
722945aea22SJiri Olsa 		!strcmp(leader->group_name, "group1"));
7238d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
7248d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
725a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
726945aea22SJiri Olsa 
727945aea22SJiri Olsa 	/* group1 cycles:kppp */
728945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
729945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
730945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
731945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
732945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
733945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
734945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
735945aea22SJiri Olsa 	/* use of precise requires exclude_guest */
736945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
737945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
738945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 3);
739945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
740945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
7418d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
742a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
743945aea22SJiri Olsa 
744945aea22SJiri Olsa 	/* group2 cycles + G modifier */
745945aea22SJiri Olsa 	evsel = leader = perf_evsel__next(evsel);
746945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
747945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
748945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
749945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
750945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
751945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
752945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
753945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
754945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
755823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
756945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong group name",
757945aea22SJiri Olsa 		!strcmp(leader->group_name, "group2"));
7588d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
7598d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
760a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
761945aea22SJiri Olsa 
762945aea22SJiri Olsa 	/* group2 1:3 + G modifier */
763945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
764945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
765945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config", 3 == evsel->attr.config);
766945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
767945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
768945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
769945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
770945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
771945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
772945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
7738d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
774a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
775945aea22SJiri Olsa 
776945aea22SJiri Olsa 	/* instructions:u */
777945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
778945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
779945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
780945aea22SJiri Olsa 			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
781945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
782945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
783945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
784945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
785945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
786945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
787823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
788a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
789945aea22SJiri Olsa 
790945aea22SJiri Olsa 	return 0;
791945aea22SJiri Olsa }
792945aea22SJiri Olsa 
793945aea22SJiri Olsa static int test__group4(struct perf_evlist *evlist __maybe_unused)
794945aea22SJiri Olsa {
795945aea22SJiri Olsa 	struct perf_evsel *evsel, *leader;
796945aea22SJiri Olsa 
797945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
7988d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
799945aea22SJiri Olsa 
800945aea22SJiri Olsa 	/* cycles:u + p */
801945aea22SJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
802945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
803945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
804945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
805945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
806945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
807945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
808945aea22SJiri Olsa 	/* use of precise requires exclude_guest */
809945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
810945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
811945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 1);
812945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
813823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
8148d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
8158d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
816a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
817945aea22SJiri Olsa 
818945aea22SJiri Olsa 	/* instructions:kp + p */
819945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
820945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
821945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
822945aea22SJiri Olsa 			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
823945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
824945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
825945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
826945aea22SJiri Olsa 	/* use of precise requires exclude_guest */
827945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
828945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
829945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 2);
830945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
8318d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
832a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
833945aea22SJiri Olsa 
834945aea22SJiri Olsa 	return 0;
835945aea22SJiri Olsa }
836945aea22SJiri Olsa 
837945aea22SJiri Olsa static int test__group5(struct perf_evlist *evlist __maybe_unused)
838945aea22SJiri Olsa {
839945aea22SJiri Olsa 	struct perf_evsel *evsel, *leader;
840945aea22SJiri Olsa 
841945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 5 == evlist->nr_entries);
8428d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong number of groups", 2 == evlist->nr_groups);
843945aea22SJiri Olsa 
844945aea22SJiri Olsa 	/* cycles + G */
845945aea22SJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
846945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
847945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
848945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
849945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
850945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
851945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
852945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
853945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
854945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
855945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
856823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
8578d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
8588d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
859a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
860945aea22SJiri Olsa 
861945aea22SJiri Olsa 	/* instructions + G */
862945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
863945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
864945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
865945aea22SJiri Olsa 			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
866945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
867945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
868945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
869945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
870945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
871945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
872945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
8738d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
874a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
875945aea22SJiri Olsa 
876945aea22SJiri Olsa 	/* cycles:G */
877945aea22SJiri Olsa 	evsel = leader = perf_evsel__next(evsel);
878945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
879945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
880945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
881945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
882945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
883945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
884945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
885945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
886945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
887945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
888823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
8898d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
8908d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
891a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
892945aea22SJiri Olsa 
893945aea22SJiri Olsa 	/* instructions:G */
894945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
895945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
896945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
897945aea22SJiri Olsa 			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
898945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
899945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
900945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
901945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
902945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
903945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
904945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
9058d7d8474SNamhyung Kim 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
906945aea22SJiri Olsa 
907945aea22SJiri Olsa 	/* cycles */
908945aea22SJiri Olsa 	evsel = perf_evsel__next(evsel);
909945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
910945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
911945aea22SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
912945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
913945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
914945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
915945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
916945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
917945aea22SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
918823254edSNamhyung Kim 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
919945aea22SJiri Olsa 
920945aea22SJiri Olsa 	return 0;
921945aea22SJiri Olsa }
922945aea22SJiri Olsa 
9235a30a99fSJiri Olsa static int test__group_gh1(struct perf_evlist *evlist)
9245a30a99fSJiri Olsa {
9255a30a99fSJiri Olsa 	struct perf_evsel *evsel, *leader;
9265a30a99fSJiri Olsa 
9275a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
9285a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
9295a30a99fSJiri Olsa 
9305a30a99fSJiri Olsa 	/* cycles + :H group modifier */
9315a30a99fSJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
9325a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
9335a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong config",
9345a30a99fSJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
9355a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
9365a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
9375a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
9385a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
9395a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
9405a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
9415a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
9425a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
9435a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
9445a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
9455a30a99fSJiri Olsa 
9465a30a99fSJiri Olsa 	/* cache-misses:G + :H group modifier */
9475a30a99fSJiri Olsa 	evsel = perf_evsel__next(evsel);
9485a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
9495a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong config",
9505a30a99fSJiri Olsa 			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
9515a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
9525a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
9535a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
9545a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
9555a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
9565a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
9575a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
9585a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
9595a30a99fSJiri Olsa 
9605a30a99fSJiri Olsa 	return 0;
9615a30a99fSJiri Olsa }
9625a30a99fSJiri Olsa 
9635a30a99fSJiri Olsa static int test__group_gh2(struct perf_evlist *evlist)
9645a30a99fSJiri Olsa {
9655a30a99fSJiri Olsa 	struct perf_evsel *evsel, *leader;
9665a30a99fSJiri Olsa 
9675a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
9685a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
9695a30a99fSJiri Olsa 
9705a30a99fSJiri Olsa 	/* cycles + :G group modifier */
9715a30a99fSJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
9725a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
9735a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong config",
9745a30a99fSJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
9755a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
9765a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
9775a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
9785a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
9795a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
9805a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
9815a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
9825a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
9835a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
9845a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
9855a30a99fSJiri Olsa 
9865a30a99fSJiri Olsa 	/* cache-misses:H + :G group modifier */
9875a30a99fSJiri Olsa 	evsel = perf_evsel__next(evsel);
9885a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
9895a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong config",
9905a30a99fSJiri Olsa 			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
9915a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
9925a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
9935a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
9945a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
9955a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
9965a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
9975a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
9985a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
9995a30a99fSJiri Olsa 
10005a30a99fSJiri Olsa 	return 0;
10015a30a99fSJiri Olsa }
10025a30a99fSJiri Olsa 
10035a30a99fSJiri Olsa static int test__group_gh3(struct perf_evlist *evlist)
10045a30a99fSJiri Olsa {
10055a30a99fSJiri Olsa 	struct perf_evsel *evsel, *leader;
10065a30a99fSJiri Olsa 
10075a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
10085a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
10095a30a99fSJiri Olsa 
10105a30a99fSJiri Olsa 	/* cycles:G + :u group modifier */
10115a30a99fSJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
10125a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
10135a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong config",
10145a30a99fSJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
10155a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
10165a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
10175a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
10185a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
10195a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
10205a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
10215a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
10225a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
10235a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
10245a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
10255a30a99fSJiri Olsa 
10265a30a99fSJiri Olsa 	/* cache-misses:H + :u group modifier */
10275a30a99fSJiri Olsa 	evsel = perf_evsel__next(evsel);
10285a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
10295a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong config",
10305a30a99fSJiri Olsa 			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
10315a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
10325a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
10335a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
10345a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
10355a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
10365a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
10375a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
10385a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
10395a30a99fSJiri Olsa 
10405a30a99fSJiri Olsa 	return 0;
10415a30a99fSJiri Olsa }
10425a30a99fSJiri Olsa 
10435a30a99fSJiri Olsa static int test__group_gh4(struct perf_evlist *evlist)
10445a30a99fSJiri Olsa {
10455a30a99fSJiri Olsa 	struct perf_evsel *evsel, *leader;
10465a30a99fSJiri Olsa 
10475a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
10485a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
10495a30a99fSJiri Olsa 
10505a30a99fSJiri Olsa 	/* cycles:G + :uG group modifier */
10515a30a99fSJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
10525a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
10535a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong config",
10545a30a99fSJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
10555a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
10565a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
10575a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
10585a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
10595a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
10605a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
10615a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
10625a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
10635a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
10645a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
10655a30a99fSJiri Olsa 
10665a30a99fSJiri Olsa 	/* cache-misses:H + :uG group modifier */
10675a30a99fSJiri Olsa 	evsel = perf_evsel__next(evsel);
10685a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
10695a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong config",
10705a30a99fSJiri Olsa 			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
10715a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
10725a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
10735a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
10745a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
10755a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
10765a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
10775a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
10785a30a99fSJiri Olsa 	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
10795a30a99fSJiri Olsa 
10805a30a99fSJiri Olsa 	return 0;
10815a30a99fSJiri Olsa }
10825a30a99fSJiri Olsa 
1083a9f93f97SJiri Olsa static int test__leader_sample1(struct perf_evlist *evlist)
1084a9f93f97SJiri Olsa {
1085a9f93f97SJiri Olsa 	struct perf_evsel *evsel, *leader;
1086a9f93f97SJiri Olsa 
1087a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
1088a9f93f97SJiri Olsa 
1089a9f93f97SJiri Olsa 	/* cycles - sampling group leader */
1090a9f93f97SJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
1091a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1092a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
1093a9f93f97SJiri Olsa 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
1094a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1095a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
1096a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
1097a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1098a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1099a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1100a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1101a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1102a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1103a9f93f97SJiri Olsa 
1104a9f93f97SJiri Olsa 	/* cache-misses - not sampling */
1105a9f93f97SJiri Olsa 	evsel = perf_evsel__next(evsel);
1106a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1107a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
1108a9f93f97SJiri Olsa 			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
1109a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1110a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
1111a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
1112a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1113a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1114a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1115a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1116a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1117a9f93f97SJiri Olsa 
1118a9f93f97SJiri Olsa 	/* branch-misses - not sampling */
1119a9f93f97SJiri Olsa 	evsel = perf_evsel__next(evsel);
1120a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1121a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
1122a9f93f97SJiri Olsa 			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1123a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1124a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
1125a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
1126a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1127a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1128a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1129a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1130a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1131a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1132a9f93f97SJiri Olsa 
1133a9f93f97SJiri Olsa 	return 0;
1134a9f93f97SJiri Olsa }
1135a9f93f97SJiri Olsa 
1136a9f93f97SJiri Olsa static int test__leader_sample2(struct perf_evlist *evlist __maybe_unused)
1137a9f93f97SJiri Olsa {
1138a9f93f97SJiri Olsa 	struct perf_evsel *evsel, *leader;
1139a9f93f97SJiri Olsa 
1140a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
1141a9f93f97SJiri Olsa 
1142a9f93f97SJiri Olsa 	/* instructions - sampling group leader */
1143a9f93f97SJiri Olsa 	evsel = leader = perf_evlist__first(evlist);
1144a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1145a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
1146a9f93f97SJiri Olsa 			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
1147a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1148a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1149a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1150a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1151a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1152a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1153a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1154a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1155a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1156a9f93f97SJiri Olsa 
1157a9f93f97SJiri Olsa 	/* branch-misses - not sampling */
1158a9f93f97SJiri Olsa 	evsel = perf_evsel__next(evsel);
1159a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1160a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
1161a9f93f97SJiri Olsa 			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1162a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1163a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1164a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1165a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1166a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1167a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1168a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1169a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1170a9f93f97SJiri Olsa 	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1171a9f93f97SJiri Olsa 
1172a9f93f97SJiri Olsa 	return 0;
1173a9f93f97SJiri Olsa }
1174a9f93f97SJiri Olsa 
1175c9ee780fSMichael Ellerman static int test__checkevent_pinned_modifier(struct perf_evlist *evlist)
1176c9ee780fSMichael Ellerman {
1177c9ee780fSMichael Ellerman 	struct perf_evsel *evsel = perf_evlist__first(evlist);
1178c9ee780fSMichael Ellerman 
1179c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1180c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1181c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1182c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
1183c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong pinned", evsel->attr.pinned);
1184c9ee780fSMichael Ellerman 
1185c9ee780fSMichael Ellerman 	return test__checkevent_symbolic_name(evlist);
1186c9ee780fSMichael Ellerman }
1187c9ee780fSMichael Ellerman 
1188c9ee780fSMichael Ellerman static int test__pinned_group(struct perf_evlist *evlist)
1189c9ee780fSMichael Ellerman {
1190c9ee780fSMichael Ellerman 	struct perf_evsel *evsel, *leader;
1191c9ee780fSMichael Ellerman 
1192c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
1193c9ee780fSMichael Ellerman 
1194c9ee780fSMichael Ellerman 	/* cycles - group leader */
1195c9ee780fSMichael Ellerman 	evsel = leader = perf_evlist__first(evlist);
1196c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1197c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong config",
1198c9ee780fSMichael Ellerman 			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
1199c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1200c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1201c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong pinned", evsel->attr.pinned);
1202c9ee780fSMichael Ellerman 
1203c9ee780fSMichael Ellerman 	/* cache-misses - can not be pinned, but will go on with the leader */
1204c9ee780fSMichael Ellerman 	evsel = perf_evsel__next(evsel);
1205c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1206c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong config",
1207c9ee780fSMichael Ellerman 			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
1208c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
1209c9ee780fSMichael Ellerman 
1210c9ee780fSMichael Ellerman 	/* branch-misses - ditto */
1211c9ee780fSMichael Ellerman 	evsel = perf_evsel__next(evsel);
1212c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong config",
1213c9ee780fSMichael Ellerman 			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1214c9ee780fSMichael Ellerman 	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
1215c9ee780fSMichael Ellerman 
1216c9ee780fSMichael Ellerman 	return 0;
1217c9ee780fSMichael Ellerman }
1218c9ee780fSMichael Ellerman 
1219ec32398cSJacob Shin static int test__checkevent_breakpoint_len(struct perf_evlist *evlist)
1220ec32398cSJacob Shin {
1221ec32398cSJacob Shin 	struct perf_evsel *evsel = perf_evlist__first(evlist);
1222ec32398cSJacob Shin 
1223ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
1224ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
1225ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
1226ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong bp_type", (HW_BREAKPOINT_R | HW_BREAKPOINT_W) ==
1227ec32398cSJacob Shin 					 evsel->attr.bp_type);
1228ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong bp_len", HW_BREAKPOINT_LEN_1 ==
1229ec32398cSJacob Shin 					evsel->attr.bp_len);
1230ec32398cSJacob Shin 
1231ec32398cSJacob Shin 	return 0;
1232ec32398cSJacob Shin }
1233ec32398cSJacob Shin 
1234ec32398cSJacob Shin static int test__checkevent_breakpoint_len_w(struct perf_evlist *evlist)
1235ec32398cSJacob Shin {
1236ec32398cSJacob Shin 	struct perf_evsel *evsel = perf_evlist__first(evlist);
1237ec32398cSJacob Shin 
1238ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
1239ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
1240ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
1241ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong bp_type", HW_BREAKPOINT_W ==
1242ec32398cSJacob Shin 					 evsel->attr.bp_type);
1243ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong bp_len", HW_BREAKPOINT_LEN_2 ==
1244ec32398cSJacob Shin 					evsel->attr.bp_len);
1245ec32398cSJacob Shin 
1246ec32398cSJacob Shin 	return 0;
1247ec32398cSJacob Shin }
1248ec32398cSJacob Shin 
1249ec32398cSJacob Shin static int
1250ec32398cSJacob Shin test__checkevent_breakpoint_len_rw_modifier(struct perf_evlist *evlist)
1251ec32398cSJacob Shin {
1252ec32398cSJacob Shin 	struct perf_evsel *evsel = perf_evlist__first(evlist);
1253ec32398cSJacob Shin 
1254ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1255ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1256ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1257ec32398cSJacob Shin 	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1258ec32398cSJacob Shin 
1259ec32398cSJacob Shin 	return test__checkevent_breakpoint_rw(evlist);
1260ec32398cSJacob Shin }
1261ec32398cSJacob Shin 
1262*ddd83c97SJiri Olsa static int test__checkevent_precise_max_modifier(struct perf_evlist *evlist)
1263*ddd83c97SJiri Olsa {
1264*ddd83c97SJiri Olsa 	struct perf_evsel *evsel = perf_evlist__first(evlist);
1265*ddd83c97SJiri Olsa 
1266*ddd83c97SJiri Olsa 	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
1267*ddd83c97SJiri Olsa 	TEST_ASSERT_VAL("wrong type", PERF_TYPE_SOFTWARE == evsel->attr.type);
1268*ddd83c97SJiri Olsa 	TEST_ASSERT_VAL("wrong config",
1269*ddd83c97SJiri Olsa 			PERF_COUNT_SW_TASK_CLOCK == evsel->attr.config);
1270*ddd83c97SJiri Olsa 	return 0;
1271*ddd83c97SJiri Olsa }
1272*ddd83c97SJiri Olsa 
127382ce75d9SJiri Olsa static int count_tracepoints(void)
127482ce75d9SJiri Olsa {
127582ce75d9SJiri Olsa 	struct dirent *events_ent;
127682ce75d9SJiri Olsa 	DIR *events_dir;
127782ce75d9SJiri Olsa 	int cnt = 0;
127882ce75d9SJiri Olsa 
1279fbf99625SJiri Olsa 	events_dir = opendir(tracing_events_path);
128082ce75d9SJiri Olsa 
128182ce75d9SJiri Olsa 	TEST_ASSERT_VAL("Can't open events dir", events_dir);
128282ce75d9SJiri Olsa 
128382ce75d9SJiri Olsa 	while ((events_ent = readdir(events_dir))) {
128482ce75d9SJiri Olsa 		char sys_path[PATH_MAX];
128582ce75d9SJiri Olsa 		struct dirent *sys_ent;
128682ce75d9SJiri Olsa 		DIR *sys_dir;
128782ce75d9SJiri Olsa 
128882ce75d9SJiri Olsa 		if (!strcmp(events_ent->d_name, ".")
128982ce75d9SJiri Olsa 		    || !strcmp(events_ent->d_name, "..")
129082ce75d9SJiri Olsa 		    || !strcmp(events_ent->d_name, "enable")
129182ce75d9SJiri Olsa 		    || !strcmp(events_ent->d_name, "header_event")
129282ce75d9SJiri Olsa 		    || !strcmp(events_ent->d_name, "header_page"))
129382ce75d9SJiri Olsa 			continue;
129482ce75d9SJiri Olsa 
129582ce75d9SJiri Olsa 		scnprintf(sys_path, PATH_MAX, "%s/%s",
1296fbf99625SJiri Olsa 			  tracing_events_path, events_ent->d_name);
129782ce75d9SJiri Olsa 
129882ce75d9SJiri Olsa 		sys_dir = opendir(sys_path);
129982ce75d9SJiri Olsa 		TEST_ASSERT_VAL("Can't open sys dir", sys_dir);
130082ce75d9SJiri Olsa 
130182ce75d9SJiri Olsa 		while ((sys_ent = readdir(sys_dir))) {
130282ce75d9SJiri Olsa 			if (!strcmp(sys_ent->d_name, ".")
130382ce75d9SJiri Olsa 			    || !strcmp(sys_ent->d_name, "..")
130482ce75d9SJiri Olsa 			    || !strcmp(sys_ent->d_name, "enable")
130582ce75d9SJiri Olsa 			    || !strcmp(sys_ent->d_name, "filter"))
130682ce75d9SJiri Olsa 				continue;
130782ce75d9SJiri Olsa 
130882ce75d9SJiri Olsa 			cnt++;
130982ce75d9SJiri Olsa 		}
131082ce75d9SJiri Olsa 
131182ce75d9SJiri Olsa 		closedir(sys_dir);
131282ce75d9SJiri Olsa 	}
131382ce75d9SJiri Olsa 
131482ce75d9SJiri Olsa 	closedir(events_dir);
131582ce75d9SJiri Olsa 	return cnt;
131682ce75d9SJiri Olsa }
131782ce75d9SJiri Olsa 
131882ce75d9SJiri Olsa static int test__all_tracepoints(struct perf_evlist *evlist)
131982ce75d9SJiri Olsa {
132082ce75d9SJiri Olsa 	TEST_ASSERT_VAL("wrong events count",
132182ce75d9SJiri Olsa 			count_tracepoints() == evlist->nr_entries);
132282ce75d9SJiri Olsa 
132382ce75d9SJiri Olsa 	return test__checkevent_tracepoint_multi(evlist);
132482ce75d9SJiri Olsa }
132582ce75d9SJiri Olsa 
132623b6339bSArnaldo Carvalho de Melo struct evlist_test {
1327945aea22SJiri Olsa 	const char *name;
1328945aea22SJiri Olsa 	__u32 type;
1329615b8f99SAlexander Yarygin 	const int id;
1330945aea22SJiri Olsa 	int (*check)(struct perf_evlist *evlist);
1331945aea22SJiri Olsa };
1332945aea22SJiri Olsa 
133323b6339bSArnaldo Carvalho de Melo static struct evlist_test test__events[] = {
1334615b8f99SAlexander Yarygin 	{
133543f322b4SRiku Voipio 		.name  = "syscalls:sys_enter_openat",
1336945aea22SJiri Olsa 		.check = test__checkevent_tracepoint,
1337615b8f99SAlexander Yarygin 		.id    = 0,
1338945aea22SJiri Olsa 	},
1339615b8f99SAlexander Yarygin 	{
1340945aea22SJiri Olsa 		.name  = "syscalls:*",
1341945aea22SJiri Olsa 		.check = test__checkevent_tracepoint_multi,
1342615b8f99SAlexander Yarygin 		.id    = 1,
1343945aea22SJiri Olsa 	},
1344615b8f99SAlexander Yarygin 	{
1345945aea22SJiri Olsa 		.name  = "r1a",
1346945aea22SJiri Olsa 		.check = test__checkevent_raw,
1347615b8f99SAlexander Yarygin 		.id    = 2,
1348945aea22SJiri Olsa 	},
1349615b8f99SAlexander Yarygin 	{
1350945aea22SJiri Olsa 		.name  = "1:1",
1351945aea22SJiri Olsa 		.check = test__checkevent_numeric,
1352615b8f99SAlexander Yarygin 		.id    = 3,
1353945aea22SJiri Olsa 	},
1354615b8f99SAlexander Yarygin 	{
1355945aea22SJiri Olsa 		.name  = "instructions",
1356945aea22SJiri Olsa 		.check = test__checkevent_symbolic_name,
1357615b8f99SAlexander Yarygin 		.id    = 4,
1358945aea22SJiri Olsa 	},
1359615b8f99SAlexander Yarygin 	{
1360945aea22SJiri Olsa 		.name  = "cycles/period=100000,config2/",
1361945aea22SJiri Olsa 		.check = test__checkevent_symbolic_name_config,
1362615b8f99SAlexander Yarygin 		.id    = 5,
1363945aea22SJiri Olsa 	},
1364615b8f99SAlexander Yarygin 	{
1365945aea22SJiri Olsa 		.name  = "faults",
1366945aea22SJiri Olsa 		.check = test__checkevent_symbolic_alias,
1367615b8f99SAlexander Yarygin 		.id    = 6,
1368945aea22SJiri Olsa 	},
1369615b8f99SAlexander Yarygin 	{
1370945aea22SJiri Olsa 		.name  = "L1-dcache-load-miss",
1371945aea22SJiri Olsa 		.check = test__checkevent_genhw,
1372615b8f99SAlexander Yarygin 		.id    = 7,
1373945aea22SJiri Olsa 	},
1374615b8f99SAlexander Yarygin 	{
1375945aea22SJiri Olsa 		.name  = "mem:0",
1376945aea22SJiri Olsa 		.check = test__checkevent_breakpoint,
1377615b8f99SAlexander Yarygin 		.id    = 8,
1378945aea22SJiri Olsa 	},
1379615b8f99SAlexander Yarygin 	{
1380945aea22SJiri Olsa 		.name  = "mem:0:x",
1381945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_x,
1382615b8f99SAlexander Yarygin 		.id    = 9,
1383945aea22SJiri Olsa 	},
1384615b8f99SAlexander Yarygin 	{
1385945aea22SJiri Olsa 		.name  = "mem:0:r",
1386945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_r,
1387615b8f99SAlexander Yarygin 		.id    = 10,
1388945aea22SJiri Olsa 	},
1389615b8f99SAlexander Yarygin 	{
1390945aea22SJiri Olsa 		.name  = "mem:0:w",
1391945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_w,
1392615b8f99SAlexander Yarygin 		.id    = 11,
1393945aea22SJiri Olsa 	},
1394615b8f99SAlexander Yarygin 	{
139543f322b4SRiku Voipio 		.name  = "syscalls:sys_enter_openat:k",
1396945aea22SJiri Olsa 		.check = test__checkevent_tracepoint_modifier,
1397615b8f99SAlexander Yarygin 		.id    = 12,
1398945aea22SJiri Olsa 	},
1399615b8f99SAlexander Yarygin 	{
1400945aea22SJiri Olsa 		.name  = "syscalls:*:u",
1401945aea22SJiri Olsa 		.check = test__checkevent_tracepoint_multi_modifier,
1402615b8f99SAlexander Yarygin 		.id    = 13,
1403945aea22SJiri Olsa 	},
1404615b8f99SAlexander Yarygin 	{
1405945aea22SJiri Olsa 		.name  = "r1a:kp",
1406945aea22SJiri Olsa 		.check = test__checkevent_raw_modifier,
1407615b8f99SAlexander Yarygin 		.id    = 14,
1408945aea22SJiri Olsa 	},
1409615b8f99SAlexander Yarygin 	{
1410945aea22SJiri Olsa 		.name  = "1:1:hp",
1411945aea22SJiri Olsa 		.check = test__checkevent_numeric_modifier,
1412615b8f99SAlexander Yarygin 		.id    = 15,
1413945aea22SJiri Olsa 	},
1414615b8f99SAlexander Yarygin 	{
1415945aea22SJiri Olsa 		.name  = "instructions:h",
1416945aea22SJiri Olsa 		.check = test__checkevent_symbolic_name_modifier,
1417615b8f99SAlexander Yarygin 		.id    = 16,
1418945aea22SJiri Olsa 	},
1419615b8f99SAlexander Yarygin 	{
1420945aea22SJiri Olsa 		.name  = "faults:u",
1421945aea22SJiri Olsa 		.check = test__checkevent_symbolic_alias_modifier,
1422615b8f99SAlexander Yarygin 		.id    = 17,
1423945aea22SJiri Olsa 	},
1424615b8f99SAlexander Yarygin 	{
1425945aea22SJiri Olsa 		.name  = "L1-dcache-load-miss:kp",
1426945aea22SJiri Olsa 		.check = test__checkevent_genhw_modifier,
1427615b8f99SAlexander Yarygin 		.id    = 18,
1428945aea22SJiri Olsa 	},
1429615b8f99SAlexander Yarygin 	{
1430945aea22SJiri Olsa 		.name  = "mem:0:u",
1431945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_modifier,
1432615b8f99SAlexander Yarygin 		.id    = 19,
1433945aea22SJiri Olsa 	},
1434615b8f99SAlexander Yarygin 	{
1435945aea22SJiri Olsa 		.name  = "mem:0:x:k",
1436945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_x_modifier,
1437615b8f99SAlexander Yarygin 		.id    = 20,
1438945aea22SJiri Olsa 	},
1439615b8f99SAlexander Yarygin 	{
1440945aea22SJiri Olsa 		.name  = "mem:0:r:hp",
1441945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_r_modifier,
1442615b8f99SAlexander Yarygin 		.id    = 21,
1443945aea22SJiri Olsa 	},
1444615b8f99SAlexander Yarygin 	{
1445945aea22SJiri Olsa 		.name  = "mem:0:w:up",
1446945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_w_modifier,
1447615b8f99SAlexander Yarygin 		.id    = 22,
1448945aea22SJiri Olsa 	},
1449615b8f99SAlexander Yarygin 	{
145043f322b4SRiku Voipio 		.name  = "r1,syscalls:sys_enter_openat:k,1:1:hp",
1451945aea22SJiri Olsa 		.check = test__checkevent_list,
1452615b8f99SAlexander Yarygin 		.id    = 23,
1453945aea22SJiri Olsa 	},
1454615b8f99SAlexander Yarygin 	{
1455945aea22SJiri Olsa 		.name  = "instructions:G",
1456945aea22SJiri Olsa 		.check = test__checkevent_exclude_host_modifier,
1457615b8f99SAlexander Yarygin 		.id    = 24,
1458945aea22SJiri Olsa 	},
1459615b8f99SAlexander Yarygin 	{
1460945aea22SJiri Olsa 		.name  = "instructions:H",
1461945aea22SJiri Olsa 		.check = test__checkevent_exclude_guest_modifier,
1462615b8f99SAlexander Yarygin 		.id    = 25,
1463945aea22SJiri Olsa 	},
1464615b8f99SAlexander Yarygin 	{
1465945aea22SJiri Olsa 		.name  = "mem:0:rw",
1466945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_rw,
1467615b8f99SAlexander Yarygin 		.id    = 26,
1468945aea22SJiri Olsa 	},
1469615b8f99SAlexander Yarygin 	{
1470945aea22SJiri Olsa 		.name  = "mem:0:rw:kp",
1471945aea22SJiri Olsa 		.check = test__checkevent_breakpoint_rw_modifier,
1472615b8f99SAlexander Yarygin 		.id    = 27,
1473945aea22SJiri Olsa 	},
1474615b8f99SAlexander Yarygin 	{
1475945aea22SJiri Olsa 		.name  = "{instructions:k,cycles:upp}",
1476945aea22SJiri Olsa 		.check = test__group1,
1477615b8f99SAlexander Yarygin 		.id    = 28,
1478945aea22SJiri Olsa 	},
1479615b8f99SAlexander Yarygin 	{
1480945aea22SJiri Olsa 		.name  = "{faults:k,cache-references}:u,cycles:k",
1481945aea22SJiri Olsa 		.check = test__group2,
1482615b8f99SAlexander Yarygin 		.id    = 29,
1483945aea22SJiri Olsa 	},
1484615b8f99SAlexander Yarygin 	{
148543f322b4SRiku Voipio 		.name  = "group1{syscalls:sys_enter_openat:H,cycles:kppp},group2{cycles,1:3}:G,instructions:u",
1486945aea22SJiri Olsa 		.check = test__group3,
1487615b8f99SAlexander Yarygin 		.id    = 30,
1488945aea22SJiri Olsa 	},
1489615b8f99SAlexander Yarygin 	{
1490945aea22SJiri Olsa 		.name  = "{cycles:u,instructions:kp}:p",
1491945aea22SJiri Olsa 		.check = test__group4,
1492615b8f99SAlexander Yarygin 		.id    = 31,
1493945aea22SJiri Olsa 	},
1494615b8f99SAlexander Yarygin 	{
1495945aea22SJiri Olsa 		.name  = "{cycles,instructions}:G,{cycles:G,instructions:G},cycles",
1496945aea22SJiri Olsa 		.check = test__group5,
1497615b8f99SAlexander Yarygin 		.id    = 32,
1498945aea22SJiri Olsa 	},
1499615b8f99SAlexander Yarygin 	{
150082ce75d9SJiri Olsa 		.name  = "*:*",
150182ce75d9SJiri Olsa 		.check = test__all_tracepoints,
1502615b8f99SAlexander Yarygin 		.id    = 33,
150382ce75d9SJiri Olsa 	},
1504615b8f99SAlexander Yarygin 	{
15055a30a99fSJiri Olsa 		.name  = "{cycles,cache-misses:G}:H",
15065a30a99fSJiri Olsa 		.check = test__group_gh1,
1507615b8f99SAlexander Yarygin 		.id    = 34,
15085a30a99fSJiri Olsa 	},
1509615b8f99SAlexander Yarygin 	{
15105a30a99fSJiri Olsa 		.name  = "{cycles,cache-misses:H}:G",
15115a30a99fSJiri Olsa 		.check = test__group_gh2,
1512615b8f99SAlexander Yarygin 		.id    = 35,
15135a30a99fSJiri Olsa 	},
1514615b8f99SAlexander Yarygin 	{
15155a30a99fSJiri Olsa 		.name  = "{cycles:G,cache-misses:H}:u",
15165a30a99fSJiri Olsa 		.check = test__group_gh3,
1517615b8f99SAlexander Yarygin 		.id    = 36,
15185a30a99fSJiri Olsa 	},
1519615b8f99SAlexander Yarygin 	{
15205a30a99fSJiri Olsa 		.name  = "{cycles:G,cache-misses:H}:uG",
15215a30a99fSJiri Olsa 		.check = test__group_gh4,
1522615b8f99SAlexander Yarygin 		.id    = 37,
15235a30a99fSJiri Olsa 	},
1524615b8f99SAlexander Yarygin 	{
1525a9f93f97SJiri Olsa 		.name  = "{cycles,cache-misses,branch-misses}:S",
1526a9f93f97SJiri Olsa 		.check = test__leader_sample1,
1527615b8f99SAlexander Yarygin 		.id    = 38,
1528a9f93f97SJiri Olsa 	},
1529615b8f99SAlexander Yarygin 	{
1530a9f93f97SJiri Olsa 		.name  = "{instructions,branch-misses}:Su",
1531a9f93f97SJiri Olsa 		.check = test__leader_sample2,
1532615b8f99SAlexander Yarygin 		.id    = 39,
1533a9f93f97SJiri Olsa 	},
1534615b8f99SAlexander Yarygin 	{
1535c9ee780fSMichael Ellerman 		.name  = "instructions:uDp",
1536c9ee780fSMichael Ellerman 		.check = test__checkevent_pinned_modifier,
1537615b8f99SAlexander Yarygin 		.id    = 40,
1538c9ee780fSMichael Ellerman 	},
1539615b8f99SAlexander Yarygin 	{
1540c9ee780fSMichael Ellerman 		.name  = "{cycles,cache-misses,branch-misses}:D",
1541c9ee780fSMichael Ellerman 		.check = test__pinned_group,
1542615b8f99SAlexander Yarygin 		.id    = 41,
1543c9ee780fSMichael Ellerman 	},
1544ec32398cSJacob Shin 	{
1545ec32398cSJacob Shin 		.name  = "mem:0/1",
1546ec32398cSJacob Shin 		.check = test__checkevent_breakpoint_len,
1547ec32398cSJacob Shin 		.id    = 42,
1548ec32398cSJacob Shin 	},
1549ec32398cSJacob Shin 	{
1550ec32398cSJacob Shin 		.name  = "mem:0/2:w",
1551ec32398cSJacob Shin 		.check = test__checkevent_breakpoint_len_w,
1552ec32398cSJacob Shin 		.id    = 43,
1553ec32398cSJacob Shin 	},
1554ec32398cSJacob Shin 	{
1555ec32398cSJacob Shin 		.name  = "mem:0/4:rw:u",
1556ec32398cSJacob Shin 		.check = test__checkevent_breakpoint_len_rw_modifier,
1557ec32398cSJacob Shin 		.id    = 44
1558ec32398cSJacob Shin 	},
1559c0bc8c6dSAlexander Yarygin #if defined(__s390x__)
1560c0bc8c6dSAlexander Yarygin 	{
1561c0bc8c6dSAlexander Yarygin 		.name  = "kvm-s390:kvm_s390_create_vm",
1562c0bc8c6dSAlexander Yarygin 		.check = test__checkevent_tracepoint,
1563c0bc8c6dSAlexander Yarygin 		.id    = 100,
1564c0bc8c6dSAlexander Yarygin 	},
1565c0bc8c6dSAlexander Yarygin #endif
1566a1e12da4SJiri Olsa 	{
1567a1e12da4SJiri Olsa 		.name  = "instructions:I",
1568a1e12da4SJiri Olsa 		.check = test__checkevent_exclude_idle_modifier,
1569a1e12da4SJiri Olsa 		.id    = 45,
1570a1e12da4SJiri Olsa 	},
1571a1e12da4SJiri Olsa 	{
1572a1e12da4SJiri Olsa 		.name  = "instructions:kIG",
1573a1e12da4SJiri Olsa 		.check = test__checkevent_exclude_idle_modifier_1,
1574a1e12da4SJiri Olsa 		.id    = 46,
1575a1e12da4SJiri Olsa 	},
1576*ddd83c97SJiri Olsa 	{
1577*ddd83c97SJiri Olsa 		.name  = "task-clock:P,cycles",
1578*ddd83c97SJiri Olsa 		.check = test__checkevent_precise_max_modifier,
1579*ddd83c97SJiri Olsa 		.id    = 47,
1580*ddd83c97SJiri Olsa 	},
1581945aea22SJiri Olsa };
1582945aea22SJiri Olsa 
158323b6339bSArnaldo Carvalho de Melo static struct evlist_test test__events_pmu[] = {
1584615b8f99SAlexander Yarygin 	{
1585945aea22SJiri Olsa 		.name  = "cpu/config=10,config1,config2=3,period=1000/u",
1586945aea22SJiri Olsa 		.check = test__checkevent_pmu,
1587615b8f99SAlexander Yarygin 		.id    = 0,
1588945aea22SJiri Olsa 	},
1589615b8f99SAlexander Yarygin 	{
1590945aea22SJiri Olsa 		.name  = "cpu/config=1,name=krava/u,cpu/config=2/u",
1591945aea22SJiri Olsa 		.check = test__checkevent_pmu_name,
1592615b8f99SAlexander Yarygin 		.id    = 1,
1593945aea22SJiri Olsa 	},
159471ef150eSKan Liang 	{
159571ef150eSKan Liang 		.name  = "cpu/config=1,call-graph=fp,time,period=100000/,cpu/config=2,call-graph=no,time=0,period=2000/",
159671ef150eSKan Liang 		.check = test__checkevent_pmu_partial_time_callgraph,
159771ef150eSKan Liang 		.id    = 2,
159871ef150eSKan Liang 	},
1599945aea22SJiri Olsa };
1600945aea22SJiri Olsa 
160123b6339bSArnaldo Carvalho de Melo struct terms_test {
1602945aea22SJiri Olsa 	const char *str;
1603945aea22SJiri Olsa 	__u32 type;
1604945aea22SJiri Olsa 	int (*check)(struct list_head *terms);
1605945aea22SJiri Olsa };
1606945aea22SJiri Olsa 
160723b6339bSArnaldo Carvalho de Melo static struct terms_test test__terms[] = {
1608945aea22SJiri Olsa 	[0] = {
1609945aea22SJiri Olsa 		.str   = "config=10,config1,config2=3,umask=1",
1610945aea22SJiri Olsa 		.check = test__checkterms_simple,
1611945aea22SJiri Olsa 	},
1612945aea22SJiri Olsa };
1613945aea22SJiri Olsa 
161423b6339bSArnaldo Carvalho de Melo static int test_event(struct evlist_test *e)
1615945aea22SJiri Olsa {
1616945aea22SJiri Olsa 	struct perf_evlist *evlist;
1617945aea22SJiri Olsa 	int ret;
1618945aea22SJiri Olsa 
1619334fe7a3SNamhyung Kim 	evlist = perf_evlist__new();
1620945aea22SJiri Olsa 	if (evlist == NULL)
1621945aea22SJiri Olsa 		return -ENOMEM;
1622945aea22SJiri Olsa 
1623b39b8393SJiri Olsa 	ret = parse_events(evlist, e->name, NULL);
1624945aea22SJiri Olsa 	if (ret) {
1625945aea22SJiri Olsa 		pr_debug("failed to parse event '%s', err %d\n",
1626945aea22SJiri Olsa 			 e->name, ret);
16272d4352c0SArnaldo Carvalho de Melo 	} else {
16282d4352c0SArnaldo Carvalho de Melo 		ret = e->check(evlist);
1629945aea22SJiri Olsa 	}
1630945aea22SJiri Olsa 
1631945aea22SJiri Olsa 	perf_evlist__delete(evlist);
1632945aea22SJiri Olsa 
1633945aea22SJiri Olsa 	return ret;
1634945aea22SJiri Olsa }
1635945aea22SJiri Olsa 
163623b6339bSArnaldo Carvalho de Melo static int test_events(struct evlist_test *events, unsigned cnt)
1637945aea22SJiri Olsa {
1638945aea22SJiri Olsa 	int ret1, ret2 = 0;
1639945aea22SJiri Olsa 	unsigned i;
1640945aea22SJiri Olsa 
1641945aea22SJiri Olsa 	for (i = 0; i < cnt; i++) {
164223b6339bSArnaldo Carvalho de Melo 		struct evlist_test *e = &events[i];
1643945aea22SJiri Olsa 
1644615b8f99SAlexander Yarygin 		pr_debug("running test %d '%s'\n", e->id, e->name);
1645945aea22SJiri Olsa 		ret1 = test_event(e);
1646945aea22SJiri Olsa 		if (ret1)
1647945aea22SJiri Olsa 			ret2 = ret1;
1648945aea22SJiri Olsa 	}
1649945aea22SJiri Olsa 
1650945aea22SJiri Olsa 	return ret2;
1651945aea22SJiri Olsa }
1652945aea22SJiri Olsa 
165323b6339bSArnaldo Carvalho de Melo static int test_term(struct terms_test *t)
1654945aea22SJiri Olsa {
1655c549aca5SDavid Ahern 	struct list_head terms;
1656945aea22SJiri Olsa 	int ret;
1657945aea22SJiri Olsa 
1658c549aca5SDavid Ahern 	INIT_LIST_HEAD(&terms);
1659945aea22SJiri Olsa 
1660c549aca5SDavid Ahern 	ret = parse_events_terms(&terms, t->str);
1661945aea22SJiri Olsa 	if (ret) {
1662945aea22SJiri Olsa 		pr_debug("failed to parse terms '%s', err %d\n",
1663945aea22SJiri Olsa 			 t->str , ret);
1664945aea22SJiri Olsa 		return ret;
1665945aea22SJiri Olsa 	}
1666945aea22SJiri Olsa 
1667c549aca5SDavid Ahern 	ret = t->check(&terms);
1668c549aca5SDavid Ahern 	parse_events__free_terms(&terms);
1669945aea22SJiri Olsa 
1670945aea22SJiri Olsa 	return ret;
1671945aea22SJiri Olsa }
1672945aea22SJiri Olsa 
167323b6339bSArnaldo Carvalho de Melo static int test_terms(struct terms_test *terms, unsigned cnt)
1674945aea22SJiri Olsa {
1675945aea22SJiri Olsa 	int ret = 0;
1676945aea22SJiri Olsa 	unsigned i;
1677945aea22SJiri Olsa 
1678945aea22SJiri Olsa 	for (i = 0; i < cnt; i++) {
167923b6339bSArnaldo Carvalho de Melo 		struct terms_test *t = &terms[i];
1680945aea22SJiri Olsa 
1681945aea22SJiri Olsa 		pr_debug("running test %d '%s'\n", i, t->str);
1682945aea22SJiri Olsa 		ret = test_term(t);
1683945aea22SJiri Olsa 		if (ret)
1684945aea22SJiri Olsa 			break;
1685945aea22SJiri Olsa 	}
1686945aea22SJiri Olsa 
1687945aea22SJiri Olsa 	return ret;
1688945aea22SJiri Olsa }
1689945aea22SJiri Olsa 
1690945aea22SJiri Olsa static int test_pmu(void)
1691945aea22SJiri Olsa {
1692945aea22SJiri Olsa 	struct stat st;
1693945aea22SJiri Olsa 	char path[PATH_MAX];
1694945aea22SJiri Olsa 	int ret;
1695945aea22SJiri Olsa 
1696945aea22SJiri Olsa 	snprintf(path, PATH_MAX, "%s/bus/event_source/devices/cpu/format/",
1697cf38fadaSArnaldo Carvalho de Melo 		 sysfs__mountpoint());
1698945aea22SJiri Olsa 
1699945aea22SJiri Olsa 	ret = stat(path, &st);
1700945aea22SJiri Olsa 	if (ret)
1701945aea22SJiri Olsa 		pr_debug("omitting PMU cpu tests\n");
1702945aea22SJiri Olsa 	return !ret;
1703945aea22SJiri Olsa }
1704945aea22SJiri Olsa 
1705945aea22SJiri Olsa static int test_pmu_events(void)
1706945aea22SJiri Olsa {
1707945aea22SJiri Olsa 	struct stat st;
1708945aea22SJiri Olsa 	char path[PATH_MAX];
1709945aea22SJiri Olsa 	struct dirent *ent;
1710945aea22SJiri Olsa 	DIR *dir;
1711945aea22SJiri Olsa 	int ret;
1712945aea22SJiri Olsa 
1713945aea22SJiri Olsa 	snprintf(path, PATH_MAX, "%s/bus/event_source/devices/cpu/events/",
1714cf38fadaSArnaldo Carvalho de Melo 		 sysfs__mountpoint());
1715945aea22SJiri Olsa 
1716945aea22SJiri Olsa 	ret = stat(path, &st);
1717945aea22SJiri Olsa 	if (ret) {
1718a895d57dSMasanari Iida 		pr_debug("omitting PMU cpu events tests\n");
1719945aea22SJiri Olsa 		return 0;
1720945aea22SJiri Olsa 	}
1721945aea22SJiri Olsa 
1722945aea22SJiri Olsa 	dir = opendir(path);
1723945aea22SJiri Olsa 	if (!dir) {
1724945aea22SJiri Olsa 		pr_debug("can't open pmu event dir");
1725945aea22SJiri Olsa 		return -1;
1726945aea22SJiri Olsa 	}
1727945aea22SJiri Olsa 
1728945aea22SJiri Olsa 	while (!ret && (ent = readdir(dir))) {
1729945aea22SJiri Olsa #define MAX_NAME 100
173023b6339bSArnaldo Carvalho de Melo 		struct evlist_test e;
1731945aea22SJiri Olsa 		char name[MAX_NAME];
1732945aea22SJiri Olsa 
1733945aea22SJiri Olsa 		if (!strcmp(ent->d_name, ".") ||
1734945aea22SJiri Olsa 		    !strcmp(ent->d_name, ".."))
1735945aea22SJiri Olsa 			continue;
1736945aea22SJiri Olsa 
1737945aea22SJiri Olsa 		snprintf(name, MAX_NAME, "cpu/event=%s/u", ent->d_name);
1738945aea22SJiri Olsa 
1739945aea22SJiri Olsa 		e.name  = name;
1740945aea22SJiri Olsa 		e.check = test__checkevent_pmu_events;
1741945aea22SJiri Olsa 
1742945aea22SJiri Olsa 		ret = test_event(&e);
1743ffe59788SKan Liang 		if (ret)
1744ffe59788SKan Liang 			break;
1745ffe59788SKan Liang 		snprintf(name, MAX_NAME, "%s:u,cpu/event=%s/u", ent->d_name, ent->d_name);
1746ffe59788SKan Liang 		e.name  = name;
1747ffe59788SKan Liang 		e.check = test__checkevent_pmu_events_mix;
1748ffe59788SKan Liang 		ret = test_event(&e);
1749945aea22SJiri Olsa #undef MAX_NAME
1750945aea22SJiri Olsa 	}
1751945aea22SJiri Olsa 
1752945aea22SJiri Olsa 	closedir(dir);
1753945aea22SJiri Olsa 	return ret;
1754945aea22SJiri Olsa }
1755945aea22SJiri Olsa 
1756c81251e8SJiri Olsa int test__parse_events(void)
1757945aea22SJiri Olsa {
1758945aea22SJiri Olsa 	int ret1, ret2 = 0;
1759945aea22SJiri Olsa 
1760945aea22SJiri Olsa #define TEST_EVENTS(tests)				\
1761945aea22SJiri Olsa do {							\
1762945aea22SJiri Olsa 	ret1 = test_events(tests, ARRAY_SIZE(tests));	\
1763945aea22SJiri Olsa 	if (!ret2)					\
1764945aea22SJiri Olsa 		ret2 = ret1;				\
1765945aea22SJiri Olsa } while (0)
1766945aea22SJiri Olsa 
1767945aea22SJiri Olsa 	TEST_EVENTS(test__events);
1768945aea22SJiri Olsa 
1769945aea22SJiri Olsa 	if (test_pmu())
1770945aea22SJiri Olsa 		TEST_EVENTS(test__events_pmu);
1771945aea22SJiri Olsa 
1772945aea22SJiri Olsa 	if (test_pmu()) {
1773945aea22SJiri Olsa 		int ret = test_pmu_events();
1774945aea22SJiri Olsa 		if (ret)
1775945aea22SJiri Olsa 			return ret;
1776945aea22SJiri Olsa 	}
1777945aea22SJiri Olsa 
1778945aea22SJiri Olsa 	ret1 = test_terms(test__terms, ARRAY_SIZE(test__terms));
1779945aea22SJiri Olsa 	if (!ret2)
1780945aea22SJiri Olsa 		ret2 = ret1;
1781945aea22SJiri Olsa 
1782945aea22SJiri Olsa 	return ret2;
1783945aea22SJiri Olsa }
1784