-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
selftests/powerpc/pmu: Add selftest for group constraint check for MM…
…CR1 cache bits Data and instruction cache qualifier bits in the event code is used to program cache select field in Monitor Mode Control Register 1 (MMCR1: 16-17). When scheduling events as a group, all events in that group should match value in these bits. Otherwise event open for the sibling events will fail. Testcase uses event code "0x1100fc" as leader and other events like "0x23e054" and "0x13e054" as sibling events to checks for l1 cache select field constraints via perf interface. Signed-off-by: Kajol Jain <kjain@linux.ibm.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20220610134113.62991-31-atrajeev@linux.vnet.ibm.com
- Loading branch information
Kajol Jain
authored and
Michael Ellerman
committed
Jun 28, 2022
1 parent
20b3073
commit 291c01e
Showing
2 changed files
with
61 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
60 changes: 60 additions & 0 deletions
60
tools/testing/selftests/powerpc/pmu/event_code_tests/group_constraint_cache_test.c
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
// SPDX-License-Identifier: GPL-2.0-only | ||
/* | ||
* Copyright 2022, Kajol Jain, IBM Corp. | ||
*/ | ||
|
||
#include <stdio.h> | ||
#include <stdlib.h> | ||
|
||
#include "../event.h" | ||
#include "utils.h" | ||
#include "../sampling_tests/misc.h" | ||
|
||
/* All L1 D cache load references counted at finish, gated by reject */ | ||
#define EventCode_1 0x1100fc | ||
/* Load Missed L1 */ | ||
#define EventCode_2 0x23e054 | ||
/* Load Missed L1 */ | ||
#define EventCode_3 0x13e054 | ||
|
||
/* | ||
* Testcase for group constraint check of data and instructions | ||
* cache qualifier bits which is used to program cache select field in | ||
* Monitor Mode Control Register 1 (MMCR1: 16-17) for l1 cache. | ||
* All events in the group should match cache select bits otherwise | ||
* event_open for the group will fail. | ||
*/ | ||
static int group_constraint_cache(void) | ||
{ | ||
struct event event, leader; | ||
|
||
/* Check for platform support for the test */ | ||
SKIP_IF(platform_check_for_tests()); | ||
|
||
/* Init the events for the group contraint check for l1 cache select bits */ | ||
event_init(&leader, EventCode_1); | ||
FAIL_IF(event_open(&leader)); | ||
|
||
event_init(&event, EventCode_2); | ||
|
||
/* Expected to fail as sibling event doesn't request same l1 cache select bits as leader */ | ||
FAIL_IF(!event_open_with_group(&event, leader.fd)); | ||
|
||
event_close(&event); | ||
|
||
/* Init the event for the group contraint l1 cache select test */ | ||
event_init(&event, EventCode_3); | ||
|
||
/* Expected to succeed as sibling event request same l1 cache select bits as leader */ | ||
FAIL_IF(event_open_with_group(&event, leader.fd)); | ||
|
||
event_close(&leader); | ||
event_close(&event); | ||
|
||
return 0; | ||
} | ||
|
||
int main(void) | ||
{ | ||
return test_harness(group_constraint_cache, "group_constraint_cache"); | ||
} |