Linux Audio

Check our new training course

Loading...
v4.6
   1
   2#include "parse-events.h"
   3#include "evsel.h"
   4#include "evlist.h"
   5#include <api/fs/fs.h>
 
   6#include "tests.h"
   7#include "debug.h"
   8#include "util.h"
   9#include <linux/hw_breakpoint.h>
  10#include <api/fs/fs.h>
  11
  12#define PERF_TP_SAMPLE_TYPE (PERF_SAMPLE_RAW | PERF_SAMPLE_TIME | \
  13			     PERF_SAMPLE_CPU | PERF_SAMPLE_PERIOD)
  14
  15static int test__checkevent_tracepoint(struct perf_evlist *evlist)
  16{
  17	struct perf_evsel *evsel = perf_evlist__first(evlist);
  18
  19	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  20	TEST_ASSERT_VAL("wrong number of groups", 0 == evlist->nr_groups);
  21	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
  22	TEST_ASSERT_VAL("wrong sample_type",
  23		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
  24	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
  25	return 0;
  26}
  27
  28static int test__checkevent_tracepoint_multi(struct perf_evlist *evlist)
  29{
  30	struct perf_evsel *evsel;
  31
  32	TEST_ASSERT_VAL("wrong number of entries", evlist->nr_entries > 1);
  33	TEST_ASSERT_VAL("wrong number of groups", 0 == evlist->nr_groups);
  34
  35	evlist__for_each(evlist, evsel) {
  36		TEST_ASSERT_VAL("wrong type",
  37			PERF_TYPE_TRACEPOINT == evsel->attr.type);
  38		TEST_ASSERT_VAL("wrong sample_type",
  39			PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
  40		TEST_ASSERT_VAL("wrong sample_period",
  41			1 == evsel->attr.sample_period);
  42	}
  43	return 0;
  44}
  45
  46static int test__checkevent_raw(struct perf_evlist *evlist)
  47{
  48	struct perf_evsel *evsel = perf_evlist__first(evlist);
  49
  50	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  51	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
  52	TEST_ASSERT_VAL("wrong config", 0x1a == evsel->attr.config);
  53	return 0;
  54}
  55
  56static int test__checkevent_numeric(struct perf_evlist *evlist)
  57{
  58	struct perf_evsel *evsel = perf_evlist__first(evlist);
  59
  60	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  61	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
  62	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
  63	return 0;
  64}
  65
  66static int test__checkevent_symbolic_name(struct perf_evlist *evlist)
  67{
  68	struct perf_evsel *evsel = perf_evlist__first(evlist);
  69
  70	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  71	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
  72	TEST_ASSERT_VAL("wrong config",
  73			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
  74	return 0;
  75}
  76
  77static int test__checkevent_symbolic_name_config(struct perf_evlist *evlist)
  78{
  79	struct perf_evsel *evsel = perf_evlist__first(evlist);
  80
  81	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  82	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
  83	TEST_ASSERT_VAL("wrong config",
  84			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
  85	/*
  86	 * The period value gets configured within perf_evlist__config,
  87	 * while this test executes only parse events method.
  88	 */
  89	TEST_ASSERT_VAL("wrong period",
  90			0 == evsel->attr.sample_period);
  91	TEST_ASSERT_VAL("wrong config1",
  92			0 == evsel->attr.config1);
  93	TEST_ASSERT_VAL("wrong config2",
  94			1 == evsel->attr.config2);
  95	return 0;
  96}
  97
  98static int test__checkevent_symbolic_alias(struct perf_evlist *evlist)
  99{
 100	struct perf_evsel *evsel = perf_evlist__first(evlist);
 101
 102	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 103	TEST_ASSERT_VAL("wrong type", PERF_TYPE_SOFTWARE == evsel->attr.type);
 104	TEST_ASSERT_VAL("wrong config",
 105			PERF_COUNT_SW_PAGE_FAULTS == evsel->attr.config);
 106	return 0;
 107}
 108
 109static int test__checkevent_genhw(struct perf_evlist *evlist)
 110{
 111	struct perf_evsel *evsel = perf_evlist__first(evlist);
 112
 113	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 114	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HW_CACHE == evsel->attr.type);
 115	TEST_ASSERT_VAL("wrong config", (1 << 16) == evsel->attr.config);
 116	return 0;
 117}
 118
 119static int test__checkevent_breakpoint(struct perf_evlist *evlist)
 120{
 121	struct perf_evsel *evsel = perf_evlist__first(evlist);
 122
 123	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 124	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
 125	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 126	TEST_ASSERT_VAL("wrong bp_type", (HW_BREAKPOINT_R | HW_BREAKPOINT_W) ==
 127					 evsel->attr.bp_type);
 128	TEST_ASSERT_VAL("wrong bp_len", HW_BREAKPOINT_LEN_4 ==
 129					evsel->attr.bp_len);
 130	return 0;
 131}
 132
 133static int test__checkevent_breakpoint_x(struct perf_evlist *evlist)
 134{
 135	struct perf_evsel *evsel = perf_evlist__first(evlist);
 136
 137	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 138	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
 139	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 140	TEST_ASSERT_VAL("wrong bp_type",
 141			HW_BREAKPOINT_X == evsel->attr.bp_type);
 142	TEST_ASSERT_VAL("wrong bp_len", sizeof(long) == evsel->attr.bp_len);
 143	return 0;
 144}
 145
 146static int test__checkevent_breakpoint_r(struct perf_evlist *evlist)
 147{
 148	struct perf_evsel *evsel = perf_evlist__first(evlist);
 149
 150	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 151	TEST_ASSERT_VAL("wrong type",
 152			PERF_TYPE_BREAKPOINT == evsel->attr.type);
 153	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 154	TEST_ASSERT_VAL("wrong bp_type",
 155			HW_BREAKPOINT_R == evsel->attr.bp_type);
 156	TEST_ASSERT_VAL("wrong bp_len",
 157			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
 158	return 0;
 159}
 160
 161static int test__checkevent_breakpoint_w(struct perf_evlist *evlist)
 162{
 163	struct perf_evsel *evsel = perf_evlist__first(evlist);
 164
 165	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 166	TEST_ASSERT_VAL("wrong type",
 167			PERF_TYPE_BREAKPOINT == evsel->attr.type);
 168	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 169	TEST_ASSERT_VAL("wrong bp_type",
 170			HW_BREAKPOINT_W == evsel->attr.bp_type);
 171	TEST_ASSERT_VAL("wrong bp_len",
 172			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
 173	return 0;
 174}
 175
 176static int test__checkevent_breakpoint_rw(struct perf_evlist *evlist)
 177{
 178	struct perf_evsel *evsel = perf_evlist__first(evlist);
 179
 180	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 181	TEST_ASSERT_VAL("wrong type",
 182			PERF_TYPE_BREAKPOINT == evsel->attr.type);
 183	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 184	TEST_ASSERT_VAL("wrong bp_type",
 185		(HW_BREAKPOINT_R|HW_BREAKPOINT_W) == evsel->attr.bp_type);
 186	TEST_ASSERT_VAL("wrong bp_len",
 187			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
 188	return 0;
 189}
 190
 191static int test__checkevent_tracepoint_modifier(struct perf_evlist *evlist)
 192{
 193	struct perf_evsel *evsel = perf_evlist__first(evlist);
 194
 195	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 196	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 197	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 198	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 199
 200	return test__checkevent_tracepoint(evlist);
 201}
 202
 203static int
 204test__checkevent_tracepoint_multi_modifier(struct perf_evlist *evlist)
 205{
 206	struct perf_evsel *evsel;
 207
 208	TEST_ASSERT_VAL("wrong number of entries", evlist->nr_entries > 1);
 209
 210	evlist__for_each(evlist, evsel) {
 211		TEST_ASSERT_VAL("wrong exclude_user",
 212				!evsel->attr.exclude_user);
 213		TEST_ASSERT_VAL("wrong exclude_kernel",
 214				evsel->attr.exclude_kernel);
 215		TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 216		TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 217	}
 218
 219	return test__checkevent_tracepoint_multi(evlist);
 220}
 221
 222static int test__checkevent_raw_modifier(struct perf_evlist *evlist)
 223{
 224	struct perf_evsel *evsel = perf_evlist__first(evlist);
 225
 226	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 227	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 228	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 229	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 230
 231	return test__checkevent_raw(evlist);
 232}
 233
 234static int test__checkevent_numeric_modifier(struct perf_evlist *evlist)
 235{
 236	struct perf_evsel *evsel = perf_evlist__first(evlist);
 237
 238	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 239	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 240	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 241	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 242
 243	return test__checkevent_numeric(evlist);
 244}
 245
 246static int test__checkevent_symbolic_name_modifier(struct perf_evlist *evlist)
 247{
 248	struct perf_evsel *evsel = perf_evlist__first(evlist);
 249
 250	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 251	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 252	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 253	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 254
 255	return test__checkevent_symbolic_name(evlist);
 256}
 257
 258static int test__checkevent_exclude_host_modifier(struct perf_evlist *evlist)
 259{
 260	struct perf_evsel *evsel = perf_evlist__first(evlist);
 261
 262	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 263	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 264
 265	return test__checkevent_symbolic_name(evlist);
 266}
 267
 268static int test__checkevent_exclude_guest_modifier(struct perf_evlist *evlist)
 269{
 270	struct perf_evsel *evsel = perf_evlist__first(evlist);
 271
 272	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 273	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 274
 275	return test__checkevent_symbolic_name(evlist);
 276}
 277
 278static int test__checkevent_symbolic_alias_modifier(struct perf_evlist *evlist)
 279{
 280	struct perf_evsel *evsel = perf_evlist__first(evlist);
 281
 282	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 283	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 284	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 285	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 286
 287	return test__checkevent_symbolic_alias(evlist);
 288}
 289
 290static int test__checkevent_genhw_modifier(struct perf_evlist *evlist)
 291{
 292	struct perf_evsel *evsel = perf_evlist__first(evlist);
 293
 294	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 295	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 296	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 297	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 298
 299	return test__checkevent_genhw(evlist);
 300}
 301
 302static int test__checkevent_exclude_idle_modifier(struct perf_evlist *evlist)
 303{
 304	struct perf_evsel *evsel = perf_evlist__first(evlist);
 305
 306	TEST_ASSERT_VAL("wrong exclude idle", evsel->attr.exclude_idle);
 307	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 308	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 309	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 310	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 311	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 312	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 313
 314	return test__checkevent_symbolic_name(evlist);
 315}
 316
 317static int test__checkevent_exclude_idle_modifier_1(struct perf_evlist *evlist)
 318{
 319	struct perf_evsel *evsel = perf_evlist__first(evlist);
 320
 321	TEST_ASSERT_VAL("wrong exclude idle", evsel->attr.exclude_idle);
 322	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 323	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 324	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 325	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 326	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 327	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 328
 329	return test__checkevent_symbolic_name(evlist);
 330}
 331
 332static int test__checkevent_breakpoint_modifier(struct perf_evlist *evlist)
 333{
 334	struct perf_evsel *evsel = perf_evlist__first(evlist);
 335
 336
 337	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 338	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 339	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 340	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 341	TEST_ASSERT_VAL("wrong name",
 342			!strcmp(perf_evsel__name(evsel), "mem:0:u"));
 343
 344	return test__checkevent_breakpoint(evlist);
 345}
 346
 347static int test__checkevent_breakpoint_x_modifier(struct perf_evlist *evlist)
 348{
 349	struct perf_evsel *evsel = perf_evlist__first(evlist);
 350
 351	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 352	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 353	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 354	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 355	TEST_ASSERT_VAL("wrong name",
 356			!strcmp(perf_evsel__name(evsel), "mem:0:x:k"));
 357
 358	return test__checkevent_breakpoint_x(evlist);
 359}
 360
 361static int test__checkevent_breakpoint_r_modifier(struct perf_evlist *evlist)
 362{
 363	struct perf_evsel *evsel = perf_evlist__first(evlist);
 364
 365	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 366	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 367	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 368	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 369	TEST_ASSERT_VAL("wrong name",
 370			!strcmp(perf_evsel__name(evsel), "mem:0:r:hp"));
 371
 372	return test__checkevent_breakpoint_r(evlist);
 373}
 374
 375static int test__checkevent_breakpoint_w_modifier(struct perf_evlist *evlist)
 376{
 377	struct perf_evsel *evsel = perf_evlist__first(evlist);
 378
 379	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 380	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 381	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 382	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 383	TEST_ASSERT_VAL("wrong name",
 384			!strcmp(perf_evsel__name(evsel), "mem:0:w:up"));
 385
 386	return test__checkevent_breakpoint_w(evlist);
 387}
 388
 389static int test__checkevent_breakpoint_rw_modifier(struct perf_evlist *evlist)
 390{
 391	struct perf_evsel *evsel = perf_evlist__first(evlist);
 392
 393	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 394	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 395	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 396	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 397	TEST_ASSERT_VAL("wrong name",
 398			!strcmp(perf_evsel__name(evsel), "mem:0:rw:kp"));
 399
 400	return test__checkevent_breakpoint_rw(evlist);
 401}
 402
 403static int test__checkevent_pmu(struct perf_evlist *evlist)
 404{
 405
 406	struct perf_evsel *evsel = perf_evlist__first(evlist);
 407
 408	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 409	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 410	TEST_ASSERT_VAL("wrong config",    10 == evsel->attr.config);
 411	TEST_ASSERT_VAL("wrong config1",    1 == evsel->attr.config1);
 412	TEST_ASSERT_VAL("wrong config2",    3 == evsel->attr.config2);
 413	/*
 414	 * The period value gets configured within perf_evlist__config,
 415	 * while this test executes only parse events method.
 416	 */
 417	TEST_ASSERT_VAL("wrong period",     0 == evsel->attr.sample_period);
 418
 419	return 0;
 420}
 421
 422static int test__checkevent_list(struct perf_evlist *evlist)
 423{
 424	struct perf_evsel *evsel = perf_evlist__first(evlist);
 425
 426	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
 427
 428	/* r1 */
 429	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 430	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
 431	TEST_ASSERT_VAL("wrong config1", 0 == evsel->attr.config1);
 432	TEST_ASSERT_VAL("wrong config2", 0 == evsel->attr.config2);
 433	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 434	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 435	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 436	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 437
 438	/* syscalls:sys_enter_openat:k */
 439	evsel = perf_evsel__next(evsel);
 440	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
 441	TEST_ASSERT_VAL("wrong sample_type",
 442		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
 443	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
 444	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 445	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 446	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 447	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 448
 449	/* 1:1:hp */
 450	evsel = perf_evsel__next(evsel);
 451	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
 452	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
 453	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 454	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 455	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 456	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 457
 458	return 0;
 459}
 460
 461static int test__checkevent_pmu_name(struct perf_evlist *evlist)
 462{
 463	struct perf_evsel *evsel = perf_evlist__first(evlist);
 464
 465	/* cpu/config=1,name=krava/u */
 466	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 467	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 468	TEST_ASSERT_VAL("wrong config",  1 == evsel->attr.config);
 469	TEST_ASSERT_VAL("wrong name", !strcmp(perf_evsel__name(evsel), "krava"));
 470
 471	/* cpu/config=2/u" */
 472	evsel = perf_evsel__next(evsel);
 473	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 474	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 475	TEST_ASSERT_VAL("wrong config",  2 == evsel->attr.config);
 476	TEST_ASSERT_VAL("wrong name",
 477			!strcmp(perf_evsel__name(evsel), "cpu/config=2/u"));
 478
 479	return 0;
 480}
 481
 482static int test__checkevent_pmu_partial_time_callgraph(struct perf_evlist *evlist)
 483{
 484	struct perf_evsel *evsel = perf_evlist__first(evlist);
 485
 486	/* cpu/config=1,call-graph=fp,time,period=100000/ */
 487	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 488	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 489	TEST_ASSERT_VAL("wrong config",  1 == evsel->attr.config);
 490	/*
 491	 * The period, time and callgraph value gets configured
 492	 * within perf_evlist__config,
 493	 * while this test executes only parse events method.
 494	 */
 495	TEST_ASSERT_VAL("wrong period",     0 == evsel->attr.sample_period);
 496	TEST_ASSERT_VAL("wrong callgraph",  !(PERF_SAMPLE_CALLCHAIN & evsel->attr.sample_type));
 497	TEST_ASSERT_VAL("wrong time",  !(PERF_SAMPLE_TIME & evsel->attr.sample_type));
 498
 499	/* cpu/config=2,call-graph=no,time=0,period=2000/ */
 500	evsel = perf_evsel__next(evsel);
 501	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 502	TEST_ASSERT_VAL("wrong config",  2 == evsel->attr.config);
 503	/*
 504	 * The period, time and callgraph value gets configured
 505	 * within perf_evlist__config,
 506	 * while this test executes only parse events method.
 507	 */
 508	TEST_ASSERT_VAL("wrong period",     0 == evsel->attr.sample_period);
 509	TEST_ASSERT_VAL("wrong callgraph",  !(PERF_SAMPLE_CALLCHAIN & evsel->attr.sample_type));
 510	TEST_ASSERT_VAL("wrong time",  !(PERF_SAMPLE_TIME & evsel->attr.sample_type));
 511
 512	return 0;
 513}
 514
 515static int test__checkevent_pmu_events(struct perf_evlist *evlist)
 516{
 517	struct perf_evsel *evsel = perf_evlist__first(evlist);
 518
 519	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 520	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 521	TEST_ASSERT_VAL("wrong exclude_user",
 522			!evsel->attr.exclude_user);
 523	TEST_ASSERT_VAL("wrong exclude_kernel",
 524			evsel->attr.exclude_kernel);
 525	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 526	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 527	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
 528
 529	return 0;
 530}
 531
 532
 533static int test__checkevent_pmu_events_mix(struct perf_evlist *evlist)
 534{
 535	struct perf_evsel *evsel = perf_evlist__first(evlist);
 536
 537	/* pmu-event:u */
 538	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 539	TEST_ASSERT_VAL("wrong exclude_user",
 540			!evsel->attr.exclude_user);
 541	TEST_ASSERT_VAL("wrong exclude_kernel",
 542			evsel->attr.exclude_kernel);
 543	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 544	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 545	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
 546
 547	/* cpu/pmu-event/u*/
 548	evsel = perf_evsel__next(evsel);
 549	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 550	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 551	TEST_ASSERT_VAL("wrong exclude_user",
 552			!evsel->attr.exclude_user);
 553	TEST_ASSERT_VAL("wrong exclude_kernel",
 554			evsel->attr.exclude_kernel);
 555	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 556	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 557	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
 558
 559	return 0;
 560}
 561
 562static int test__checkterms_simple(struct list_head *terms)
 563{
 564	struct parse_events_term *term;
 565
 566	/* config=10 */
 567	term = list_entry(terms->next, struct parse_events_term, list);
 568	TEST_ASSERT_VAL("wrong type term",
 569			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG);
 570	TEST_ASSERT_VAL("wrong type val",
 571			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
 572	TEST_ASSERT_VAL("wrong val", term->val.num == 10);
 573	TEST_ASSERT_VAL("wrong config", !term->config);
 574
 575	/* config1 */
 576	term = list_entry(term->list.next, struct parse_events_term, list);
 577	TEST_ASSERT_VAL("wrong type term",
 578			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG1);
 579	TEST_ASSERT_VAL("wrong type val",
 580			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
 581	TEST_ASSERT_VAL("wrong val", term->val.num == 1);
 582	TEST_ASSERT_VAL("wrong config", !term->config);
 583
 584	/* config2=3 */
 585	term = list_entry(term->list.next, struct parse_events_term, list);
 586	TEST_ASSERT_VAL("wrong type term",
 587			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG2);
 588	TEST_ASSERT_VAL("wrong type val",
 589			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
 590	TEST_ASSERT_VAL("wrong val", term->val.num == 3);
 591	TEST_ASSERT_VAL("wrong config", !term->config);
 592
 593	/* umask=1*/
 594	term = list_entry(term->list.next, struct parse_events_term, list);
 595	TEST_ASSERT_VAL("wrong type term",
 596			term->type_term == PARSE_EVENTS__TERM_TYPE_USER);
 597	TEST_ASSERT_VAL("wrong type val",
 598			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
 599	TEST_ASSERT_VAL("wrong val", term->val.num == 1);
 600	TEST_ASSERT_VAL("wrong config", !strcmp(term->config, "umask"));
 601
 602	return 0;
 603}
 604
 605static int test__group1(struct perf_evlist *evlist)
 606{
 607	struct perf_evsel *evsel, *leader;
 608
 609	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 610	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 611
 612	/* instructions:k */
 613	evsel = leader = perf_evlist__first(evlist);
 614	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 615	TEST_ASSERT_VAL("wrong config",
 616			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 617	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 618	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 619	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 620	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 621	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 622	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 623	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 624	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 625	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 626	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 627
 628	/* cycles:upp */
 629	evsel = perf_evsel__next(evsel);
 630	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 631	TEST_ASSERT_VAL("wrong config",
 632			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 633	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 634	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 635	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 636	/* use of precise requires exclude_guest */
 637	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 638	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 639	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 2);
 640	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 641	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 642	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 643
 644	return 0;
 645}
 646
 647static int test__group2(struct perf_evlist *evlist)
 648{
 649	struct perf_evsel *evsel, *leader;
 650
 651	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
 652	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 653
 654	/* faults + :ku modifier */
 655	evsel = leader = perf_evlist__first(evlist);
 656	TEST_ASSERT_VAL("wrong type", PERF_TYPE_SOFTWARE == evsel->attr.type);
 657	TEST_ASSERT_VAL("wrong config",
 658			PERF_COUNT_SW_PAGE_FAULTS == evsel->attr.config);
 659	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 660	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 661	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 662	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 663	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 664	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 665	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 666	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 667	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 668	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 669
 670	/* cache-references + :u modifier */
 671	evsel = perf_evsel__next(evsel);
 672	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 673	TEST_ASSERT_VAL("wrong config",
 674			PERF_COUNT_HW_CACHE_REFERENCES == evsel->attr.config);
 675	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 676	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 677	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 678	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 679	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 680	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 681	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 682	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 683	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 684
 685	/* cycles:k */
 686	evsel = perf_evsel__next(evsel);
 687	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 688	TEST_ASSERT_VAL("wrong config",
 689			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 690	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 691	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 692	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 693	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 694	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 695	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 696	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 697	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 698
 699	return 0;
 700}
 701
 702static int test__group3(struct perf_evlist *evlist __maybe_unused)
 703{
 704	struct perf_evsel *evsel, *leader;
 705
 706	TEST_ASSERT_VAL("wrong number of entries", 5 == evlist->nr_entries);
 707	TEST_ASSERT_VAL("wrong number of groups", 2 == evlist->nr_groups);
 708
 709	/* group1 syscalls:sys_enter_openat:H */
 710	evsel = leader = perf_evlist__first(evlist);
 711	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
 712	TEST_ASSERT_VAL("wrong sample_type",
 713		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
 714	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
 715	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 716	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 717	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 718	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 719	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 720	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 721	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 722	TEST_ASSERT_VAL("wrong group name",
 723		!strcmp(leader->group_name, "group1"));
 724	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 725	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 726	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 727
 728	/* group1 cycles:kppp */
 729	evsel = perf_evsel__next(evsel);
 730	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 731	TEST_ASSERT_VAL("wrong config",
 732			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 733	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 734	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 735	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 736	/* use of precise requires exclude_guest */
 737	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 738	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 739	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 3);
 740	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 741	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 742	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 743	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 744
 745	/* group2 cycles + G modifier */
 746	evsel = leader = perf_evsel__next(evsel);
 747	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 748	TEST_ASSERT_VAL("wrong config",
 749			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 750	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 751	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 752	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 753	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 754	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 755	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 756	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 757	TEST_ASSERT_VAL("wrong group name",
 758		!strcmp(leader->group_name, "group2"));
 759	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 760	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 761	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 762
 763	/* group2 1:3 + G modifier */
 764	evsel = perf_evsel__next(evsel);
 765	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
 766	TEST_ASSERT_VAL("wrong config", 3 == evsel->attr.config);
 767	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 768	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 769	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 770	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 771	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 772	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 773	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 774	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 775	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 776
 777	/* instructions:u */
 778	evsel = perf_evsel__next(evsel);
 779	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 780	TEST_ASSERT_VAL("wrong config",
 781			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 782	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 783	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 784	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 785	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 786	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 787	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 788	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 789	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 790
 791	return 0;
 792}
 793
 794static int test__group4(struct perf_evlist *evlist __maybe_unused)
 795{
 796	struct perf_evsel *evsel, *leader;
 797
 798	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 799	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 800
 801	/* cycles:u + p */
 802	evsel = leader = perf_evlist__first(evlist);
 803	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 804	TEST_ASSERT_VAL("wrong config",
 805			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 806	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 807	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 808	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 809	/* use of precise requires exclude_guest */
 810	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 811	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 812	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 1);
 813	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 814	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 815	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 816	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 817	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 818
 819	/* instructions:kp + p */
 820	evsel = perf_evsel__next(evsel);
 821	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 822	TEST_ASSERT_VAL("wrong config",
 823			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 824	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 825	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 826	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 827	/* use of precise requires exclude_guest */
 828	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 829	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 830	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 2);
 831	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 832	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 833	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 834
 835	return 0;
 836}
 837
 838static int test__group5(struct perf_evlist *evlist __maybe_unused)
 839{
 840	struct perf_evsel *evsel, *leader;
 841
 842	TEST_ASSERT_VAL("wrong number of entries", 5 == evlist->nr_entries);
 843	TEST_ASSERT_VAL("wrong number of groups", 2 == evlist->nr_groups);
 844
 845	/* cycles + G */
 846	evsel = leader = perf_evlist__first(evlist);
 847	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 848	TEST_ASSERT_VAL("wrong config",
 849			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 850	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 851	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 852	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 853	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 854	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 855	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 856	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 857	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 858	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 859	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 860	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 861
 862	/* instructions + G */
 863	evsel = perf_evsel__next(evsel);
 864	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 865	TEST_ASSERT_VAL("wrong config",
 866			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 867	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 868	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 869	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 870	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 871	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 872	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 873	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 874	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 875	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 876
 877	/* cycles:G */
 878	evsel = leader = perf_evsel__next(evsel);
 879	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 880	TEST_ASSERT_VAL("wrong config",
 881			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 882	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 883	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 884	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 885	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 886	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 887	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 888	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 889	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 890	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 891	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 892	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 893
 894	/* instructions:G */
 895	evsel = perf_evsel__next(evsel);
 896	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 897	TEST_ASSERT_VAL("wrong config",
 898			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 899	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 900	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 901	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 902	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 903	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 904	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 905	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 906	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 907
 908	/* cycles */
 909	evsel = perf_evsel__next(evsel);
 910	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 911	TEST_ASSERT_VAL("wrong config",
 912			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 913	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 914	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 915	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 916	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 917	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 918	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 919	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 920
 921	return 0;
 922}
 923
 924static int test__group_gh1(struct perf_evlist *evlist)
 925{
 926	struct perf_evsel *evsel, *leader;
 927
 928	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 929	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 930
 931	/* cycles + :H group modifier */
 932	evsel = leader = perf_evlist__first(evlist);
 933	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 934	TEST_ASSERT_VAL("wrong config",
 935			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 936	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 937	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 938	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 939	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 940	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 941	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 942	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 943	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 944	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 945	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 946
 947	/* cache-misses:G + :H group modifier */
 948	evsel = perf_evsel__next(evsel);
 949	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 950	TEST_ASSERT_VAL("wrong config",
 951			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
 952	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 953	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 954	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 955	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 956	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 957	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 958	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 959	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 960
 961	return 0;
 962}
 963
 964static int test__group_gh2(struct perf_evlist *evlist)
 965{
 966	struct perf_evsel *evsel, *leader;
 967
 968	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 969	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 970
 971	/* cycles + :G group modifier */
 972	evsel = leader = perf_evlist__first(evlist);
 973	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 974	TEST_ASSERT_VAL("wrong config",
 975			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 976	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 977	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 978	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 979	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 980	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 981	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 982	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 983	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 984	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 985	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 986
 987	/* cache-misses:H + :G group modifier */
 988	evsel = perf_evsel__next(evsel);
 989	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 990	TEST_ASSERT_VAL("wrong config",
 991			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
 992	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 993	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 994	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 995	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 996	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 997	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 998	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 999	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
1000
1001	return 0;
1002}
1003
1004static int test__group_gh3(struct perf_evlist *evlist)
1005{
1006	struct perf_evsel *evsel, *leader;
1007
1008	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
1009	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
1010
1011	/* cycles:G + :u group modifier */
1012	evsel = leader = perf_evlist__first(evlist);
1013	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1014	TEST_ASSERT_VAL("wrong config",
1015			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
1016	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1017	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1018	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1019	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
1020	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
1021	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1022	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1023	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
1024	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
1025	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
1026
1027	/* cache-misses:H + :u group modifier */
1028	evsel = perf_evsel__next(evsel);
1029	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1030	TEST_ASSERT_VAL("wrong config",
1031			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
1032	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1033	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1034	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1035	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1036	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1037	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1038	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1039	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
1040
1041	return 0;
1042}
1043
1044static int test__group_gh4(struct perf_evlist *evlist)
1045{
1046	struct perf_evsel *evsel, *leader;
1047
1048	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
1049	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
1050
1051	/* cycles:G + :uG group modifier */
1052	evsel = leader = perf_evlist__first(evlist);
1053	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1054	TEST_ASSERT_VAL("wrong config",
1055			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
1056	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1057	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1058	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1059	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
1060	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
1061	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1062	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1063	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
1064	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
1065	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
1066
1067	/* cache-misses:H + :uG group modifier */
1068	evsel = perf_evsel__next(evsel);
1069	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1070	TEST_ASSERT_VAL("wrong config",
1071			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
1072	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1073	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1074	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1075	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
1076	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1077	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1078	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1079	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
1080
1081	return 0;
1082}
1083
1084static int test__leader_sample1(struct perf_evlist *evlist)
1085{
1086	struct perf_evsel *evsel, *leader;
1087
1088	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
1089
1090	/* cycles - sampling group leader */
1091	evsel = leader = perf_evlist__first(evlist);
1092	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1093	TEST_ASSERT_VAL("wrong config",
1094			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
1095	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1096	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
1097	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
1098	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1099	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1100	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1101	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1102	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1103	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1104
1105	/* cache-misses - not sampling */
1106	evsel = perf_evsel__next(evsel);
1107	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1108	TEST_ASSERT_VAL("wrong config",
1109			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
1110	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1111	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
1112	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
1113	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1114	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1115	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1116	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1117	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1118
1119	/* branch-misses - not sampling */
1120	evsel = perf_evsel__next(evsel);
1121	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1122	TEST_ASSERT_VAL("wrong config",
1123			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1124	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1125	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
1126	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
1127	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1128	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1129	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1130	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1131	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1132	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1133
1134	return 0;
1135}
1136
1137static int test__leader_sample2(struct perf_evlist *evlist __maybe_unused)
1138{
1139	struct perf_evsel *evsel, *leader;
1140
1141	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
1142
1143	/* instructions - sampling group leader */
1144	evsel = leader = perf_evlist__first(evlist);
1145	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1146	TEST_ASSERT_VAL("wrong config",
1147			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
1148	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1149	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1150	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1151	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1152	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1153	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1154	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1155	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1156	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1157
1158	/* branch-misses - not sampling */
1159	evsel = perf_evsel__next(evsel);
1160	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1161	TEST_ASSERT_VAL("wrong config",
1162			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1163	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1164	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1165	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1166	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1167	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1168	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1169	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1170	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1171	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1172
1173	return 0;
1174}
1175
1176static int test__checkevent_pinned_modifier(struct perf_evlist *evlist)
1177{
1178	struct perf_evsel *evsel = perf_evlist__first(evlist);
1179
1180	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1181	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1182	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1183	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
1184	TEST_ASSERT_VAL("wrong pinned", evsel->attr.pinned);
1185
1186	return test__checkevent_symbolic_name(evlist);
1187}
1188
1189static int test__pinned_group(struct perf_evlist *evlist)
1190{
1191	struct perf_evsel *evsel, *leader;
1192
1193	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
1194
1195	/* cycles - group leader */
1196	evsel = leader = perf_evlist__first(evlist);
1197	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1198	TEST_ASSERT_VAL("wrong config",
1199			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
1200	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1201	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1202	TEST_ASSERT_VAL("wrong pinned", evsel->attr.pinned);
1203
1204	/* cache-misses - can not be pinned, but will go on with the leader */
1205	evsel = perf_evsel__next(evsel);
1206	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1207	TEST_ASSERT_VAL("wrong config",
1208			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
1209	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
1210
1211	/* branch-misses - ditto */
1212	evsel = perf_evsel__next(evsel);
1213	TEST_ASSERT_VAL("wrong config",
1214			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1215	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
1216
1217	return 0;
1218}
1219
1220static int test__checkevent_breakpoint_len(struct perf_evlist *evlist)
1221{
1222	struct perf_evsel *evsel = perf_evlist__first(evlist);
1223
1224	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
1225	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
1226	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
1227	TEST_ASSERT_VAL("wrong bp_type", (HW_BREAKPOINT_R | HW_BREAKPOINT_W) ==
1228					 evsel->attr.bp_type);
1229	TEST_ASSERT_VAL("wrong bp_len", HW_BREAKPOINT_LEN_1 ==
1230					evsel->attr.bp_len);
1231
1232	return 0;
1233}
1234
1235static int test__checkevent_breakpoint_len_w(struct perf_evlist *evlist)
1236{
1237	struct perf_evsel *evsel = perf_evlist__first(evlist);
1238
1239	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
1240	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
1241	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
1242	TEST_ASSERT_VAL("wrong bp_type", HW_BREAKPOINT_W ==
1243					 evsel->attr.bp_type);
1244	TEST_ASSERT_VAL("wrong bp_len", HW_BREAKPOINT_LEN_2 ==
1245					evsel->attr.bp_len);
1246
1247	return 0;
1248}
1249
1250static int
1251test__checkevent_breakpoint_len_rw_modifier(struct perf_evlist *evlist)
1252{
1253	struct perf_evsel *evsel = perf_evlist__first(evlist);
1254
1255	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1256	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1257	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1258	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1259
1260	return test__checkevent_breakpoint_rw(evlist);
1261}
1262
1263static int test__checkevent_precise_max_modifier(struct perf_evlist *evlist)
1264{
1265	struct perf_evsel *evsel = perf_evlist__first(evlist);
1266
1267	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
1268	TEST_ASSERT_VAL("wrong type", PERF_TYPE_SOFTWARE == evsel->attr.type);
1269	TEST_ASSERT_VAL("wrong config",
1270			PERF_COUNT_SW_TASK_CLOCK == evsel->attr.config);
1271	return 0;
1272}
1273
1274static int test__checkevent_config_symbol(struct perf_evlist *evlist)
1275{
1276	struct perf_evsel *evsel = perf_evlist__first(evlist);
1277
1278	TEST_ASSERT_VAL("wrong name setting", strcmp(evsel->name, "insn") == 0);
1279	return 0;
1280}
1281
1282static int test__checkevent_config_raw(struct perf_evlist *evlist)
1283{
1284	struct perf_evsel *evsel = perf_evlist__first(evlist);
1285
1286	TEST_ASSERT_VAL("wrong name setting", strcmp(evsel->name, "rawpmu") == 0);
1287	return 0;
1288}
1289
1290static int test__checkevent_config_num(struct perf_evlist *evlist)
1291{
1292	struct perf_evsel *evsel = perf_evlist__first(evlist);
1293
1294	TEST_ASSERT_VAL("wrong name setting", strcmp(evsel->name, "numpmu") == 0);
1295	return 0;
1296}
1297
1298static int test__checkevent_config_cache(struct perf_evlist *evlist)
1299{
1300	struct perf_evsel *evsel = perf_evlist__first(evlist);
1301
1302	TEST_ASSERT_VAL("wrong name setting", strcmp(evsel->name, "cachepmu") == 0);
1303	return 0;
1304}
1305
1306static int count_tracepoints(void)
1307{
 
1308	struct dirent *events_ent;
1309	DIR *events_dir;
1310	int cnt = 0;
1311
1312	events_dir = opendir(tracing_events_path);
 
 
 
1313
1314	TEST_ASSERT_VAL("Can't open events dir", events_dir);
1315
1316	while ((events_ent = readdir(events_dir))) {
1317		char sys_path[PATH_MAX];
1318		struct dirent *sys_ent;
1319		DIR *sys_dir;
1320
1321		if (!strcmp(events_ent->d_name, ".")
1322		    || !strcmp(events_ent->d_name, "..")
1323		    || !strcmp(events_ent->d_name, "enable")
1324		    || !strcmp(events_ent->d_name, "header_event")
1325		    || !strcmp(events_ent->d_name, "header_page"))
1326			continue;
1327
1328		scnprintf(sys_path, PATH_MAX, "%s/%s",
1329			  tracing_events_path, events_ent->d_name);
1330
1331		sys_dir = opendir(sys_path);
1332		TEST_ASSERT_VAL("Can't open sys dir", sys_dir);
1333
1334		while ((sys_ent = readdir(sys_dir))) {
1335			if (!strcmp(sys_ent->d_name, ".")
1336			    || !strcmp(sys_ent->d_name, "..")
1337			    || !strcmp(sys_ent->d_name, "enable")
1338			    || !strcmp(sys_ent->d_name, "filter"))
1339				continue;
1340
1341			cnt++;
1342		}
1343
1344		closedir(sys_dir);
1345	}
1346
1347	closedir(events_dir);
1348	return cnt;
1349}
1350
1351static int test__all_tracepoints(struct perf_evlist *evlist)
1352{
1353	TEST_ASSERT_VAL("wrong events count",
1354			count_tracepoints() == evlist->nr_entries);
1355
1356	return test__checkevent_tracepoint_multi(evlist);
1357}
1358
1359struct evlist_test {
1360	const char *name;
1361	__u32 type;
1362	const int id;
1363	int (*check)(struct perf_evlist *evlist);
1364};
1365
1366static struct evlist_test test__events[] = {
1367	{
1368		.name  = "syscalls:sys_enter_openat",
1369		.check = test__checkevent_tracepoint,
1370		.id    = 0,
1371	},
1372	{
1373		.name  = "syscalls:*",
1374		.check = test__checkevent_tracepoint_multi,
1375		.id    = 1,
1376	},
1377	{
1378		.name  = "r1a",
1379		.check = test__checkevent_raw,
1380		.id    = 2,
1381	},
1382	{
1383		.name  = "1:1",
1384		.check = test__checkevent_numeric,
1385		.id    = 3,
1386	},
1387	{
1388		.name  = "instructions",
1389		.check = test__checkevent_symbolic_name,
1390		.id    = 4,
1391	},
1392	{
1393		.name  = "cycles/period=100000,config2/",
1394		.check = test__checkevent_symbolic_name_config,
1395		.id    = 5,
1396	},
1397	{
1398		.name  = "faults",
1399		.check = test__checkevent_symbolic_alias,
1400		.id    = 6,
1401	},
1402	{
1403		.name  = "L1-dcache-load-miss",
1404		.check = test__checkevent_genhw,
1405		.id    = 7,
1406	},
1407	{
1408		.name  = "mem:0",
1409		.check = test__checkevent_breakpoint,
1410		.id    = 8,
1411	},
1412	{
1413		.name  = "mem:0:x",
1414		.check = test__checkevent_breakpoint_x,
1415		.id    = 9,
1416	},
1417	{
1418		.name  = "mem:0:r",
1419		.check = test__checkevent_breakpoint_r,
1420		.id    = 10,
1421	},
1422	{
1423		.name  = "mem:0:w",
1424		.check = test__checkevent_breakpoint_w,
1425		.id    = 11,
1426	},
1427	{
1428		.name  = "syscalls:sys_enter_openat:k",
1429		.check = test__checkevent_tracepoint_modifier,
1430		.id    = 12,
1431	},
1432	{
1433		.name  = "syscalls:*:u",
1434		.check = test__checkevent_tracepoint_multi_modifier,
1435		.id    = 13,
1436	},
1437	{
1438		.name  = "r1a:kp",
1439		.check = test__checkevent_raw_modifier,
1440		.id    = 14,
1441	},
1442	{
1443		.name  = "1:1:hp",
1444		.check = test__checkevent_numeric_modifier,
1445		.id    = 15,
1446	},
1447	{
1448		.name  = "instructions:h",
1449		.check = test__checkevent_symbolic_name_modifier,
1450		.id    = 16,
1451	},
1452	{
1453		.name  = "faults:u",
1454		.check = test__checkevent_symbolic_alias_modifier,
1455		.id    = 17,
1456	},
1457	{
1458		.name  = "L1-dcache-load-miss:kp",
1459		.check = test__checkevent_genhw_modifier,
1460		.id    = 18,
1461	},
1462	{
1463		.name  = "mem:0:u",
1464		.check = test__checkevent_breakpoint_modifier,
1465		.id    = 19,
1466	},
1467	{
1468		.name  = "mem:0:x:k",
1469		.check = test__checkevent_breakpoint_x_modifier,
1470		.id    = 20,
1471	},
1472	{
1473		.name  = "mem:0:r:hp",
1474		.check = test__checkevent_breakpoint_r_modifier,
1475		.id    = 21,
1476	},
1477	{
1478		.name  = "mem:0:w:up",
1479		.check = test__checkevent_breakpoint_w_modifier,
1480		.id    = 22,
1481	},
1482	{
1483		.name  = "r1,syscalls:sys_enter_openat:k,1:1:hp",
1484		.check = test__checkevent_list,
1485		.id    = 23,
1486	},
1487	{
1488		.name  = "instructions:G",
1489		.check = test__checkevent_exclude_host_modifier,
1490		.id    = 24,
1491	},
1492	{
1493		.name  = "instructions:H",
1494		.check = test__checkevent_exclude_guest_modifier,
1495		.id    = 25,
1496	},
1497	{
1498		.name  = "mem:0:rw",
1499		.check = test__checkevent_breakpoint_rw,
1500		.id    = 26,
1501	},
1502	{
1503		.name  = "mem:0:rw:kp",
1504		.check = test__checkevent_breakpoint_rw_modifier,
1505		.id    = 27,
1506	},
1507	{
1508		.name  = "{instructions:k,cycles:upp}",
1509		.check = test__group1,
1510		.id    = 28,
1511	},
1512	{
1513		.name  = "{faults:k,cache-references}:u,cycles:k",
1514		.check = test__group2,
1515		.id    = 29,
1516	},
1517	{
1518		.name  = "group1{syscalls:sys_enter_openat:H,cycles:kppp},group2{cycles,1:3}:G,instructions:u",
1519		.check = test__group3,
1520		.id    = 30,
1521	},
1522	{
1523		.name  = "{cycles:u,instructions:kp}:p",
1524		.check = test__group4,
1525		.id    = 31,
1526	},
1527	{
1528		.name  = "{cycles,instructions}:G,{cycles:G,instructions:G},cycles",
1529		.check = test__group5,
1530		.id    = 32,
1531	},
1532	{
1533		.name  = "*:*",
1534		.check = test__all_tracepoints,
1535		.id    = 33,
1536	},
1537	{
1538		.name  = "{cycles,cache-misses:G}:H",
1539		.check = test__group_gh1,
1540		.id    = 34,
1541	},
1542	{
1543		.name  = "{cycles,cache-misses:H}:G",
1544		.check = test__group_gh2,
1545		.id    = 35,
1546	},
1547	{
1548		.name  = "{cycles:G,cache-misses:H}:u",
1549		.check = test__group_gh3,
1550		.id    = 36,
1551	},
1552	{
1553		.name  = "{cycles:G,cache-misses:H}:uG",
1554		.check = test__group_gh4,
1555		.id    = 37,
1556	},
1557	{
1558		.name  = "{cycles,cache-misses,branch-misses}:S",
1559		.check = test__leader_sample1,
1560		.id    = 38,
1561	},
1562	{
1563		.name  = "{instructions,branch-misses}:Su",
1564		.check = test__leader_sample2,
1565		.id    = 39,
1566	},
1567	{
1568		.name  = "instructions:uDp",
1569		.check = test__checkevent_pinned_modifier,
1570		.id    = 40,
1571	},
1572	{
1573		.name  = "{cycles,cache-misses,branch-misses}:D",
1574		.check = test__pinned_group,
1575		.id    = 41,
1576	},
1577	{
1578		.name  = "mem:0/1",
1579		.check = test__checkevent_breakpoint_len,
1580		.id    = 42,
1581	},
1582	{
1583		.name  = "mem:0/2:w",
1584		.check = test__checkevent_breakpoint_len_w,
1585		.id    = 43,
1586	},
1587	{
1588		.name  = "mem:0/4:rw:u",
1589		.check = test__checkevent_breakpoint_len_rw_modifier,
1590		.id    = 44
1591	},
1592#if defined(__s390x__)
1593	{
1594		.name  = "kvm-s390:kvm_s390_create_vm",
1595		.check = test__checkevent_tracepoint,
1596		.id    = 100,
1597	},
1598#endif
1599	{
1600		.name  = "instructions:I",
1601		.check = test__checkevent_exclude_idle_modifier,
1602		.id    = 45,
1603	},
1604	{
1605		.name  = "instructions:kIG",
1606		.check = test__checkevent_exclude_idle_modifier_1,
1607		.id    = 46,
1608	},
1609	{
1610		.name  = "task-clock:P,cycles",
1611		.check = test__checkevent_precise_max_modifier,
1612		.id    = 47,
1613	},
1614	{
1615		.name  = "instructions/name=insn/",
1616		.check = test__checkevent_config_symbol,
1617		.id    = 48,
1618	},
1619	{
1620		.name  = "r1234/name=rawpmu/",
1621		.check = test__checkevent_config_raw,
1622		.id    = 49,
1623	},
1624	{
1625		.name  = "4:0x6530160/name=numpmu/",
1626		.check = test__checkevent_config_num,
1627		.id    = 50,
1628	},
1629	{
1630		.name  = "L1-dcache-misses/name=cachepmu/",
1631		.check = test__checkevent_config_cache,
1632		.id    = 51,
1633	},
1634};
1635
1636static struct evlist_test test__events_pmu[] = {
1637	{
1638		.name  = "cpu/config=10,config1,config2=3,period=1000/u",
1639		.check = test__checkevent_pmu,
1640		.id    = 0,
1641	},
1642	{
1643		.name  = "cpu/config=1,name=krava/u,cpu/config=2/u",
1644		.check = test__checkevent_pmu_name,
1645		.id    = 1,
1646	},
1647	{
1648		.name  = "cpu/config=1,call-graph=fp,time,period=100000/,cpu/config=2,call-graph=no,time=0,period=2000/",
1649		.check = test__checkevent_pmu_partial_time_callgraph,
1650		.id    = 2,
1651	},
1652};
1653
1654struct terms_test {
1655	const char *str;
1656	__u32 type;
1657	int (*check)(struct list_head *terms);
1658};
1659
1660static struct terms_test test__terms[] = {
1661	[0] = {
1662		.str   = "config=10,config1,config2=3,umask=1",
1663		.check = test__checkterms_simple,
1664	},
1665};
1666
1667static int test_event(struct evlist_test *e)
1668{
1669	struct perf_evlist *evlist;
1670	int ret;
1671
1672	evlist = perf_evlist__new();
1673	if (evlist == NULL)
1674		return -ENOMEM;
1675
1676	ret = parse_events(evlist, e->name, NULL);
1677	if (ret) {
1678		pr_debug("failed to parse event '%s', err %d\n",
1679			 e->name, ret);
1680	} else {
1681		ret = e->check(evlist);
1682	}
1683
1684	perf_evlist__delete(evlist);
1685
1686	return ret;
1687}
1688
1689static int test_events(struct evlist_test *events, unsigned cnt)
1690{
1691	int ret1, ret2 = 0;
1692	unsigned i;
1693
1694	for (i = 0; i < cnt; i++) {
1695		struct evlist_test *e = &events[i];
1696
1697		pr_debug("running test %d '%s'\n", e->id, e->name);
1698		ret1 = test_event(e);
1699		if (ret1)
1700			ret2 = ret1;
1701	}
1702
1703	return ret2;
1704}
1705
1706static int test_term(struct terms_test *t)
1707{
1708	struct list_head terms;
1709	int ret;
1710
1711	INIT_LIST_HEAD(&terms);
1712
1713	ret = parse_events_terms(&terms, t->str);
1714	if (ret) {
1715		pr_debug("failed to parse terms '%s', err %d\n",
1716			 t->str , ret);
1717		return ret;
1718	}
1719
1720	ret = t->check(&terms);
1721	parse_events_terms__purge(&terms);
1722
1723	return ret;
1724}
1725
1726static int test_terms(struct terms_test *terms, unsigned cnt)
1727{
1728	int ret = 0;
1729	unsigned i;
1730
1731	for (i = 0; i < cnt; i++) {
1732		struct terms_test *t = &terms[i];
1733
1734		pr_debug("running test %d '%s'\n", i, t->str);
1735		ret = test_term(t);
1736		if (ret)
1737			break;
1738	}
1739
1740	return ret;
1741}
1742
1743static int test_pmu(void)
1744{
1745	struct stat st;
1746	char path[PATH_MAX];
1747	int ret;
1748
1749	snprintf(path, PATH_MAX, "%s/bus/event_source/devices/cpu/format/",
1750		 sysfs__mountpoint());
1751
1752	ret = stat(path, &st);
1753	if (ret)
1754		pr_debug("omitting PMU cpu tests\n");
1755	return !ret;
1756}
1757
1758static int test_pmu_events(void)
1759{
1760	struct stat st;
1761	char path[PATH_MAX];
1762	struct dirent *ent;
1763	DIR *dir;
1764	int ret;
1765
1766	snprintf(path, PATH_MAX, "%s/bus/event_source/devices/cpu/events/",
1767		 sysfs__mountpoint());
1768
1769	ret = stat(path, &st);
1770	if (ret) {
1771		pr_debug("omitting PMU cpu events tests\n");
1772		return 0;
1773	}
1774
1775	dir = opendir(path);
1776	if (!dir) {
1777		pr_debug("can't open pmu event dir");
1778		return -1;
1779	}
1780
1781	while (!ret && (ent = readdir(dir))) {
1782#define MAX_NAME 100
1783		struct evlist_test e;
1784		char name[MAX_NAME];
1785
1786		if (!strcmp(ent->d_name, ".") ||
1787		    !strcmp(ent->d_name, ".."))
1788			continue;
1789
1790		snprintf(name, MAX_NAME, "cpu/event=%s/u", ent->d_name);
1791
1792		e.name  = name;
1793		e.check = test__checkevent_pmu_events;
1794
1795		ret = test_event(&e);
1796		if (ret)
1797			break;
1798		snprintf(name, MAX_NAME, "%s:u,cpu/event=%s/u", ent->d_name, ent->d_name);
1799		e.name  = name;
1800		e.check = test__checkevent_pmu_events_mix;
1801		ret = test_event(&e);
1802#undef MAX_NAME
1803	}
1804
1805	closedir(dir);
1806	return ret;
1807}
1808
1809static void debug_warn(const char *warn, va_list params)
1810{
1811	char msg[1024];
1812
1813	if (!verbose)
1814		return;
1815
1816	vsnprintf(msg, sizeof(msg), warn, params);
1817	fprintf(stderr, " Warning: %s\n", msg);
1818}
1819
1820int test__parse_events(int subtest __maybe_unused)
1821{
1822	int ret1, ret2 = 0;
1823
1824#define TEST_EVENTS(tests)				\
1825do {							\
1826	ret1 = test_events(tests, ARRAY_SIZE(tests));	\
1827	if (!ret2)					\
1828		ret2 = ret1;				\
1829} while (0)
1830
1831	set_warning_routine(debug_warn);
1832
1833	TEST_EVENTS(test__events);
1834
1835	if (test_pmu())
1836		TEST_EVENTS(test__events_pmu);
1837
1838	if (test_pmu()) {
1839		int ret = test_pmu_events();
1840		if (ret)
1841			return ret;
1842	}
1843
1844	ret1 = test_terms(test__terms, ARRAY_SIZE(test__terms));
1845	if (!ret2)
1846		ret2 = ret1;
1847
1848	return ret2;
1849}
v3.15
   1
   2#include "parse-events.h"
   3#include "evsel.h"
   4#include "evlist.h"
   5#include <api/fs/fs.h>
   6#include <api/fs/debugfs.h>
   7#include "tests.h"
 
 
   8#include <linux/hw_breakpoint.h>
 
   9
  10#define PERF_TP_SAMPLE_TYPE (PERF_SAMPLE_RAW | PERF_SAMPLE_TIME | \
  11			     PERF_SAMPLE_CPU | PERF_SAMPLE_PERIOD)
  12
  13static int test__checkevent_tracepoint(struct perf_evlist *evlist)
  14{
  15	struct perf_evsel *evsel = perf_evlist__first(evlist);
  16
  17	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  18	TEST_ASSERT_VAL("wrong number of groups", 0 == evlist->nr_groups);
  19	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
  20	TEST_ASSERT_VAL("wrong sample_type",
  21		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
  22	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
  23	return 0;
  24}
  25
  26static int test__checkevent_tracepoint_multi(struct perf_evlist *evlist)
  27{
  28	struct perf_evsel *evsel;
  29
  30	TEST_ASSERT_VAL("wrong number of entries", evlist->nr_entries > 1);
  31	TEST_ASSERT_VAL("wrong number of groups", 0 == evlist->nr_groups);
  32
  33	evlist__for_each(evlist, evsel) {
  34		TEST_ASSERT_VAL("wrong type",
  35			PERF_TYPE_TRACEPOINT == evsel->attr.type);
  36		TEST_ASSERT_VAL("wrong sample_type",
  37			PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
  38		TEST_ASSERT_VAL("wrong sample_period",
  39			1 == evsel->attr.sample_period);
  40	}
  41	return 0;
  42}
  43
  44static int test__checkevent_raw(struct perf_evlist *evlist)
  45{
  46	struct perf_evsel *evsel = perf_evlist__first(evlist);
  47
  48	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  49	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
  50	TEST_ASSERT_VAL("wrong config", 0x1a == evsel->attr.config);
  51	return 0;
  52}
  53
  54static int test__checkevent_numeric(struct perf_evlist *evlist)
  55{
  56	struct perf_evsel *evsel = perf_evlist__first(evlist);
  57
  58	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  59	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
  60	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
  61	return 0;
  62}
  63
  64static int test__checkevent_symbolic_name(struct perf_evlist *evlist)
  65{
  66	struct perf_evsel *evsel = perf_evlist__first(evlist);
  67
  68	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  69	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
  70	TEST_ASSERT_VAL("wrong config",
  71			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
  72	return 0;
  73}
  74
  75static int test__checkevent_symbolic_name_config(struct perf_evlist *evlist)
  76{
  77	struct perf_evsel *evsel = perf_evlist__first(evlist);
  78
  79	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  80	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
  81	TEST_ASSERT_VAL("wrong config",
  82			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 
 
 
 
  83	TEST_ASSERT_VAL("wrong period",
  84			100000 == evsel->attr.sample_period);
  85	TEST_ASSERT_VAL("wrong config1",
  86			0 == evsel->attr.config1);
  87	TEST_ASSERT_VAL("wrong config2",
  88			1 == evsel->attr.config2);
  89	return 0;
  90}
  91
  92static int test__checkevent_symbolic_alias(struct perf_evlist *evlist)
  93{
  94	struct perf_evsel *evsel = perf_evlist__first(evlist);
  95
  96	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
  97	TEST_ASSERT_VAL("wrong type", PERF_TYPE_SOFTWARE == evsel->attr.type);
  98	TEST_ASSERT_VAL("wrong config",
  99			PERF_COUNT_SW_PAGE_FAULTS == evsel->attr.config);
 100	return 0;
 101}
 102
 103static int test__checkevent_genhw(struct perf_evlist *evlist)
 104{
 105	struct perf_evsel *evsel = perf_evlist__first(evlist);
 106
 107	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 108	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HW_CACHE == evsel->attr.type);
 109	TEST_ASSERT_VAL("wrong config", (1 << 16) == evsel->attr.config);
 110	return 0;
 111}
 112
 113static int test__checkevent_breakpoint(struct perf_evlist *evlist)
 114{
 115	struct perf_evsel *evsel = perf_evlist__first(evlist);
 116
 117	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 118	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
 119	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 120	TEST_ASSERT_VAL("wrong bp_type", (HW_BREAKPOINT_R | HW_BREAKPOINT_W) ==
 121					 evsel->attr.bp_type);
 122	TEST_ASSERT_VAL("wrong bp_len", HW_BREAKPOINT_LEN_4 ==
 123					evsel->attr.bp_len);
 124	return 0;
 125}
 126
 127static int test__checkevent_breakpoint_x(struct perf_evlist *evlist)
 128{
 129	struct perf_evsel *evsel = perf_evlist__first(evlist);
 130
 131	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 132	TEST_ASSERT_VAL("wrong type", PERF_TYPE_BREAKPOINT == evsel->attr.type);
 133	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 134	TEST_ASSERT_VAL("wrong bp_type",
 135			HW_BREAKPOINT_X == evsel->attr.bp_type);
 136	TEST_ASSERT_VAL("wrong bp_len", sizeof(long) == evsel->attr.bp_len);
 137	return 0;
 138}
 139
 140static int test__checkevent_breakpoint_r(struct perf_evlist *evlist)
 141{
 142	struct perf_evsel *evsel = perf_evlist__first(evlist);
 143
 144	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 145	TEST_ASSERT_VAL("wrong type",
 146			PERF_TYPE_BREAKPOINT == evsel->attr.type);
 147	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 148	TEST_ASSERT_VAL("wrong bp_type",
 149			HW_BREAKPOINT_R == evsel->attr.bp_type);
 150	TEST_ASSERT_VAL("wrong bp_len",
 151			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
 152	return 0;
 153}
 154
 155static int test__checkevent_breakpoint_w(struct perf_evlist *evlist)
 156{
 157	struct perf_evsel *evsel = perf_evlist__first(evlist);
 158
 159	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 160	TEST_ASSERT_VAL("wrong type",
 161			PERF_TYPE_BREAKPOINT == evsel->attr.type);
 162	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 163	TEST_ASSERT_VAL("wrong bp_type",
 164			HW_BREAKPOINT_W == evsel->attr.bp_type);
 165	TEST_ASSERT_VAL("wrong bp_len",
 166			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
 167	return 0;
 168}
 169
 170static int test__checkevent_breakpoint_rw(struct perf_evlist *evlist)
 171{
 172	struct perf_evsel *evsel = perf_evlist__first(evlist);
 173
 174	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 175	TEST_ASSERT_VAL("wrong type",
 176			PERF_TYPE_BREAKPOINT == evsel->attr.type);
 177	TEST_ASSERT_VAL("wrong config", 0 == evsel->attr.config);
 178	TEST_ASSERT_VAL("wrong bp_type",
 179		(HW_BREAKPOINT_R|HW_BREAKPOINT_W) == evsel->attr.bp_type);
 180	TEST_ASSERT_VAL("wrong bp_len",
 181			HW_BREAKPOINT_LEN_4 == evsel->attr.bp_len);
 182	return 0;
 183}
 184
 185static int test__checkevent_tracepoint_modifier(struct perf_evlist *evlist)
 186{
 187	struct perf_evsel *evsel = perf_evlist__first(evlist);
 188
 189	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 190	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 191	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 192	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 193
 194	return test__checkevent_tracepoint(evlist);
 195}
 196
 197static int
 198test__checkevent_tracepoint_multi_modifier(struct perf_evlist *evlist)
 199{
 200	struct perf_evsel *evsel;
 201
 202	TEST_ASSERT_VAL("wrong number of entries", evlist->nr_entries > 1);
 203
 204	evlist__for_each(evlist, evsel) {
 205		TEST_ASSERT_VAL("wrong exclude_user",
 206				!evsel->attr.exclude_user);
 207		TEST_ASSERT_VAL("wrong exclude_kernel",
 208				evsel->attr.exclude_kernel);
 209		TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 210		TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 211	}
 212
 213	return test__checkevent_tracepoint_multi(evlist);
 214}
 215
 216static int test__checkevent_raw_modifier(struct perf_evlist *evlist)
 217{
 218	struct perf_evsel *evsel = perf_evlist__first(evlist);
 219
 220	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 221	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 222	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 223	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 224
 225	return test__checkevent_raw(evlist);
 226}
 227
 228static int test__checkevent_numeric_modifier(struct perf_evlist *evlist)
 229{
 230	struct perf_evsel *evsel = perf_evlist__first(evlist);
 231
 232	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 233	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 234	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 235	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 236
 237	return test__checkevent_numeric(evlist);
 238}
 239
 240static int test__checkevent_symbolic_name_modifier(struct perf_evlist *evlist)
 241{
 242	struct perf_evsel *evsel = perf_evlist__first(evlist);
 243
 244	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 245	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 246	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 247	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 248
 249	return test__checkevent_symbolic_name(evlist);
 250}
 251
 252static int test__checkevent_exclude_host_modifier(struct perf_evlist *evlist)
 253{
 254	struct perf_evsel *evsel = perf_evlist__first(evlist);
 255
 256	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 257	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 258
 259	return test__checkevent_symbolic_name(evlist);
 260}
 261
 262static int test__checkevent_exclude_guest_modifier(struct perf_evlist *evlist)
 263{
 264	struct perf_evsel *evsel = perf_evlist__first(evlist);
 265
 266	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 267	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 268
 269	return test__checkevent_symbolic_name(evlist);
 270}
 271
 272static int test__checkevent_symbolic_alias_modifier(struct perf_evlist *evlist)
 273{
 274	struct perf_evsel *evsel = perf_evlist__first(evlist);
 275
 276	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 277	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 278	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 279	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 280
 281	return test__checkevent_symbolic_alias(evlist);
 282}
 283
 284static int test__checkevent_genhw_modifier(struct perf_evlist *evlist)
 285{
 286	struct perf_evsel *evsel = perf_evlist__first(evlist);
 287
 288	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 289	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 290	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 291	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 292
 293	return test__checkevent_genhw(evlist);
 294}
 295
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 296static int test__checkevent_breakpoint_modifier(struct perf_evlist *evlist)
 297{
 298	struct perf_evsel *evsel = perf_evlist__first(evlist);
 299
 300
 301	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 302	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 303	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 304	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 305	TEST_ASSERT_VAL("wrong name",
 306			!strcmp(perf_evsel__name(evsel), "mem:0:u"));
 307
 308	return test__checkevent_breakpoint(evlist);
 309}
 310
 311static int test__checkevent_breakpoint_x_modifier(struct perf_evlist *evlist)
 312{
 313	struct perf_evsel *evsel = perf_evlist__first(evlist);
 314
 315	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 316	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 317	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 318	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 319	TEST_ASSERT_VAL("wrong name",
 320			!strcmp(perf_evsel__name(evsel), "mem:0:x:k"));
 321
 322	return test__checkevent_breakpoint_x(evlist);
 323}
 324
 325static int test__checkevent_breakpoint_r_modifier(struct perf_evlist *evlist)
 326{
 327	struct perf_evsel *evsel = perf_evlist__first(evlist);
 328
 329	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 330	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 331	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 332	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 333	TEST_ASSERT_VAL("wrong name",
 334			!strcmp(perf_evsel__name(evsel), "mem:0:r:hp"));
 335
 336	return test__checkevent_breakpoint_r(evlist);
 337}
 338
 339static int test__checkevent_breakpoint_w_modifier(struct perf_evlist *evlist)
 340{
 341	struct perf_evsel *evsel = perf_evlist__first(evlist);
 342
 343	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 344	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 345	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 346	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 347	TEST_ASSERT_VAL("wrong name",
 348			!strcmp(perf_evsel__name(evsel), "mem:0:w:up"));
 349
 350	return test__checkevent_breakpoint_w(evlist);
 351}
 352
 353static int test__checkevent_breakpoint_rw_modifier(struct perf_evlist *evlist)
 354{
 355	struct perf_evsel *evsel = perf_evlist__first(evlist);
 356
 357	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 358	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 359	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 360	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 361	TEST_ASSERT_VAL("wrong name",
 362			!strcmp(perf_evsel__name(evsel), "mem:0:rw:kp"));
 363
 364	return test__checkevent_breakpoint_rw(evlist);
 365}
 366
 367static int test__checkevent_pmu(struct perf_evlist *evlist)
 368{
 369
 370	struct perf_evsel *evsel = perf_evlist__first(evlist);
 371
 372	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 373	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 374	TEST_ASSERT_VAL("wrong config",    10 == evsel->attr.config);
 375	TEST_ASSERT_VAL("wrong config1",    1 == evsel->attr.config1);
 376	TEST_ASSERT_VAL("wrong config2",    3 == evsel->attr.config2);
 377	TEST_ASSERT_VAL("wrong period",  1000 == evsel->attr.sample_period);
 
 
 
 
 378
 379	return 0;
 380}
 381
 382static int test__checkevent_list(struct perf_evlist *evlist)
 383{
 384	struct perf_evsel *evsel = perf_evlist__first(evlist);
 385
 386	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
 387
 388	/* r1 */
 389	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 390	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
 391	TEST_ASSERT_VAL("wrong config1", 0 == evsel->attr.config1);
 392	TEST_ASSERT_VAL("wrong config2", 0 == evsel->attr.config2);
 393	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 394	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 395	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 396	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 397
 398	/* syscalls:sys_enter_open:k */
 399	evsel = perf_evsel__next(evsel);
 400	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
 401	TEST_ASSERT_VAL("wrong sample_type",
 402		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
 403	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
 404	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 405	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 406	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 407	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 408
 409	/* 1:1:hp */
 410	evsel = perf_evsel__next(evsel);
 411	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
 412	TEST_ASSERT_VAL("wrong config", 1 == evsel->attr.config);
 413	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 414	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 415	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 416	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
 417
 418	return 0;
 419}
 420
 421static int test__checkevent_pmu_name(struct perf_evlist *evlist)
 422{
 423	struct perf_evsel *evsel = perf_evlist__first(evlist);
 424
 425	/* cpu/config=1,name=krava/u */
 426	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 427	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 428	TEST_ASSERT_VAL("wrong config",  1 == evsel->attr.config);
 429	TEST_ASSERT_VAL("wrong name", !strcmp(perf_evsel__name(evsel), "krava"));
 430
 431	/* cpu/config=2/u" */
 432	evsel = perf_evsel__next(evsel);
 433	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 434	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 435	TEST_ASSERT_VAL("wrong config",  2 == evsel->attr.config);
 436	TEST_ASSERT_VAL("wrong name",
 437			!strcmp(perf_evsel__name(evsel), "cpu/config=2/u"));
 438
 439	return 0;
 440}
 441
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 442static int test__checkevent_pmu_events(struct perf_evlist *evlist)
 443{
 444	struct perf_evsel *evsel = perf_evlist__first(evlist);
 445
 446	TEST_ASSERT_VAL("wrong number of entries", 1 == evlist->nr_entries);
 447	TEST_ASSERT_VAL("wrong type", PERF_TYPE_RAW == evsel->attr.type);
 448	TEST_ASSERT_VAL("wrong exclude_user",
 449			!evsel->attr.exclude_user);
 450	TEST_ASSERT_VAL("wrong exclude_kernel",
 451			evsel->attr.exclude_kernel);
 452	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 453	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 454	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
 455
 456	return 0;
 457}
 458
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 459static int test__checkterms_simple(struct list_head *terms)
 460{
 461	struct parse_events_term *term;
 462
 463	/* config=10 */
 464	term = list_entry(terms->next, struct parse_events_term, list);
 465	TEST_ASSERT_VAL("wrong type term",
 466			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG);
 467	TEST_ASSERT_VAL("wrong type val",
 468			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
 469	TEST_ASSERT_VAL("wrong val", term->val.num == 10);
 470	TEST_ASSERT_VAL("wrong config", !term->config);
 471
 472	/* config1 */
 473	term = list_entry(term->list.next, struct parse_events_term, list);
 474	TEST_ASSERT_VAL("wrong type term",
 475			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG1);
 476	TEST_ASSERT_VAL("wrong type val",
 477			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
 478	TEST_ASSERT_VAL("wrong val", term->val.num == 1);
 479	TEST_ASSERT_VAL("wrong config", !term->config);
 480
 481	/* config2=3 */
 482	term = list_entry(term->list.next, struct parse_events_term, list);
 483	TEST_ASSERT_VAL("wrong type term",
 484			term->type_term == PARSE_EVENTS__TERM_TYPE_CONFIG2);
 485	TEST_ASSERT_VAL("wrong type val",
 486			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
 487	TEST_ASSERT_VAL("wrong val", term->val.num == 3);
 488	TEST_ASSERT_VAL("wrong config", !term->config);
 489
 490	/* umask=1*/
 491	term = list_entry(term->list.next, struct parse_events_term, list);
 492	TEST_ASSERT_VAL("wrong type term",
 493			term->type_term == PARSE_EVENTS__TERM_TYPE_USER);
 494	TEST_ASSERT_VAL("wrong type val",
 495			term->type_val == PARSE_EVENTS__TERM_TYPE_NUM);
 496	TEST_ASSERT_VAL("wrong val", term->val.num == 1);
 497	TEST_ASSERT_VAL("wrong config", !strcmp(term->config, "umask"));
 498
 499	return 0;
 500}
 501
 502static int test__group1(struct perf_evlist *evlist)
 503{
 504	struct perf_evsel *evsel, *leader;
 505
 506	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 507	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 508
 509	/* instructions:k */
 510	evsel = leader = perf_evlist__first(evlist);
 511	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 512	TEST_ASSERT_VAL("wrong config",
 513			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 514	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 515	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 516	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 517	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 518	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 519	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 520	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 521	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 522	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 523	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 524
 525	/* cycles:upp */
 526	evsel = perf_evsel__next(evsel);
 527	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 528	TEST_ASSERT_VAL("wrong config",
 529			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 530	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 531	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 532	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 533	/* use of precise requires exclude_guest */
 534	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 535	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 536	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 2);
 537	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 538	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 539	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 540
 541	return 0;
 542}
 543
 544static int test__group2(struct perf_evlist *evlist)
 545{
 546	struct perf_evsel *evsel, *leader;
 547
 548	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
 549	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 550
 551	/* faults + :ku modifier */
 552	evsel = leader = perf_evlist__first(evlist);
 553	TEST_ASSERT_VAL("wrong type", PERF_TYPE_SOFTWARE == evsel->attr.type);
 554	TEST_ASSERT_VAL("wrong config",
 555			PERF_COUNT_SW_PAGE_FAULTS == evsel->attr.config);
 556	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 557	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 558	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 559	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 560	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 561	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 562	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 563	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 564	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 565	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 566
 567	/* cache-references + :u modifier */
 568	evsel = perf_evsel__next(evsel);
 569	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 570	TEST_ASSERT_VAL("wrong config",
 571			PERF_COUNT_HW_CACHE_REFERENCES == evsel->attr.config);
 572	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 573	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 574	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 575	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 576	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 577	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 578	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 579	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 580	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 581
 582	/* cycles:k */
 583	evsel = perf_evsel__next(evsel);
 584	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 585	TEST_ASSERT_VAL("wrong config",
 586			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 587	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 588	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 589	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 590	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 591	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 592	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 593	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 594	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 595
 596	return 0;
 597}
 598
 599static int test__group3(struct perf_evlist *evlist __maybe_unused)
 600{
 601	struct perf_evsel *evsel, *leader;
 602
 603	TEST_ASSERT_VAL("wrong number of entries", 5 == evlist->nr_entries);
 604	TEST_ASSERT_VAL("wrong number of groups", 2 == evlist->nr_groups);
 605
 606	/* group1 syscalls:sys_enter_open:H */
 607	evsel = leader = perf_evlist__first(evlist);
 608	TEST_ASSERT_VAL("wrong type", PERF_TYPE_TRACEPOINT == evsel->attr.type);
 609	TEST_ASSERT_VAL("wrong sample_type",
 610		PERF_TP_SAMPLE_TYPE == evsel->attr.sample_type);
 611	TEST_ASSERT_VAL("wrong sample_period", 1 == evsel->attr.sample_period);
 612	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 613	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 614	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 615	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 616	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 617	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 618	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 619	TEST_ASSERT_VAL("wrong group name",
 620		!strcmp(leader->group_name, "group1"));
 621	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 622	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 623	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 624
 625	/* group1 cycles:kppp */
 626	evsel = perf_evsel__next(evsel);
 627	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 628	TEST_ASSERT_VAL("wrong config",
 629			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 630	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 631	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 632	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 633	/* use of precise requires exclude_guest */
 634	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 635	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 636	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 3);
 637	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 638	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 639	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 640	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 641
 642	/* group2 cycles + G modifier */
 643	evsel = leader = perf_evsel__next(evsel);
 644	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 645	TEST_ASSERT_VAL("wrong config",
 646			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 647	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 648	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 649	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 650	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 651	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 652	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 653	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 654	TEST_ASSERT_VAL("wrong group name",
 655		!strcmp(leader->group_name, "group2"));
 656	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 657	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 658	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 659
 660	/* group2 1:3 + G modifier */
 661	evsel = perf_evsel__next(evsel);
 662	TEST_ASSERT_VAL("wrong type", 1 == evsel->attr.type);
 663	TEST_ASSERT_VAL("wrong config", 3 == evsel->attr.config);
 664	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 665	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 666	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 667	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 668	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 669	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 670	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 671	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 672	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 673
 674	/* instructions:u */
 675	evsel = perf_evsel__next(evsel);
 676	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 677	TEST_ASSERT_VAL("wrong config",
 678			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 679	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 680	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 681	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 682	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 683	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 684	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 685	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 686	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 687
 688	return 0;
 689}
 690
 691static int test__group4(struct perf_evlist *evlist __maybe_unused)
 692{
 693	struct perf_evsel *evsel, *leader;
 694
 695	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 696	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 697
 698	/* cycles:u + p */
 699	evsel = leader = perf_evlist__first(evlist);
 700	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 701	TEST_ASSERT_VAL("wrong config",
 702			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 703	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 704	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 705	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 706	/* use of precise requires exclude_guest */
 707	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 708	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 709	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 1);
 710	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 711	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 712	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 713	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 714	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 715
 716	/* instructions:kp + p */
 717	evsel = perf_evsel__next(evsel);
 718	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 719	TEST_ASSERT_VAL("wrong config",
 720			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 721	TEST_ASSERT_VAL("wrong exclude_user", evsel->attr.exclude_user);
 722	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 723	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 724	/* use of precise requires exclude_guest */
 725	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 726	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 727	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip == 2);
 728	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 729	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 730	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 731
 732	return 0;
 733}
 734
 735static int test__group5(struct perf_evlist *evlist __maybe_unused)
 736{
 737	struct perf_evsel *evsel, *leader;
 738
 739	TEST_ASSERT_VAL("wrong number of entries", 5 == evlist->nr_entries);
 740	TEST_ASSERT_VAL("wrong number of groups", 2 == evlist->nr_groups);
 741
 742	/* cycles + G */
 743	evsel = leader = perf_evlist__first(evlist);
 744	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 745	TEST_ASSERT_VAL("wrong config",
 746			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 747	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 748	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 749	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 750	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 751	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 752	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 753	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 754	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 755	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 756	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 757	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 758
 759	/* instructions + G */
 760	evsel = perf_evsel__next(evsel);
 761	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 762	TEST_ASSERT_VAL("wrong config",
 763			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 764	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 765	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 766	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 767	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 768	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 769	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 770	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 771	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 772	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 773
 774	/* cycles:G */
 775	evsel = leader = perf_evsel__next(evsel);
 776	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 777	TEST_ASSERT_VAL("wrong config",
 778			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 779	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 780	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 781	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 782	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 783	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 784	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 785	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 786	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 787	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 788	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 789	TEST_ASSERT_VAL("wrong sample_read", !evsel->sample_read);
 790
 791	/* instructions:G */
 792	evsel = perf_evsel__next(evsel);
 793	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 794	TEST_ASSERT_VAL("wrong config",
 795			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
 796	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 797	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 798	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 799	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 800	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 801	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 802	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 803	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 804
 805	/* cycles */
 806	evsel = perf_evsel__next(evsel);
 807	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 808	TEST_ASSERT_VAL("wrong config",
 809			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 810	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 811	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 812	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 813	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 814	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 815	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 816	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 817
 818	return 0;
 819}
 820
 821static int test__group_gh1(struct perf_evlist *evlist)
 822{
 823	struct perf_evsel *evsel, *leader;
 824
 825	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 826	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 827
 828	/* cycles + :H group modifier */
 829	evsel = leader = perf_evlist__first(evlist);
 830	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 831	TEST_ASSERT_VAL("wrong config",
 832			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 833	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 834	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 835	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 836	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 837	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 838	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 839	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 840	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 841	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 842	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 843
 844	/* cache-misses:G + :H group modifier */
 845	evsel = perf_evsel__next(evsel);
 846	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 847	TEST_ASSERT_VAL("wrong config",
 848			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
 849	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 850	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 851	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 852	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 853	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 854	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 855	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 856	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 857
 858	return 0;
 859}
 860
 861static int test__group_gh2(struct perf_evlist *evlist)
 862{
 863	struct perf_evsel *evsel, *leader;
 864
 865	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 866	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 867
 868	/* cycles + :G group modifier */
 869	evsel = leader = perf_evlist__first(evlist);
 870	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 871	TEST_ASSERT_VAL("wrong config",
 872			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 873	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 874	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 875	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 876	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 877	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 878	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 879	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 880	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 881	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 882	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 883
 884	/* cache-misses:H + :G group modifier */
 885	evsel = perf_evsel__next(evsel);
 886	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 887	TEST_ASSERT_VAL("wrong config",
 888			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
 889	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 890	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 891	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 892	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 893	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 894	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 895	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 896	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 897
 898	return 0;
 899}
 900
 901static int test__group_gh3(struct perf_evlist *evlist)
 902{
 903	struct perf_evsel *evsel, *leader;
 904
 905	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 906	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 907
 908	/* cycles:G + :u group modifier */
 909	evsel = leader = perf_evlist__first(evlist);
 910	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 911	TEST_ASSERT_VAL("wrong config",
 912			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 913	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 914	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 915	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 916	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 917	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 918	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 919	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 920	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 921	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 922	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 923
 924	/* cache-misses:H + :u group modifier */
 925	evsel = perf_evsel__next(evsel);
 926	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 927	TEST_ASSERT_VAL("wrong config",
 928			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
 929	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 930	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 931	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 932	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 933	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 934	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 935	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 936	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 937
 938	return 0;
 939}
 940
 941static int test__group_gh4(struct perf_evlist *evlist)
 942{
 943	struct perf_evsel *evsel, *leader;
 944
 945	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
 946	TEST_ASSERT_VAL("wrong number of groups", 1 == evlist->nr_groups);
 947
 948	/* cycles:G + :uG group modifier */
 949	evsel = leader = perf_evlist__first(evlist);
 950	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 951	TEST_ASSERT_VAL("wrong config",
 952			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 953	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 954	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 955	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 956	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 957	TEST_ASSERT_VAL("wrong exclude host", evsel->attr.exclude_host);
 958	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 959	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 960	TEST_ASSERT_VAL("wrong leader", perf_evsel__is_group_leader(evsel));
 961	TEST_ASSERT_VAL("wrong nr_members", evsel->nr_members == 2);
 962	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 0);
 963
 964	/* cache-misses:H + :uG group modifier */
 965	evsel = perf_evsel__next(evsel);
 966	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 967	TEST_ASSERT_VAL("wrong config",
 968			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
 969	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 970	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
 971	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
 972	TEST_ASSERT_VAL("wrong exclude guest", !evsel->attr.exclude_guest);
 973	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 974	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 975	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
 976	TEST_ASSERT_VAL("wrong group_idx", perf_evsel__group_idx(evsel) == 1);
 977
 978	return 0;
 979}
 980
 981static int test__leader_sample1(struct perf_evlist *evlist)
 982{
 983	struct perf_evsel *evsel, *leader;
 984
 985	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
 986
 987	/* cycles - sampling group leader */
 988	evsel = leader = perf_evlist__first(evlist);
 989	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
 990	TEST_ASSERT_VAL("wrong config",
 991			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
 992	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
 993	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
 994	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
 995	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
 996	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
 997	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
 998	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
 999	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1000	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1001
1002	/* cache-misses - not sampling */
1003	evsel = perf_evsel__next(evsel);
1004	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1005	TEST_ASSERT_VAL("wrong config",
1006			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
1007	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1008	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
1009	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
1010	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1011	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1012	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1013	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1014	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1015
1016	/* branch-misses - not sampling */
1017	evsel = perf_evsel__next(evsel);
1018	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1019	TEST_ASSERT_VAL("wrong config",
1020			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1021	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1022	TEST_ASSERT_VAL("wrong exclude_kernel", !evsel->attr.exclude_kernel);
1023	TEST_ASSERT_VAL("wrong exclude_hv", !evsel->attr.exclude_hv);
1024	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1025	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1026	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1027	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1028	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1029	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1030
1031	return 0;
1032}
1033
1034static int test__leader_sample2(struct perf_evlist *evlist __maybe_unused)
1035{
1036	struct perf_evsel *evsel, *leader;
1037
1038	TEST_ASSERT_VAL("wrong number of entries", 2 == evlist->nr_entries);
1039
1040	/* instructions - sampling group leader */
1041	evsel = leader = perf_evlist__first(evlist);
1042	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1043	TEST_ASSERT_VAL("wrong config",
1044			PERF_COUNT_HW_INSTRUCTIONS == evsel->attr.config);
1045	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1046	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1047	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1048	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1049	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1050	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1051	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1052	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1053	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1054
1055	/* branch-misses - not sampling */
1056	evsel = perf_evsel__next(evsel);
1057	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1058	TEST_ASSERT_VAL("wrong config",
1059			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1060	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1061	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1062	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1063	TEST_ASSERT_VAL("wrong exclude guest", evsel->attr.exclude_guest);
1064	TEST_ASSERT_VAL("wrong exclude host", !evsel->attr.exclude_host);
1065	TEST_ASSERT_VAL("wrong precise_ip", !evsel->attr.precise_ip);
1066	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1067	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1068	TEST_ASSERT_VAL("wrong sample_read", evsel->sample_read);
1069
1070	return 0;
1071}
1072
1073static int test__checkevent_pinned_modifier(struct perf_evlist *evlist)
1074{
1075	struct perf_evsel *evsel = perf_evlist__first(evlist);
1076
1077	TEST_ASSERT_VAL("wrong exclude_user", !evsel->attr.exclude_user);
1078	TEST_ASSERT_VAL("wrong exclude_kernel", evsel->attr.exclude_kernel);
1079	TEST_ASSERT_VAL("wrong exclude_hv", evsel->attr.exclude_hv);
1080	TEST_ASSERT_VAL("wrong precise_ip", evsel->attr.precise_ip);
1081	TEST_ASSERT_VAL("wrong pinned", evsel->attr.pinned);
1082
1083	return test__checkevent_symbolic_name(evlist);
1084}
1085
1086static int test__pinned_group(struct perf_evlist *evlist)
1087{
1088	struct perf_evsel *evsel, *leader;
1089
1090	TEST_ASSERT_VAL("wrong number of entries", 3 == evlist->nr_entries);
1091
1092	/* cycles - group leader */
1093	evsel = leader = perf_evlist__first(evlist);
1094	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1095	TEST_ASSERT_VAL("wrong config",
1096			PERF_COUNT_HW_CPU_CYCLES == evsel->attr.config);
1097	TEST_ASSERT_VAL("wrong group name", !evsel->group_name);
1098	TEST_ASSERT_VAL("wrong leader", evsel->leader == leader);
1099	TEST_ASSERT_VAL("wrong pinned", evsel->attr.pinned);
1100
1101	/* cache-misses - can not be pinned, but will go on with the leader */
1102	evsel = perf_evsel__next(evsel);
1103	TEST_ASSERT_VAL("wrong type", PERF_TYPE_HARDWARE == evsel->attr.type);
1104	TEST_ASSERT_VAL("wrong config",
1105			PERF_COUNT_HW_CACHE_MISSES == evsel->attr.config);
1106	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
1107
1108	/* branch-misses - ditto */
1109	evsel = perf_evsel__next(evsel);
1110	TEST_ASSERT_VAL("wrong config",
1111			PERF_COUNT_HW_BRANCH_MISSES == evsel->attr.config);
1112	TEST_ASSERT_VAL("wrong pinned", !evsel->attr.pinned);
1113
1114	return 0;
1115}
1116
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1117static int count_tracepoints(void)
1118{
1119	char events_path[PATH_MAX];
1120	struct dirent *events_ent;
1121	DIR *events_dir;
1122	int cnt = 0;
1123
1124	scnprintf(events_path, PATH_MAX, "%s/tracing/events",
1125		  debugfs_find_mountpoint());
1126
1127	events_dir = opendir(events_path);
1128
1129	TEST_ASSERT_VAL("Can't open events dir", events_dir);
1130
1131	while ((events_ent = readdir(events_dir))) {
1132		char sys_path[PATH_MAX];
1133		struct dirent *sys_ent;
1134		DIR *sys_dir;
1135
1136		if (!strcmp(events_ent->d_name, ".")
1137		    || !strcmp(events_ent->d_name, "..")
1138		    || !strcmp(events_ent->d_name, "enable")
1139		    || !strcmp(events_ent->d_name, "header_event")
1140		    || !strcmp(events_ent->d_name, "header_page"))
1141			continue;
1142
1143		scnprintf(sys_path, PATH_MAX, "%s/%s",
1144			  events_path, events_ent->d_name);
1145
1146		sys_dir = opendir(sys_path);
1147		TEST_ASSERT_VAL("Can't open sys dir", sys_dir);
1148
1149		while ((sys_ent = readdir(sys_dir))) {
1150			if (!strcmp(sys_ent->d_name, ".")
1151			    || !strcmp(sys_ent->d_name, "..")
1152			    || !strcmp(sys_ent->d_name, "enable")
1153			    || !strcmp(sys_ent->d_name, "filter"))
1154				continue;
1155
1156			cnt++;
1157		}
1158
1159		closedir(sys_dir);
1160	}
1161
1162	closedir(events_dir);
1163	return cnt;
1164}
1165
1166static int test__all_tracepoints(struct perf_evlist *evlist)
1167{
1168	TEST_ASSERT_VAL("wrong events count",
1169			count_tracepoints() == evlist->nr_entries);
1170
1171	return test__checkevent_tracepoint_multi(evlist);
1172}
1173
1174struct evlist_test {
1175	const char *name;
1176	__u32 type;
 
1177	int (*check)(struct perf_evlist *evlist);
1178};
1179
1180static struct evlist_test test__events[] = {
1181	[0] = {
1182		.name  = "syscalls:sys_enter_open",
1183		.check = test__checkevent_tracepoint,
 
1184	},
1185	[1] = {
1186		.name  = "syscalls:*",
1187		.check = test__checkevent_tracepoint_multi,
 
1188	},
1189	[2] = {
1190		.name  = "r1a",
1191		.check = test__checkevent_raw,
 
1192	},
1193	[3] = {
1194		.name  = "1:1",
1195		.check = test__checkevent_numeric,
 
1196	},
1197	[4] = {
1198		.name  = "instructions",
1199		.check = test__checkevent_symbolic_name,
 
1200	},
1201	[5] = {
1202		.name  = "cycles/period=100000,config2/",
1203		.check = test__checkevent_symbolic_name_config,
 
1204	},
1205	[6] = {
1206		.name  = "faults",
1207		.check = test__checkevent_symbolic_alias,
 
1208	},
1209	[7] = {
1210		.name  = "L1-dcache-load-miss",
1211		.check = test__checkevent_genhw,
 
1212	},
1213	[8] = {
1214		.name  = "mem:0",
1215		.check = test__checkevent_breakpoint,
 
1216	},
1217	[9] = {
1218		.name  = "mem:0:x",
1219		.check = test__checkevent_breakpoint_x,
 
1220	},
1221	[10] = {
1222		.name  = "mem:0:r",
1223		.check = test__checkevent_breakpoint_r,
 
1224	},
1225	[11] = {
1226		.name  = "mem:0:w",
1227		.check = test__checkevent_breakpoint_w,
 
1228	},
1229	[12] = {
1230		.name  = "syscalls:sys_enter_open:k",
1231		.check = test__checkevent_tracepoint_modifier,
 
1232	},
1233	[13] = {
1234		.name  = "syscalls:*:u",
1235		.check = test__checkevent_tracepoint_multi_modifier,
 
1236	},
1237	[14] = {
1238		.name  = "r1a:kp",
1239		.check = test__checkevent_raw_modifier,
 
1240	},
1241	[15] = {
1242		.name  = "1:1:hp",
1243		.check = test__checkevent_numeric_modifier,
 
1244	},
1245	[16] = {
1246		.name  = "instructions:h",
1247		.check = test__checkevent_symbolic_name_modifier,
 
1248	},
1249	[17] = {
1250		.name  = "faults:u",
1251		.check = test__checkevent_symbolic_alias_modifier,
 
1252	},
1253	[18] = {
1254		.name  = "L1-dcache-load-miss:kp",
1255		.check = test__checkevent_genhw_modifier,
 
1256	},
1257	[19] = {
1258		.name  = "mem:0:u",
1259		.check = test__checkevent_breakpoint_modifier,
 
1260	},
1261	[20] = {
1262		.name  = "mem:0:x:k",
1263		.check = test__checkevent_breakpoint_x_modifier,
 
1264	},
1265	[21] = {
1266		.name  = "mem:0:r:hp",
1267		.check = test__checkevent_breakpoint_r_modifier,
 
1268	},
1269	[22] = {
1270		.name  = "mem:0:w:up",
1271		.check = test__checkevent_breakpoint_w_modifier,
 
1272	},
1273	[23] = {
1274		.name  = "r1,syscalls:sys_enter_open:k,1:1:hp",
1275		.check = test__checkevent_list,
 
1276	},
1277	[24] = {
1278		.name  = "instructions:G",
1279		.check = test__checkevent_exclude_host_modifier,
 
1280	},
1281	[25] = {
1282		.name  = "instructions:H",
1283		.check = test__checkevent_exclude_guest_modifier,
 
1284	},
1285	[26] = {
1286		.name  = "mem:0:rw",
1287		.check = test__checkevent_breakpoint_rw,
 
1288	},
1289	[27] = {
1290		.name  = "mem:0:rw:kp",
1291		.check = test__checkevent_breakpoint_rw_modifier,
 
1292	},
1293	[28] = {
1294		.name  = "{instructions:k,cycles:upp}",
1295		.check = test__group1,
 
1296	},
1297	[29] = {
1298		.name  = "{faults:k,cache-references}:u,cycles:k",
1299		.check = test__group2,
 
1300	},
1301	[30] = {
1302		.name  = "group1{syscalls:sys_enter_open:H,cycles:kppp},group2{cycles,1:3}:G,instructions:u",
1303		.check = test__group3,
 
1304	},
1305	[31] = {
1306		.name  = "{cycles:u,instructions:kp}:p",
1307		.check = test__group4,
 
1308	},
1309	[32] = {
1310		.name  = "{cycles,instructions}:G,{cycles:G,instructions:G},cycles",
1311		.check = test__group5,
 
1312	},
1313	[33] = {
1314		.name  = "*:*",
1315		.check = test__all_tracepoints,
 
1316	},
1317	[34] = {
1318		.name  = "{cycles,cache-misses:G}:H",
1319		.check = test__group_gh1,
 
1320	},
1321	[35] = {
1322		.name  = "{cycles,cache-misses:H}:G",
1323		.check = test__group_gh2,
 
1324	},
1325	[36] = {
1326		.name  = "{cycles:G,cache-misses:H}:u",
1327		.check = test__group_gh3,
 
1328	},
1329	[37] = {
1330		.name  = "{cycles:G,cache-misses:H}:uG",
1331		.check = test__group_gh4,
 
1332	},
1333	[38] = {
1334		.name  = "{cycles,cache-misses,branch-misses}:S",
1335		.check = test__leader_sample1,
 
1336	},
1337	[39] = {
1338		.name  = "{instructions,branch-misses}:Su",
1339		.check = test__leader_sample2,
 
1340	},
1341	[40] = {
1342		.name  = "instructions:uDp",
1343		.check = test__checkevent_pinned_modifier,
 
1344	},
1345	[41] = {
1346		.name  = "{cycles,cache-misses,branch-misses}:D",
1347		.check = test__pinned_group,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1348	},
1349};
1350
1351static struct evlist_test test__events_pmu[] = {
1352	[0] = {
1353		.name  = "cpu/config=10,config1,config2=3,period=1000/u",
1354		.check = test__checkevent_pmu,
 
1355	},
1356	[1] = {
1357		.name  = "cpu/config=1,name=krava/u,cpu/config=2/u",
1358		.check = test__checkevent_pmu_name,
 
 
 
 
 
 
1359	},
1360};
1361
1362struct terms_test {
1363	const char *str;
1364	__u32 type;
1365	int (*check)(struct list_head *terms);
1366};
1367
1368static struct terms_test test__terms[] = {
1369	[0] = {
1370		.str   = "config=10,config1,config2=3,umask=1",
1371		.check = test__checkterms_simple,
1372	},
1373};
1374
1375static int test_event(struct evlist_test *e)
1376{
1377	struct perf_evlist *evlist;
1378	int ret;
1379
1380	evlist = perf_evlist__new();
1381	if (evlist == NULL)
1382		return -ENOMEM;
1383
1384	ret = parse_events(evlist, e->name);
1385	if (ret) {
1386		pr_debug("failed to parse event '%s', err %d\n",
1387			 e->name, ret);
1388	} else {
1389		ret = e->check(evlist);
1390	}
1391	
1392	perf_evlist__delete(evlist);
1393
1394	return ret;
1395}
1396
1397static int test_events(struct evlist_test *events, unsigned cnt)
1398{
1399	int ret1, ret2 = 0;
1400	unsigned i;
1401
1402	for (i = 0; i < cnt; i++) {
1403		struct evlist_test *e = &events[i];
1404
1405		pr_debug("running test %d '%s'\n", i, e->name);
1406		ret1 = test_event(e);
1407		if (ret1)
1408			ret2 = ret1;
1409	}
1410
1411	return ret2;
1412}
1413
1414static int test_term(struct terms_test *t)
1415{
1416	struct list_head terms;
1417	int ret;
1418
1419	INIT_LIST_HEAD(&terms);
1420
1421	ret = parse_events_terms(&terms, t->str);
1422	if (ret) {
1423		pr_debug("failed to parse terms '%s', err %d\n",
1424			 t->str , ret);
1425		return ret;
1426	}
1427
1428	ret = t->check(&terms);
1429	parse_events__free_terms(&terms);
1430
1431	return ret;
1432}
1433
1434static int test_terms(struct terms_test *terms, unsigned cnt)
1435{
1436	int ret = 0;
1437	unsigned i;
1438
1439	for (i = 0; i < cnt; i++) {
1440		struct terms_test *t = &terms[i];
1441
1442		pr_debug("running test %d '%s'\n", i, t->str);
1443		ret = test_term(t);
1444		if (ret)
1445			break;
1446	}
1447
1448	return ret;
1449}
1450
1451static int test_pmu(void)
1452{
1453	struct stat st;
1454	char path[PATH_MAX];
1455	int ret;
1456
1457	snprintf(path, PATH_MAX, "%s/bus/event_source/devices/cpu/format/",
1458		 sysfs__mountpoint());
1459
1460	ret = stat(path, &st);
1461	if (ret)
1462		pr_debug("omitting PMU cpu tests\n");
1463	return !ret;
1464}
1465
1466static int test_pmu_events(void)
1467{
1468	struct stat st;
1469	char path[PATH_MAX];
1470	struct dirent *ent;
1471	DIR *dir;
1472	int ret;
1473
1474	snprintf(path, PATH_MAX, "%s/bus/event_source/devices/cpu/events/",
1475		 sysfs__mountpoint());
1476
1477	ret = stat(path, &st);
1478	if (ret) {
1479		pr_debug("omitting PMU cpu events tests\n");
1480		return 0;
1481	}
1482
1483	dir = opendir(path);
1484	if (!dir) {
1485		pr_debug("can't open pmu event dir");
1486		return -1;
1487	}
1488
1489	while (!ret && (ent = readdir(dir))) {
1490#define MAX_NAME 100
1491		struct evlist_test e;
1492		char name[MAX_NAME];
1493
1494		if (!strcmp(ent->d_name, ".") ||
1495		    !strcmp(ent->d_name, ".."))
1496			continue;
1497
1498		snprintf(name, MAX_NAME, "cpu/event=%s/u", ent->d_name);
1499
1500		e.name  = name;
1501		e.check = test__checkevent_pmu_events;
1502
1503		ret = test_event(&e);
 
 
 
 
 
 
1504#undef MAX_NAME
1505	}
1506
1507	closedir(dir);
1508	return ret;
1509}
1510
1511int test__parse_events(void)
 
 
 
 
 
 
 
 
 
 
 
1512{
1513	int ret1, ret2 = 0;
1514
1515#define TEST_EVENTS(tests)				\
1516do {							\
1517	ret1 = test_events(tests, ARRAY_SIZE(tests));	\
1518	if (!ret2)					\
1519		ret2 = ret1;				\
1520} while (0)
 
 
1521
1522	TEST_EVENTS(test__events);
1523
1524	if (test_pmu())
1525		TEST_EVENTS(test__events_pmu);
1526
1527	if (test_pmu()) {
1528		int ret = test_pmu_events();
1529		if (ret)
1530			return ret;
1531	}
1532
1533	ret1 = test_terms(test__terms, ARRAY_SIZE(test__terms));
1534	if (!ret2)
1535		ret2 = ret1;
1536
1537	return ret2;
1538}