perf, arch: Cleanup perf-pmu init vs lockup-detector
The perf hardware pmu got initialized at various points in the boot, some before early_initcall() some after (notably arch_initcall). The problem is that the NMI lockup detector is ran from early_initcall() and expects the hardware pmu to be present. Sanitize this by moving all architecture hardware pmu implementations to initialize at early_initcall() and move the lockup detector to an explicit initcall right after that. Cc: paulus <paulus@samba.org> Cc: davem <davem@davemloft.net> Cc: Michael Cree <mcree@orcon.net.nz> Cc: Deng-Cheng Zhu <dengcheng.zhu@gmail.com> Acked-by:Paul Mundt <lethal@linux-sh.org> Acked-by:
Will Deacon <will.deacon@arm.com> Signed-off-by:
Peter Zijlstra <a.p.zijlstra@chello.nl> LKML-Reference: <1290707759.2145.119.camel@laptop> Signed-off-by:
Ingo Molnar <mingo@elte.hu>
Showing
- arch/alpha/include/asm/perf_event.h 0 additions, 6 deletionsarch/alpha/include/asm/perf_event.h
- arch/alpha/kernel/irq_alpha.c 0 additions, 2 deletionsarch/alpha/kernel/irq_alpha.c
- arch/alpha/kernel/perf_event.c 6 additions, 3 deletionsarch/alpha/kernel/perf_event.c
- arch/arm/kernel/perf_event.c 1 addition, 1 deletionarch/arm/kernel/perf_event.c
- arch/mips/kernel/perf_event_mipsxx.c 1 addition, 1 deletionarch/mips/kernel/perf_event_mipsxx.c
- arch/powerpc/kernel/e500-pmu.c 1 addition, 1 deletionarch/powerpc/kernel/e500-pmu.c
- arch/powerpc/kernel/mpc7450-pmu.c 1 addition, 1 deletionarch/powerpc/kernel/mpc7450-pmu.c
- arch/powerpc/kernel/power4-pmu.c 1 addition, 1 deletionarch/powerpc/kernel/power4-pmu.c
- arch/powerpc/kernel/power5+-pmu.c 1 addition, 1 deletionarch/powerpc/kernel/power5+-pmu.c
- arch/powerpc/kernel/power5-pmu.c 1 addition, 1 deletionarch/powerpc/kernel/power5-pmu.c
- arch/powerpc/kernel/power6-pmu.c 1 addition, 1 deletionarch/powerpc/kernel/power6-pmu.c
- arch/powerpc/kernel/power7-pmu.c 1 addition, 1 deletionarch/powerpc/kernel/power7-pmu.c
- arch/powerpc/kernel/ppc970-pmu.c 1 addition, 1 deletionarch/powerpc/kernel/ppc970-pmu.c
- arch/sh/kernel/cpu/sh4/perf_event.c 1 addition, 1 deletionarch/sh/kernel/cpu/sh4/perf_event.c
- arch/sh/kernel/cpu/sh4a/perf_event.c 1 addition, 1 deletionarch/sh/kernel/cpu/sh4a/perf_event.c
- arch/sparc/include/asm/perf_event.h 0 additions, 4 deletionsarch/sparc/include/asm/perf_event.h
- arch/sparc/kernel/nmi.c 0 additions, 2 deletionsarch/sparc/kernel/nmi.c
- arch/sparc/kernel/perf_event.c 5 additions, 2 deletionsarch/sparc/kernel/perf_event.c
- arch/x86/include/asm/perf_event.h 0 additions, 2 deletionsarch/x86/include/asm/perf_event.h
- arch/x86/kernel/cpu/common.c 0 additions, 1 deletionarch/x86/kernel/cpu/common.c
Loading
Please register or sign in to comment