[PATCH] drivers: perf: arm_pmuv3: Update 'pmc_width' based on actual HW event width

Robin Murphy robin.murphy at arm.com
Tue Oct 10 04:38:22 PDT 2023


On 09/10/2023 5:37 am, Anshuman Khandual wrote:
> This updates 'perf_event_mmap_page->pmc_width' based on actual HW event's
> width that are currently missing i.e ARMPMU_EVT_63BIT and ARMPMU_EVT_47BIT.
> 
> Cc: Will Deacon <will at kernel.org>
> Cc: Mark Rutland <mark.rutland at arm.com>
> Cc: linux-arm-kernel at lists.infradead.org
> Cc: linux-kernel at vger.kernel.org
> Signed-off-by: Anshuman Khandual <anshuman.khandual at arm.com>
> ---
> This applies on v6.6-rc5.
> 
>   drivers/perf/arm_pmuv3.c | 4 ++++
>   1 file changed, 4 insertions(+)
> 
> diff --git a/drivers/perf/arm_pmuv3.c b/drivers/perf/arm_pmuv3.c
> index fe4db1831662..94723d00548e 100644
> --- a/drivers/perf/arm_pmuv3.c
> +++ b/drivers/perf/arm_pmuv3.c
> @@ -1375,6 +1375,10 @@ void arch_perf_update_userpage(struct perf_event *event,
>   	if (userpg->cap_user_rdpmc) {
>   		if (event->hw.flags & ARMPMU_EVT_64BIT)
>   			userpg->pmc_width = 64;
> +		else if (event->hw.flags & ARMPMU_EVT_63BIT)
> +			userpg->pmc_width = 63;
> +		else if (event->hw.flags & ARMPMU_EVT_47BIT)
> +			userpg->pmc_width = 47;

I think this will give the wrong behaviour in at least some cases - if 
the user has not requested a "long" event which would lead to 
ARMPMU_EVT_64BIT being set, we will bias the values to only count 32 
effective bits regardless of how wide the physical counters are. I 
believe this is what "the valid width of the counter" in the 
documentation is trying to refer to.

Thanks,
Robin.

>   		else
>   			userpg->pmc_width = 32;
>   	}



More information about the linux-arm-kernel mailing list