[PATCH] perf/arm_dmc620: Add cpumask
Robin Murphy
robin.murphy at arm.com
Tue Jun 13 02:37:46 PDT 2023
On 2023-06-13 02:34, Xin Yang wrote:
> Add a cpumask for the DMC620 PMU. As it is an uncore PMU, perf
> userspace tool only needs to open a single counter on the CPU
> specified by the CPU mask for each event on a given DMC620 device.
Reviewed-by: Robin Murphy <robin.murphy at arm.com>
> Signed-off-by: Xin Yang <xin.yang at arm.com>
> ---
> drivers/perf/arm_dmc620_pmu.c | 22 ++++++++++++++++++++++
> 1 file changed, 22 insertions(+)
>
> diff --git a/drivers/perf/arm_dmc620_pmu.c b/drivers/perf/arm_dmc620_pmu.c
> index 5de06f9a4dd3..9d0f01c4455a 100644
> --- a/drivers/perf/arm_dmc620_pmu.c
> +++ b/drivers/perf/arm_dmc620_pmu.c
> @@ -227,9 +227,31 @@ static const struct attribute_group dmc620_pmu_format_attr_group = {
> .attrs = dmc620_pmu_formats_attrs,
> };
>
> +static ssize_t dmc620_pmu_cpumask_show(struct device *dev,
> + struct device_attribute *attr, char *buf)
> +{
> + struct dmc620_pmu *dmc620_pmu = to_dmc620_pmu(dev_get_drvdata(dev));
> +
> + return cpumap_print_to_pagebuf(true, buf,
> + cpumask_of(dmc620_pmu->irq->cpu));
> +}
> +
> +static struct device_attribute dmc620_pmu_cpumask_attr =
> + __ATTR(cpumask, 0444, dmc620_pmu_cpumask_show, NULL);
> +
> +static struct attribute *dmc620_pmu_cpumask_attrs[] = {
> + &dmc620_pmu_cpumask_attr.attr,
> + NULL,
> +};
> +
> +static const struct attribute_group dmc620_pmu_cpumask_attr_group = {
> + .attrs = dmc620_pmu_cpumask_attrs,
> +};
> +
> static const struct attribute_group *dmc620_pmu_attr_groups[] = {
> &dmc620_pmu_events_attr_group,
> &dmc620_pmu_format_attr_group,
> + &dmc620_pmu_cpumask_attr_group,
> NULL,
> };
>
More information about the linux-arm-kernel
mailing list