WIP FPC-III support
[linux/fpc-iii.git] / tools / testing / selftests / powerpc / pmu / l3_bank_test.c
bloba5dfa9bf3b9f2435815223a7be5f44b148d6f28d
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3 * Copyright 2014, Michael Ellerman, IBM Corp.
4 */
6 #include <stdio.h>
7 #include <stdlib.h>
9 #include "event.h"
10 #include "utils.h"
12 #define MALLOC_SIZE (0x10000 * 10) /* Ought to be enough .. */
15 * Tests that the L3 bank handling is correct. We fixed it in commit e9aaac1.
17 static int l3_bank_test(void)
19 struct event event;
20 char *p;
21 int i;
23 // The L3 bank logic is only used on Power8 or later
24 SKIP_IF(!have_hwcap2(PPC_FEATURE2_ARCH_2_07));
26 p = malloc(MALLOC_SIZE);
27 FAIL_IF(!p);
29 event_init(&event, 0x84918F);
31 FAIL_IF(event_open(&event));
33 for (i = 0; i < MALLOC_SIZE; i += 0x10000)
34 p[i] = i;
36 event_read(&event);
37 event_report(&event);
39 FAIL_IF(event.result.running == 0);
40 FAIL_IF(event.result.enabled == 0);
42 event_close(&event);
43 free(p);
45 return 0;
48 int main(void)
50 return test_harness(l3_bank_test, "l3_bank_test");