xref: /linux/tools/perf/arch/x86/tests/amd-ibs-via-core-pmu.c (revision cdd5b5a9761fd66d17586e4f4ba6588c70e640ea)
178075d94SRavi Bangoria // SPDX-License-Identifier: GPL-2.0
278075d94SRavi Bangoria #include "arch-tests.h"
378075d94SRavi Bangoria #include "linux/perf_event.h"
478075d94SRavi Bangoria #include "tests/tests.h"
578075d94SRavi Bangoria #include "pmu.h"
678075d94SRavi Bangoria #include "pmus.h"
778075d94SRavi Bangoria #include "../perf-sys.h"
878075d94SRavi Bangoria #include "debug.h"
978075d94SRavi Bangoria 
1078075d94SRavi Bangoria #define NR_SUB_TESTS 5
1178075d94SRavi Bangoria 
1278075d94SRavi Bangoria static struct sub_tests {
1378075d94SRavi Bangoria 	int type;
1478075d94SRavi Bangoria 	unsigned long config;
1578075d94SRavi Bangoria 	bool valid;
1678075d94SRavi Bangoria } sub_tests[NR_SUB_TESTS] = {
1778075d94SRavi Bangoria 	{ PERF_TYPE_HARDWARE, PERF_COUNT_HW_CPU_CYCLES, true },
1878075d94SRavi Bangoria 	{ PERF_TYPE_HARDWARE, PERF_COUNT_HW_INSTRUCTIONS, false },
1978075d94SRavi Bangoria 	{ PERF_TYPE_RAW, 0x076, true },
2078075d94SRavi Bangoria 	{ PERF_TYPE_RAW, 0x0C1, true },
2178075d94SRavi Bangoria 	{ PERF_TYPE_RAW, 0x012, false },
2278075d94SRavi Bangoria };
2378075d94SRavi Bangoria 
event_open(int type,unsigned long config)2478075d94SRavi Bangoria static int event_open(int type, unsigned long config)
2578075d94SRavi Bangoria {
2678075d94SRavi Bangoria 	struct perf_event_attr attr;
2778075d94SRavi Bangoria 
2878075d94SRavi Bangoria 	memset(&attr, 0, sizeof(struct perf_event_attr));
2978075d94SRavi Bangoria 	attr.type = type;
3078075d94SRavi Bangoria 	attr.size = sizeof(struct perf_event_attr);
3178075d94SRavi Bangoria 	attr.config = config;
3278075d94SRavi Bangoria 	attr.disabled = 1;
3378075d94SRavi Bangoria 	attr.precise_ip = 1;
3478075d94SRavi Bangoria 	attr.sample_type = PERF_SAMPLE_IP | PERF_SAMPLE_TID;
3578075d94SRavi Bangoria 	attr.sample_period = 100000;
3678075d94SRavi Bangoria 
3778075d94SRavi Bangoria 	return sys_perf_event_open(&attr, -1, 0, -1, 0);
3878075d94SRavi Bangoria }
3978075d94SRavi Bangoria 
test__amd_ibs_via_core_pmu(struct test_suite * test __maybe_unused,int subtest __maybe_unused)4078075d94SRavi Bangoria int test__amd_ibs_via_core_pmu(struct test_suite *test __maybe_unused,
4178075d94SRavi Bangoria 			       int subtest __maybe_unused)
4278075d94SRavi Bangoria {
4378075d94SRavi Bangoria 	struct perf_pmu *ibs_pmu;
4478075d94SRavi Bangoria 	int ret = TEST_OK;
4578075d94SRavi Bangoria 	int fd, i;
4678075d94SRavi Bangoria 
47b30d7a77SLinus Torvalds 	ibs_pmu = perf_pmus__find("ibs_op");
4878075d94SRavi Bangoria 	if (!ibs_pmu)
4978075d94SRavi Bangoria 		return TEST_SKIP;
5078075d94SRavi Bangoria 
5178075d94SRavi Bangoria 	for (i = 0; i < NR_SUB_TESTS; i++) {
5278075d94SRavi Bangoria 		fd = event_open(sub_tests[i].type, sub_tests[i].config);
5378075d94SRavi Bangoria 		pr_debug("type: 0x%x, config: 0x%lx, fd: %d  -  ", sub_tests[i].type,
5478075d94SRavi Bangoria 			 sub_tests[i].config, fd);
5578075d94SRavi Bangoria 		if ((sub_tests[i].valid && fd == -1) ||
5678075d94SRavi Bangoria 		    (!sub_tests[i].valid && fd > 0)) {
5778075d94SRavi Bangoria 			pr_debug("Fail\n");
5878075d94SRavi Bangoria 			ret = TEST_FAIL;
5978075d94SRavi Bangoria 		} else {
6078075d94SRavi Bangoria 			pr_debug("Pass\n");
6178075d94SRavi Bangoria 		}
6278075d94SRavi Bangoria 
6378075d94SRavi Bangoria 		if (fd > 0)
6478075d94SRavi Bangoria 			close(fd);
6578075d94SRavi Bangoria 	}
6678075d94SRavi Bangoria 
6778075d94SRavi Bangoria 	return ret;
6878075d94SRavi Bangoria }
69