Lines Matching full:pmu

31 	 * Per the ACPI spec, the MADT cannot describe a PMU that doesn't  in arm_pmu_acpi_register_irq()
87 * For lack of a better place, hook the normal PMU MADT walk
149 pr_warn("Unable to parse ACPI PMU IRQ for CPU%d: %d\n", in arm_pmu_acpi_parse_irqs()
153 pr_warn("No ACPI PMU IRQ for CPU%d\n", cpu); in arm_pmu_acpi_parse_irqs()
191 struct arm_pmu *pmu; in arm_pmu_acpi_find_alloc_pmu() local
195 pmu = per_cpu(probed_pmus, cpu); in arm_pmu_acpi_find_alloc_pmu()
196 if (!pmu || pmu->acpi_cpuid != cpuid) in arm_pmu_acpi_find_alloc_pmu()
199 return pmu; in arm_pmu_acpi_find_alloc_pmu()
202 pmu = armpmu_alloc_atomic(); in arm_pmu_acpi_find_alloc_pmu()
203 if (!pmu) { in arm_pmu_acpi_find_alloc_pmu()
204 pr_warn("Unable to allocate PMU for CPU%d\n", in arm_pmu_acpi_find_alloc_pmu()
209 pmu->acpi_cpuid = cpuid; in arm_pmu_acpi_find_alloc_pmu()
211 return pmu; in arm_pmu_acpi_find_alloc_pmu()
216 * the PMU (e.g. we don't have mismatched PPIs).
218 static bool pmu_irq_matches(struct arm_pmu *pmu, int irq) in pmu_irq_matches() argument
220 struct pmu_hw_events __percpu *hw_events = pmu->hw_events; in pmu_irq_matches()
226 for_each_cpu(cpu, &pmu->supported_cpus) { in pmu_irq_matches()
254 struct arm_pmu *pmu; in arm_pmu_acpi_cpu_starting() local
264 pmu = arm_pmu_acpi_find_alloc_pmu(); in arm_pmu_acpi_cpu_starting()
265 if (!pmu) in arm_pmu_acpi_cpu_starting()
268 per_cpu(probed_pmus, cpu) = pmu; in arm_pmu_acpi_cpu_starting()
270 if (pmu_irq_matches(pmu, irq)) { in arm_pmu_acpi_cpu_starting()
271 hw_events = pmu->hw_events; in arm_pmu_acpi_cpu_starting()
275 cpumask_set_cpu(cpu, &pmu->supported_cpus); in arm_pmu_acpi_cpu_starting()
278 * Ideally, we'd probe the PMU here when we find the first matching in arm_pmu_acpi_cpu_starting()
300 * without tying this too deeply into the "real" PMU driver. in arm_pmu_acpi_probe()
303 * of a PMU's CPUs to be online at probe time. in arm_pmu_acpi_probe()
306 struct arm_pmu *pmu = per_cpu(probed_pmus, cpu); in arm_pmu_acpi_probe() local
309 if (!pmu || pmu->name) in arm_pmu_acpi_probe()
312 ret = init_fn(pmu); in arm_pmu_acpi_probe()
314 /* PMU not handled by this driver, or not present */ in arm_pmu_acpi_probe()
317 pr_warn("Unable to initialise PMU for CPU%d\n", cpu); in arm_pmu_acpi_probe()
321 base_name = pmu->name; in arm_pmu_acpi_probe()
322 pmu->name = kasprintf(GFP_KERNEL, "%s_%d", base_name, pmu_idx++); in arm_pmu_acpi_probe()
323 if (!pmu->name) { in arm_pmu_acpi_probe()
324 pr_warn("Unable to allocate PMU name for CPU%d\n", cpu); in arm_pmu_acpi_probe()
328 ret = armpmu_register(pmu); in arm_pmu_acpi_probe()
330 pr_warn("Failed to register PMU for CPU%d\n", cpu); in arm_pmu_acpi_probe()
331 kfree(pmu->name); in arm_pmu_acpi_probe()