1*eb7aa044SAthira Rajeev // SPDX-License-Identifier: GPL-2.0-only
2*eb7aa044SAthira Rajeev /*
3*eb7aa044SAthira Rajeev  * Copyright 2022, Athira Rajeev, IBM Corp.
4*eb7aa044SAthira Rajeev  */
5*eb7aa044SAthira Rajeev 
6*eb7aa044SAthira Rajeev #include <stdio.h>
7*eb7aa044SAthira Rajeev #include <stdlib.h>
8*eb7aa044SAthira Rajeev 
9*eb7aa044SAthira Rajeev #include "../event.h"
10*eb7aa044SAthira Rajeev #include "misc.h"
11*eb7aa044SAthira Rajeev #include "utils.h"
12*eb7aa044SAthira Rajeev 
13*eb7aa044SAthira Rajeev extern void thirty_two_instruction_loop(int loops);
14*eb7aa044SAthira Rajeev 
15*eb7aa044SAthira Rajeev /*
16*eb7aa044SAthira Rajeev  * A perf sampling test for mmcr0
17*eb7aa044SAthira Rajeev  * fields : pmae, pmao.
18*eb7aa044SAthira Rajeev  */
mmcr0_exceptionbits(void)19*eb7aa044SAthira Rajeev static int mmcr0_exceptionbits(void)
20*eb7aa044SAthira Rajeev {
21*eb7aa044SAthira Rajeev 	struct event event;
22*eb7aa044SAthira Rajeev 	u64 *intr_regs;
23*eb7aa044SAthira Rajeev 
24*eb7aa044SAthira Rajeev 	/* Check for platform support for the test */
25*eb7aa044SAthira Rajeev 	SKIP_IF(check_pvr_for_sampling_tests());
26*eb7aa044SAthira Rajeev 
27*eb7aa044SAthira Rajeev 	/* Init the event for the sampling test */
28*eb7aa044SAthira Rajeev 	event_init_sampling(&event, 0x500fa);
29*eb7aa044SAthira Rajeev 	event.attr.sample_regs_intr = platform_extended_mask;
30*eb7aa044SAthira Rajeev 	FAIL_IF(event_open(&event));
31*eb7aa044SAthira Rajeev 	event.mmap_buffer = event_sample_buf_mmap(event.fd, 1);
32*eb7aa044SAthira Rajeev 
33*eb7aa044SAthira Rajeev 	FAIL_IF(event_enable(&event));
34*eb7aa044SAthira Rajeev 
35*eb7aa044SAthira Rajeev 	/* workload to make the event overflow */
36*eb7aa044SAthira Rajeev 	thirty_two_instruction_loop(10000);
37*eb7aa044SAthira Rajeev 
38*eb7aa044SAthira Rajeev 	FAIL_IF(event_disable(&event));
39*eb7aa044SAthira Rajeev 
40*eb7aa044SAthira Rajeev 	/* Check for sample count */
41*eb7aa044SAthira Rajeev 	FAIL_IF(!collect_samples(event.mmap_buffer));
42*eb7aa044SAthira Rajeev 
43*eb7aa044SAthira Rajeev 	intr_regs = get_intr_regs(&event, event.mmap_buffer);
44*eb7aa044SAthira Rajeev 
45*eb7aa044SAthira Rajeev 	/* Check for intr_regs */
46*eb7aa044SAthira Rajeev 	FAIL_IF(!intr_regs);
47*eb7aa044SAthira Rajeev 
48*eb7aa044SAthira Rajeev 	/* Verify that pmae is cleared and pmao is set in MMCR0 */
49*eb7aa044SAthira Rajeev 	FAIL_IF(get_mmcr0_pmae(get_reg_value(intr_regs, "MMCR0"), 5));
50*eb7aa044SAthira Rajeev 	FAIL_IF(!get_mmcr0_pmao(get_reg_value(intr_regs, "MMCR0"), 5));
51*eb7aa044SAthira Rajeev 
52*eb7aa044SAthira Rajeev 	event_close(&event);
53*eb7aa044SAthira Rajeev 	return 0;
54*eb7aa044SAthira Rajeev }
55*eb7aa044SAthira Rajeev 
main(void)56*eb7aa044SAthira Rajeev int main(void)
57*eb7aa044SAthira Rajeev {
58*eb7aa044SAthira Rajeev 	return test_harness(mmcr0_exceptionbits, "mmcr0_exceptionbits");
59*eb7aa044SAthira Rajeev }
60