2005-04-17 06:20:36 +08:00
|
|
|
/*
|
|
|
|
* Machine specific NMI handling for generic.
|
|
|
|
* Split out from traps.c by Osamu Tomita <tomita@cinet.co.jp>
|
|
|
|
*/
|
2008-10-23 15:01:39 +08:00
|
|
|
#ifndef _ASM_X86_MACH_DEFAULT_MACH_TRAPS_H
|
|
|
|
#define _ASM_X86_MACH_DEFAULT_MACH_TRAPS_H
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
#include <asm/mc146818rtc.h>
|
|
|
|
|
2011-01-07 05:18:47 +08:00
|
|
|
#define NMI_REASON_PORT 0x61
|
|
|
|
|
|
|
|
#define NMI_REASON_SERR 0x80
|
|
|
|
#define NMI_REASON_IOCHK 0x40
|
|
|
|
#define NMI_REASON_MASK (NMI_REASON_SERR | NMI_REASON_IOCHK)
|
|
|
|
|
|
|
|
#define NMI_REASON_CLEAR_SERR 0x04
|
|
|
|
#define NMI_REASON_CLEAR_IOCHK 0x08
|
|
|
|
#define NMI_REASON_CLEAR_MASK 0x0f
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
static inline unsigned char get_nmi_reason(void)
|
|
|
|
{
|
2011-01-07 05:18:47 +08:00
|
|
|
return inb(NMI_REASON_PORT);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void reassert_nmi(void)
|
|
|
|
{
|
|
|
|
int old_reg = -1;
|
|
|
|
|
|
|
|
if (do_i_have_lock_cmos())
|
|
|
|
old_reg = current_lock_cmos_reg();
|
|
|
|
else
|
|
|
|
lock_cmos(0); /* register doesn't matter here */
|
|
|
|
outb(0x8f, 0x70);
|
|
|
|
inb(0x71); /* dummy */
|
|
|
|
outb(0x0f, 0x70);
|
|
|
|
inb(0x71); /* dummy */
|
|
|
|
if (old_reg >= 0)
|
|
|
|
outb(old_reg, 0x70);
|
|
|
|
else
|
|
|
|
unlock_cmos();
|
|
|
|
}
|
|
|
|
|
2008-10-23 15:01:39 +08:00
|
|
|
#endif /* _ASM_X86_MACH_DEFAULT_MACH_TRAPS_H */
|