Some of the tests depends on pvr value to choose
the event. Example:
- event_alternatives_tests_p10: alternative event depends
  on registered PMU driver which is based on pvr
- generic_events_valid_test varies based on platform
- bhrb_filter_map_test: again its dependent on pmu to
  decide which bhrb filter to use
- reserved_bits_mmcra_sample_elig_mode: randome sampling
  mode reserved bits is also varies based on platform

Signed-off-by: Athira Rajeev <atraj...@linux.vnet.ibm.com>
---
Changelog:
 v1 -> v2
 No code changes. Rebased to latest upstream

 .../pmu/event_code_tests/event_alternatives_tests_p10.c    | 3 ++-
 .../pmu/event_code_tests/generic_events_valid_test.c       | 3 ++-
 .../reserved_bits_mmcra_sample_elig_mode_test.c            | 3 ++-
 .../powerpc/pmu/sampling_tests/bhrb_filter_map_test.c      | 7 +++++--
 4 files changed, 11 insertions(+), 5 deletions(-)

diff --git 
a/tools/testing/selftests/powerpc/pmu/event_code_tests/event_alternatives_tests_p10.c
 
b/tools/testing/selftests/powerpc/pmu/event_code_tests/event_alternatives_tests_p10.c
index 8be7aada6523..355f8bbe06c3 100644
--- 
a/tools/testing/selftests/powerpc/pmu/event_code_tests/event_alternatives_tests_p10.c
+++ 
b/tools/testing/selftests/powerpc/pmu/event_code_tests/event_alternatives_tests_p10.c
@@ -26,6 +26,7 @@ static int event_alternatives_tests_p10(void)
 {
        struct event *e, events[5];
        int i;
+       int pvr = PVR_VER(mfspr(SPRN_PVR));
 
        /* Check for platform support for the test */
        SKIP_IF(platform_check_for_tests());
@@ -36,7 +37,7 @@ static int event_alternatives_tests_p10(void)
         * code and using PVR will work correctly for all cases
         * including generic compat mode.
         */
-       SKIP_IF(PVR_VER(mfspr(SPRN_PVR)) != POWER10);
+       SKIP_IF((pvr != POWER10) && (pvr != POWER11));
 
        SKIP_IF(check_for_generic_compat_pmu());
 
diff --git 
a/tools/testing/selftests/powerpc/pmu/event_code_tests/generic_events_valid_test.c
 
b/tools/testing/selftests/powerpc/pmu/event_code_tests/generic_events_valid_test.c
index 0d237c15d3f2..a378fa9a5a7b 100644
--- 
a/tools/testing/selftests/powerpc/pmu/event_code_tests/generic_events_valid_test.c
+++ 
b/tools/testing/selftests/powerpc/pmu/event_code_tests/generic_events_valid_test.c
@@ -17,6 +17,7 @@
 static int generic_events_valid_test(void)
 {
        struct event event;
+       int pvr = mfspr(SPRN_PVR);
 
        /* Check for platform support for the test */
        SKIP_IF(platform_check_for_tests());
@@ -31,7 +32,7 @@ static int generic_events_valid_test(void)
         * - PERF_COUNT_HW_STALLED_CYCLES_BACKEND
         * - PERF_COUNT_HW_REF_CPU_CYCLES
         */
-       if (PVR_VER(mfspr(SPRN_PVR)) == POWER10) {
+       if ((pvr == POWER10) || (pvr == POWER11)) {
                event_init_opts(&event, PERF_COUNT_HW_CPU_CYCLES, 
PERF_TYPE_HARDWARE, "event");
                FAIL_IF(event_open(&event));
                event_close(&event);
diff --git 
a/tools/testing/selftests/powerpc/pmu/event_code_tests/reserved_bits_mmcra_sample_elig_mode_test.c
 
b/tools/testing/selftests/powerpc/pmu/event_code_tests/reserved_bits_mmcra_sample_elig_mode_test.c
index 4c119c821b99..7bb26a232fbe 100644
--- 
a/tools/testing/selftests/powerpc/pmu/event_code_tests/reserved_bits_mmcra_sample_elig_mode_test.c
+++ 
b/tools/testing/selftests/powerpc/pmu/event_code_tests/reserved_bits_mmcra_sample_elig_mode_test.c
@@ -21,6 +21,7 @@
 static int reserved_bits_mmcra_sample_elig_mode(void)
 {
        struct event event;
+       int pvr = PVR_VER(mfspr(SPRN_PVR));
 
        /* Check for platform support for the test */
        SKIP_IF(platform_check_for_tests());
@@ -59,7 +60,7 @@ static int reserved_bits_mmcra_sample_elig_mode(void)
         * is reserved in power10 and 0xC is reserved in
         * power9.
         */
-       if (PVR_VER(mfspr(SPRN_PVR)) == POWER10) {
+       if ((pvr == POWER10) || (pvr == POWER11)) {
                event_init(&event, 0x100401e0);
                FAIL_IF(!event_open(&event));
        } else if (PVR_VER(mfspr(SPRN_PVR)) == POWER9) {
diff --git 
a/tools/testing/selftests/powerpc/pmu/sampling_tests/bhrb_filter_map_test.c 
b/tools/testing/selftests/powerpc/pmu/sampling_tests/bhrb_filter_map_test.c
index 3f43c315c666..64ab9784f9b1 100644
--- a/tools/testing/selftests/powerpc/pmu/sampling_tests/bhrb_filter_map_test.c
+++ b/tools/testing/selftests/powerpc/pmu/sampling_tests/bhrb_filter_map_test.c
@@ -83,13 +83,16 @@ static int bhrb_filter_map_test(void)
         * using PVR will work correctly for all cases including generic
         * compat mode.
         */
-       if (PVR_VER(mfspr(SPRN_PVR)) == POWER10) {
+       switch (PVR_VER(mfspr(SPRN_PVR))) {
+       case POWER11:
+       case POWER10:
                for (i = 0; i < ARRAY_SIZE(bhrb_filter_map_valid_p10); i++) {
                        event.attr.branch_sample_type = 
bhrb_filter_map_valid_p10[i];
                        FAIL_IF(event_open(&event));
                        event_close(&event);
                }
-       } else {
+               break;
+       default:
                for (i = 0; i < ARRAY_SIZE(bhrb_filter_map_valid_p10); i++) {
                        event.attr.branch_sample_type = 
bhrb_filter_map_valid_p10[i];
                        FAIL_IF(!event_open(&event));
-- 
2.43.5


Reply via email to