diff options
author | Bibo Mao <maobibo@loongson.cn> | 2024-04-25 16:17:52 +0200 |
---|---|---|
committer | Huacai Chen <chenhuacai@loongson.cn> | 2024-04-25 16:17:52 +0200 |
commit | f3334ebb8a2a1841c2824594dd992e66de19deb2 (patch) | |
tree | b7c8ca8bc5eef16cd39be8528d18c513fceab980 /arch/loongarch/kernel | |
parent | LoongArch: Fix callchain parse error with kernel tracepoint events (diff) | |
download | linux-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.c | 2 |
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); |