[PATCH] tools/perf/tests: Update event_groups test to use instructions as one of the sibling event for hw type
Ravi Bangoria
ravi.bangoria at amd.com
Mon Jan 20 20:38:32 AEDT 2025
>>> In some of the powerpc platforms, event group testcase fails as below:
>>>
>>> # perf test -v 'Event groups'
>>> 69: Event groups :
>>> --- start ---
>>> test child forked, pid 9765
>>> Using CPUID 0x00820200
>>> Using hv_24x7 for uncore pmu event
>>> 0x0 0x0, 0x0 0x0, 0x0 0x0: Fail
>>> 0x0 0x0, 0x0 0x0, 0x1 0x3: Pass
>>>
>>> The testcase creates various combinations of hw, sw and uncore
>>> PMU events and verify group creation succeeds or fails as expected.
>>> This tests one of the limitation in perf where it doesn't allow
>>> creating a group of events from different hw PMUs.
>>>
>>> The testcase starts a leader event and opens two sibling events.
>>> The combination the fails is three hardware events in a group.
>>> "0x0 0x0, 0x0 0x0, 0x0 0x0: Fail"
>>>
>>> Type zero and config zero which translates to PERF_TYPE_HARDWARE
>>> and PERF_COUNT_HW_CPU_CYCLE. There is event constraint in powerpc
>>> that events using same counter cannot be programmed in a group.
>>> Here there is one alternative event for cycles, hence one leader
>>> and only one sibling event can go in as a group.
>>
>> For power9, cycles seems to map to PM_CYC event:
>>
>> GENERIC_EVENT_ATTR(cpu-cycles, PM_CYC);
>>
>> However, I don't see PM_CYC in power9_event_alternatives[]. Is PM_RUN_CYC
>> and PM_CYC are same?
>
> Hi Ravi
>
> They are not the same. PM_CYC count irrespective of the run latch state (idle state)
> whereas PM_RUN_CYC doesn’t do that.
>
> This test runs fine in power9. The event code for PM_CYC is
> EVENT(PM_CYC, 0x0001e)
>
> Here it is not specifically meant to be run a particular counter and even if no alternative event is defined, it can pick available counters and go in as a group.
Got it.
> But there are cases like other PMU (which is used in absence of platform specific PMU) , where alternative event is specified to run a particular counter.
> Example: arch/powerpc/perf/generic-compat-pmu.c
>
> EVENT(PM_CYC_ALT, 0x100f0)
> EVENT(PM_CYC, 0x600f4)
>
> In this case, we can have only two cycles events to go in a group. So with our testcase events, one leader and only one sibling event
> can go in a group (checked other PMU’s to confirm two is possible). So added this fix to consider instructions as one of the sibling event.
Thanks for the explanation.
Reviewed-by: Ravi Bangoria <ravi.bangoria at amd.com>
Thanks,
Ravi
More information about the Linuxppc-dev
mailing list