diff options
author | Robert Richter <robert.richter@amd.com> | 2011-10-11 17:11:08 +0200 |
---|---|---|
committer | Robert Richter <robert.richter@amd.com> | 2011-11-04 16:27:18 +0100 |
commit | dcfce4a095932e6e95d83ad982be3609947963bc (patch) | |
tree | 2808b7cbdb57deab25cc1cd847fd0f9ffa058f92 /arch/x86/oprofile/Makefile | |
parent | 75c43a20b220f885c39ffa7cdbbb1191e257a9a9 (diff) | |
download | linux-dcfce4a095932e6e95d83ad982be3609947963bc.tar.gz linux-dcfce4a095932e6e95d83ad982be3609947963bc.tar.bz2 linux-dcfce4a095932e6e95d83ad982be3609947963bc.zip |
oprofile, x86: Reimplement nmi timer mode using perf event
The legacy x86 nmi watchdog code was removed with the implementation
of the perf based nmi watchdog. This broke Oprofile's nmi timer
mode. To run nmi timer mode we relied on a continuous ticking nmi
source which the nmi watchdog provided. The nmi tick was no longer
available and current watchdog can not be used anymore since it runs
with very long periods in the range of seconds. This patch
reimplements the nmi timer mode using a perf counter nmi source.
V2:
* removing pr_info()
* fix undefined reference to `__udivdi3' for 32 bit build
* fix section mismatch of .cpuinit.data:nmi_timer_cpu_nb
* removed nmi timer setup in arch/x86
* implemented function stubs for op_nmi_init/exit()
* made code more readable in oprofile_init()
V3:
* fix architectural initialization in oprofile_init()
* fix CONFIG_OPROFILE_NMI_TIMER dependencies
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Signed-off-by: Robert Richter <robert.richter@amd.com>
Diffstat (limited to 'arch/x86/oprofile/Makefile')
-rw-r--r-- | arch/x86/oprofile/Makefile | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/arch/x86/oprofile/Makefile b/arch/x86/oprofile/Makefile index 446902b2a6b6..1599f568f0e2 100644 --- a/arch/x86/oprofile/Makefile +++ b/arch/x86/oprofile/Makefile @@ -4,9 +4,8 @@ DRIVER_OBJS = $(addprefix ../../../drivers/oprofile/, \ oprof.o cpu_buffer.o buffer_sync.o \ event_buffer.o oprofile_files.o \ oprofilefs.o oprofile_stats.o \ - timer_int.o ) + timer_int.o nmi_timer_int.o ) oprofile-y := $(DRIVER_OBJS) init.o backtrace.o oprofile-$(CONFIG_X86_LOCAL_APIC) += nmi_int.o op_model_amd.o \ op_model_ppro.o op_model_p4.o -oprofile-$(CONFIG_X86_IO_APIC) += nmi_timer_int.o |