blob: 8f02a2a416e693e424977b4f996932af82aeb44f [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/include/asm-i386/nmi.h
3 */
4#ifndef ASM_NMI_H
5#define ASM_NMI_H
6
7#include <linux/pm.h>
Don Zickus3e4ff112006-06-26 13:57:01 +02008#include <asm/io.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07009
10struct pt_regs;
Don Zickus3e4ff112006-06-26 13:57:01 +020011
Linus Torvalds1da177e2005-04-16 15:20:36 -070012typedef int (*nmi_callback_t)(struct pt_regs * regs, int cpu);
Don Zickus3e4ff112006-06-26 13:57:01 +020013
14/**
Linus Torvalds1da177e2005-04-16 15:20:36 -070015 * set_nmi_callback
16 *
17 * Set a handler for an NMI. Only one handler may be
18 * set. Return 1 if the NMI was handled.
19 */
20void set_nmi_callback(nmi_callback_t callback);
Don Zickus3e4ff112006-06-26 13:57:01 +020021
22/**
Linus Torvalds1da177e2005-04-16 15:20:36 -070023 * unset_nmi_callback
24 *
25 * Remove the handler previously set.
26 */
27void unset_nmi_callback(void);
Don Zickus3e4ff112006-06-26 13:57:01 +020028
Don Zickus3adbbcc2006-09-26 10:52:26 +020029/**
30 * do_nmi_callback
31 *
32 * Check to see if a callback exists and execute it. Return 1
33 * if the handler exists and was handled successfully.
34 */
35int do_nmi_callback(struct pt_regs *regs, int cpu);
36
Linus Torvalds1da177e2005-04-16 15:20:36 -070037#ifdef CONFIG_PM
38
39/** Replace the PM callback routine for NMI. */
40struct pm_dev * set_nmi_pm_callback(pm_callback callback);
41
42/** Unset the PM callback routine back to the default. */
43void unset_nmi_pm_callback(struct pm_dev * dev);
44
45#else
46
47static inline struct pm_dev * set_nmi_pm_callback(pm_callback callback)
48{
49 return 0;
50}
51
52static inline void unset_nmi_pm_callback(struct pm_dev * dev)
53{
54}
55
56#endif /* CONFIG_PM */
57
58extern void default_do_nmi(struct pt_regs *);
59extern void die_nmi(char *str, struct pt_regs *regs);
60
61#define get_nmi_reason() inb(0x61)
62
63extern int panic_on_timeout;
64extern int unknown_nmi_panic;
Andi Kleen75152112005-05-16 21:53:34 -070065
66extern int check_nmi_watchdog(void);
Don Zickus828f0af2006-09-26 10:52:26 +020067extern int avail_to_resrv_perfctr_nmi_bit(unsigned int);
68extern int avail_to_resrv_perfctr_nmi(unsigned int);
69extern int reserve_perfctr_nmi(unsigned int);
70extern void release_perfctr_nmi(unsigned int);
71extern int reserve_evntsel_nmi(unsigned int);
72extern void release_evntsel_nmi(unsigned int);
73
Don Zickusf2802e72006-09-26 10:52:26 +020074extern void setup_apic_nmi_watchdog (void *);
Don Zickus3e4ff112006-06-26 13:57:01 +020075extern int reserve_lapic_nmi(void);
76extern void release_lapic_nmi(void);
77extern void disable_timer_nmi_watchdog(void);
78extern void enable_timer_nmi_watchdog(void);
Don Zickus3adbbcc2006-09-26 10:52:26 +020079extern int nmi_watchdog_tick (struct pt_regs * regs, unsigned reason);
Don Zickus3e4ff112006-06-26 13:57:01 +020080
81extern void nmi_watchdog_default(void);
82extern int setup_nmi_watchdog(char *);
83
Don Zickusf2802e72006-09-26 10:52:26 +020084extern atomic_t nmi_active;
Don Zickus3e4ff112006-06-26 13:57:01 +020085extern unsigned int nmi_watchdog;
86#define NMI_DEFAULT -1
87#define NMI_NONE 0
88#define NMI_IO_APIC 1
89#define NMI_LOCAL_APIC 2
90#define NMI_INVALID 3
91
Linus Torvalds1da177e2005-04-16 15:20:36 -070092#endif /* ASM_NMI_H */