[PATCH] tools/perf/tests: Update event_groups test to use instructions as one of the sibling event for hw type

Athira Rajeev atrajeev at linux.vnet.ibm.com
Mon Jan 20 19:23:08 AEDT 2025



> On 20 Jan 2025, at 12:00 PM, Ravi Bangoria <ravi.bangoria at amd.com> wrote:
> 
> Hi Athira,
> 
> On 10-Jan-25 3:16 PM, Athira Rajeev wrote:
>> 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. 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
Athira

> 
> Thanks,
> Ravi




More information about the Linuxppc-dev mailing list