[bug report] perf: ARM DynamIQ Shared Unit PMU support
Suzuki K Poulose
Suzuki.Poulose at arm.com
Mon Jan 15 02:51:16 PST 2018
Hi Dan,
Thanks for the report.
On 12/01/18 20:13, Dan Carpenter wrote:
> Hello Suzuki K Poulose,
>
> The patch 7520fa99246d: "perf: ARM DynamIQ Shared Unit PMU support"
> from Jan 2, 2018, leads to the following static checker warning:
>
> drivers/perf/arm_dsu_pmu.c:680 dsu_pmu_init_pmu()
> warn: impossible condition '(dsu_pmu->num_counters == -1) => (0-255 == (-1))'
>
> drivers/perf/arm_dsu_pmu.c
> 674 /*
> 675 * dsu_pmu_init_pmu: Initialise the DSU PMU configurations if
> 676 * we haven't done it already.
> 677 */
> 678 static void dsu_pmu_init_pmu(struct dsu_pmu *dsu_pmu)
> 679 {
> 680 if (dsu_pmu->num_counters == -1)
> ^^^^^^^^^^^^^^^^^^^^^^^^^^^
> A u8 variable can't ever be -1.
>
> 681 dsu_pmu_probe_pmu(dsu_pmu);
> 682 /* Reset the interrupt overflow mask */
> 683 dsu_pmu_get_reset_overflow();
> 684 }
>
> regards,
> dan carpenter
>
Here is the fix.
---8>---
perf: dsu: Use signed field for dsu_pmu->num_counters
We set dsu_pmu->num_counters to -1, when the DSU is allocated
but not initialised when none of the CPUs are active in the DSU.
However, we use an unsigned field for num_counters. Switch this
to a signed field.
Reported-by: Dan Carpenter <dan.carpenter at oracle.com>
Cc: Mark Rutland <mark.rutland at arm.com>
Cc: Will Deacon <will.deacon at arm.com>
Signed-off-by: Suzuki K Poulose <suzuki.poulose at arm.com>
diff --git a/drivers/perf/arm_dsu_pmu.c b/drivers/perf/arm_dsu_pmu.c
index 37c0526c93d5..93c50e377507 100644
--- a/drivers/perf/arm_dsu_pmu.c
+++ b/drivers/perf/arm_dsu_pmu.c
@@ -120,7 +120,7 @@ struct dsu_pmu {
cpumask_t associated_cpus;
cpumask_t active_cpu;
struct hlist_node cpuhp_node;
- u8 num_counters;
+ s8 num_counters;
int irq;
DECLARE_BITMAP(cpmceid_bitmap, DSU_PMU_MAX_COMMON_EVENTS);
};
More information about the linux-arm-kernel
mailing list