blob: 29af2d5df0972cdac25fd2c73e42cd49976efa8a [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/include/linux/nmi.h
3 */
4#ifndef LINUX_NMI_H
5#define LINUX_NMI_H
6
Michal Schmidt99384062006-09-29 01:59:03 -07007#include <linux/sched.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07008#include <asm/irq.h>
9
10/**
11 * touch_nmi_watchdog - restart NMI watchdog timeout.
12 *
13 * If the architecture supports the NMI watchdog, touch_nmi_watchdog()
14 * may be used to reset the timeout - for code which intentionally
15 * disables interrupts for a long time. This call is stateless.
16 */
17#ifdef ARCH_HAS_NMI_WATCHDOG
Andrew Mortonbb81a092006-12-07 02:14:01 +010018#include <asm/nmi.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070019extern void touch_nmi_watchdog(void);
Ingo Molnar5d0e6002007-02-13 13:26:24 +010020extern void acpi_nmi_disable(void);
21extern void acpi_nmi_enable(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -070022#else
Ingo Molnar5d0e6002007-02-13 13:26:24 +010023static inline void touch_nmi_watchdog(void)
24{
25 touch_softlockup_watchdog();
26}
27static inline void acpi_nmi_disable(void) { }
28static inline void acpi_nmi_enable(void) { }
Linus Torvalds1da177e2005-04-16 15:20:36 -070029#endif
30
Andrew Mortonbb81a092006-12-07 02:14:01 +010031#ifndef trigger_all_cpu_backtrace
32#define trigger_all_cpu_backtrace() do { } while (0)
33#endif
34
Linus Torvalds1da177e2005-04-16 15:20:36 -070035#endif