summaryrefslogtreecommitdiffstats
path: root/arch/loongarch/kernel
diff options
context:
space:
mode:
authorBibo Mao <maobibo@loongson.cn>2024-04-25 16:17:52 +0200
committerHuacai Chen <chenhuacai@loongson.cn>2024-04-25 16:17:52 +0200
commitf3334ebb8a2a1841c2824594dd992e66de19deb2 (patch)
treeb7c8ca8bc5eef16cd39be8528d18c513fceab980 /arch/loongarch/kernel
parentLoongArch: Fix callchain parse error with kernel tracepoint events (diff)
downloadlinux-f3334ebb8a2a1841c2824594dd992e66de19deb2.tar.xz
linux-f3334ebb8a2a1841c2824594dd992e66de19deb2.zip
LoongArch: Lately init pmu after smp is online
There is an smp function call named reset_counters() to init PMU registers of every CPU in PMU initialization state. It requires that all CPUs are online. However there is an early_initcall() wrapper for the PMU init funciton init_hw_perf_events(), so that pmu init funciton is called in do_pre_smp_initcalls() which before function smp_init(). Function reset_counters() cannot work on other CPUs since they haven't boot up still. Here replace the wrapper early_initcall() with pure_initcall(), so that the PMU init function is called after every cpu is online. Signed-off-by: Bibo Mao <maobibo@loongson.cn> Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
Diffstat (limited to 'arch/loongarch/kernel')
-rw-r--r--arch/loongarch/kernel/perf_event.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/loongarch/kernel/perf_event.c b/arch/loongarch/kernel/perf_event.c
index 0491bf453cd4..cac7cba81b65 100644
--- a/arch/loongarch/kernel/perf_event.c
+++ b/arch/loongarch/kernel/perf_event.c
@@ -884,4 +884,4 @@ static int __init init_hw_perf_events(void)
return 0;
}
-early_initcall(init_hw_perf_events);
+pure_initcall(init_hw_perf_events);