[PATCH 1/2] perf/arm-ni: rename PMU device name

Robin Murphy robin.murphy at arm.com
Mon Nov 24 10:01:10 PST 2025


On 2025-11-24 3:47 pm, Will Deacon wrote:
> On Fri, Nov 07, 2025 at 04:43:18PM +0800, Shouping Wang wrote:
>> The PMU device names are arm_ni_1_*,arm_ni_2_*, etc.
>> The device names change based on the order of registration
>> for multiple NI instances. By naming the PMU device using
>> its address, the device name can be made independent of
>> the registration order.
>>
>> Signed-off-by: Shouping Wang <allen.wang at hj-micro.com>
>> ---
>>   drivers/perf/arm-ni.c | 6 ++----
>>   1 file changed, 2 insertions(+), 4 deletions(-)
>>
>> diff --git a/drivers/perf/arm-ni.c b/drivers/perf/arm-ni.c
>> index 1615a0564031..32eabdbe877a 100644
>> --- a/drivers/perf/arm-ni.c
>> +++ b/drivers/perf/arm-ni.c
>> @@ -53,6 +53,7 @@
>>   
>>   #define NI_NUM_COUNTERS		8
>>   #define NI_CCNT_IDX		31
>> +#define NI_PMU_PA_SHIFT		12
>>   
>>   /* Event attributes */
>>   #define NI_CONFIG_TYPE		GENMASK_ULL(15, 0)
>> @@ -115,7 +116,6 @@ struct arm_ni {
>>   	struct device *dev;
>>   	void __iomem *base;
>>   	enum ni_part part;
>> -	int id;
>>   	int cpu;
>>   	int num_cds;
>>   	struct hlist_node cpuhp_node;
>> @@ -560,7 +560,7 @@ static int arm_ni_init_cd(struct arm_ni *ni, struct arm_ni_node *node, u64 res_s
>>   		.read = arm_ni_event_read,
>>   	};
>>   
>> -	name = devm_kasprintf(ni->dev, GFP_KERNEL, "arm_ni_%d_cd_%d", ni->id, cd->id);
>> +	name = devm_kasprintf(ni->dev, GFP_KERNEL, "arm_ni_%llx", res_start >> NI_PMU_PA_SHIFT);
> 
> Doesn't this have the potential to break userspace (e.g. scripts) that
> expect the current naming to be stable?

Certainly on platforms where only arm_ni_0 ever exists. For 
multi-instance cases it's always been documented that this ID is 
arbitrary, and users should look at the platform device that is the 
sysfs parent of the PMU device(s) in order to disambiguate - from there 
they already have the freedom to use whatever information they like, 
including MMIO resources, but also interrupt numbers, ACPI _UIDs or 
whatever. So although changing one arbitrary value to a different 
arbitrary value is in theory something well-behaved users should be OK 
with, in practice changing it from a small decimal integer to a massive 
hex number may well still break parsing expectations.

Thanks,
Robin.

> 
> Either way, I'll need Robin's acks for these changes.
> 
> Will



More information about the linux-arm-kernel mailing list