blob: c0fa356e90de24ea60ba8a0ac90c39e6bb05d73b [file] [log] [blame]
H. Peter Anvin1965aae2008-10-22 22:26:29 -07001#ifndef _ASM_X86_NMI_H
2#define _ASM_X86_NMI_H
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -03003
4#include <linux/pm.h>
5#include <asm/irq.h>
6#include <asm/io.h>
7
Don Zickus4a7863c2010-12-22 14:00:03 -05008#ifdef CONFIG_X86_LOCAL_APIC
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -03009
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -030010extern int avail_to_resrv_perfctr_nmi_bit(unsigned int);
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -030011extern int reserve_perfctr_nmi(unsigned int);
12extern void release_perfctr_nmi(unsigned int);
13extern int reserve_evntsel_nmi(unsigned int);
14extern void release_evntsel_nmi(unsigned int);
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -030015
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -030016struct ctl_table;
Alexey Dobriyan8d65af72009-09-23 15:57:19 -070017extern int proc_nmi_enabled(struct ctl_table *, int ,
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -030018 void __user *, size_t *, loff_t *);
19extern int unknown_nmi_panic;
20
Ingo Molnar47cab6a2009-08-03 09:31:54 +020021void arch_trigger_all_cpu_backtrace(void);
22#define arch_trigger_all_cpu_backtrace arch_trigger_all_cpu_backtrace
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -030023#endif
24
Don Zickusc9126b22011-09-30 15:06:20 -040025#define NMI_FLAG_FIRST 1
26
27enum {
28 NMI_LOCAL=0,
29 NMI_UNKNOWN,
Don Zickus553222f2012-03-29 16:11:16 -040030 NMI_SERR,
31 NMI_IO_CHECK,
Don Zickusc9126b22011-09-30 15:06:20 -040032 NMI_MAX
33};
34
35#define NMI_DONE 0
36#define NMI_HANDLED 1
37
38typedef int (*nmi_handler_t)(unsigned int, struct pt_regs *);
39
Li Zhong72b3fb22012-03-29 16:11:17 -040040struct nmiaction {
41 struct list_head list;
42 nmi_handler_t handler;
Betty Dall6ff968c2012-04-27 14:40:55 -060043 unsigned long flags;
Li Zhong72b3fb22012-03-29 16:11:17 -040044 const char *name;
45};
46
Li Zhong07184672012-06-18 15:56:33 -040047#define register_nmi_handler(t, fn, fg, n, init...) \
Li Zhong72b3fb22012-03-29 16:11:17 -040048({ \
Li Zhong07184672012-06-18 15:56:33 -040049 static struct nmiaction init fn##_na = { \
Li Zhong72b3fb22012-03-29 16:11:17 -040050 .handler = (fn), \
51 .name = (n), \
52 .flags = (fg), \
53 }; \
Li Zhong07184672012-06-18 15:56:33 -040054 __register_nmi_handler((t), &fn##_na); \
Don Zickuseeaaa962012-06-06 10:05:42 -040055})
56
Li Zhong72b3fb22012-03-29 16:11:17 -040057int __register_nmi_handler(unsigned int, struct nmiaction *);
Don Zickusc9126b22011-09-30 15:06:20 -040058
59void unregister_nmi_handler(unsigned int, const char *);
60
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -030061void stop_nmi(void);
62void restart_nmi(void);
Don Zickusb227e232011-09-30 15:06:22 -040063void local_touch_nmi(void);
Glauber de Oliveira Costa6d60cd52008-03-19 14:25:36 -030064
H. Peter Anvin1965aae2008-10-22 22:26:29 -070065#endif /* _ASM_X86_NMI_H */