blob: b752e807addece22ec9210f0d109d2818505d34d [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
Ingo Molnar47cab6a2009-08-03 09:31:54 +020031/*
32 * Create trigger_all_cpu_backtrace() out of the arch-provided
33 * base function. Return whether such support was available,
34 * to allow calling code to fall back to some other mechanism:
35 */
36#ifdef arch_trigger_all_cpu_backtrace
37static inline bool trigger_all_cpu_backtrace(void)
38{
39 arch_trigger_all_cpu_backtrace();
40
41 return true;
42}
43#else
44static inline bool trigger_all_cpu_backtrace(void)
45{
46 return false;
47}
Andrew Mortonbb81a092006-12-07 02:14:01 +010048#endif
49
Linus Torvalds1da177e2005-04-16 15:20:36 -070050#endif