[PATCH] drivers/perf: arm_pmu: Show PMU version on boot

Shaokun Zhang zhangshaokun at hisilicon.com
Tue Sep 8 06:59:09 EDT 2020


Hi Will,

在 2020/9/7 21:24, Will Deacon 写道:
> On Wed, Sep 02, 2020 at 09:31:00AM +0800, Shaokun Zhang wrote:
>> 在 2020/9/2 0:16, Will Deacon 写道:
>>> On Wed, Aug 26, 2020 at 02:42:26PM +0800, Shaokun Zhang wrote:
>>>> 在 2020/8/22 0:03, Will Deacon 写道:
>>>>> On Thu, Jul 30, 2020 at 06:47:21PM +0800, Shaokun Zhang wrote:
>>>>>> The @pmuver field has been initialized and can tell the PMU version.
>>>>>> Let's show it on boot and the user obtains this information directly.
>>>>>>
>>>>>> Cc: Will Deacon <will at kernel.org>
>>>>>> Cc: Mark Rutland <mark.rutland at arm.com>
>>>>>> Signed-off-by: Shaokun Zhang <zhangshaokun at hisilicon.com>
>>>>>> ---
>>>>>>  drivers/perf/arm_pmu.c | 4 ++--
>>>>>>  1 file changed, 2 insertions(+), 2 deletions(-)
>>>>>>
>>>>>> diff --git a/drivers/perf/arm_pmu.c b/drivers/perf/arm_pmu.c
>>>>>> index df352b334ea7..36f7fad7ba5a 100644
>>>>>> --- a/drivers/perf/arm_pmu.c
>>>>>> +++ b/drivers/perf/arm_pmu.c
>>>>>> @@ -870,8 +870,8 @@ int armpmu_register(struct arm_pmu *pmu)
>>>>>>  	if (!__oprofile_cpu_pmu)
>>>>>>  		__oprofile_cpu_pmu = pmu;
>>>>>>  
>>>>>> -	pr_info("enabled with %s PMU driver, %d counters available\n",
>>>>>> -		pmu->name, pmu->num_events);
>>>>>> +	pr_info("enabled with %s PMU driver, %d counters available, version is %d\n",
>>>>>> +		pmu->name, pmu->num_events, pmu->pmuver);
>>>>>
>>>>> Hmm. I'm suspicious about this. Who is using this, and what for? We're
>>>>
>>>> Since Arm ARM has extended PMU version for Armv8.1/8.4/8.5 with different PMUver in
>>>> ID_AA64DFR0_EL1, someone who does the performance profiling may care the number of
>>>> counter and want to know the supported PMU version. Because some events or features
>>>> are related to PMU version, Like events corresponding to PMCEID0/1_EL0[32:63] or if
>>>> anyone be told PMMIR_EL1 to ZERO, he can check the PMU version directly from the boot
>>>> log information.
>>>
>>> What do you mean by "may care the number of counter"? The number of counters
>>
>> If the user doesn't want the kernel to use time multiplexing, it shall use events less
>> than the counters that it has been told by the boot information, of course, he can access
>> PMCR_EL0 directly to check it.
> 
> But this isn't an arm64-specific problem, is it? What happens on other

Correct, but I don't mention it as a problem, I just want to explain why some user may check
the counter number information. Apologies that I gave some misunderstanding words.

> architectures, such as x86?
> 
>>> is independent of the PMU version and shouldn't really be of interest to
>>> userspace anyway, should it? Or are you referring to something else?
>>
>> Yes, it is independent, I mean that if the user is interested in PMU information, like,
>> PMU counter number, PMU version, etc, it can be exposed at boot time directly.
> 
> If userspace needs information about the PMU, I'm up for exposing it via
> sysfs, but I don't think we should expose things for the sake of it, and I
> also think that information which isn't specific to the particular PMU
> should be exposed more generally so that userspace doesn't need lots of
> different parsers to get the same information on different hardware.
> 

Got it, thanks for more explanations.

>>> As for whether events are supported or not, we already expose that on a
>>> per-event basis, and I think we should continue to do that.
>>
>> Shall we check the PMU version(ARMv8.1) in the driver for PMCEID0/1_EL0[32:63]?
> 
> I'd need to see the patch, since I don't see where you're going with this.

Oh,I'm not sure whether we shall check PMU verion for PMCEID0/1_EL0[32:63] since
these are ARMv8.1-PMU events. Indeed I didn't do it anything about it in this patch.

Thanks,
Shaokun

> 

> Will
> 
> .
> 




More information about the linux-arm-kernel mailing list