/** * @file nmi_timer_int.c * * @remark Copyright 2003 OProfile authors * @remark Read the file COPYING * * @author Zwane Mwaikambo */ #include #include #include #include #include #include #include #include static int nmi_timer_callback(struct pt_regs * regs, int cpu) { oprofile_add_sample(regs, 0); return 1; } static int timer_start(void) { disable_timer_nmi_watchdog(); set_nmi_callback(nmi_timer_callback); return 0; } static void timer_stop(void) { enable_timer_nmi_watchdog(); unset_nmi_callback(); synchronize_sched(); /* Allow already-started NMIs to complete. */ } int __init op_nmi_timer_init(struct oprofile_operations * ops) { if (atomic_read(&nmi_active) <= 0) return -ENODEV; ops->start = timer_start; ops->stop = timer_stop; ops->cpu_type = "timer"; printk(KERN_INFO "oprofile: using NMI timer interrupt.\n"); return 0; }