diff options
author | Andi Kleen <andi@firstfloor.org> | 2009-05-27 15:56:57 -0400 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2009-06-03 17:45:34 -0400 |
commit | ed7290d0ee8f81aa78bfe816f01b012f208cafc5 (patch) | |
tree | c73c44c14ff9f43147422df00dcef830cd952530 /arch/x86/include/asm/mce.h | |
parent | 86503560e48153aba539ff117450d31ab2ef76d7 (diff) |
x86, mce: implement new status bits
The x86 architecture recently added some new machine check status bits:
S(ignalled) and AR (Action-Required). Signalled allows to check
if a specific event caused an exception or was just logged through CMCI.
AR allows the kernel to decide if an event needs immediate action
or can be delayed or ignored.
Implement support for these new status bits. mce_severity() uses
the new bits to grade the machine check correctly and decide what
to do. The exception handler uses AR to decide to kill or not.
The S bit is used to separate events between the poll/CMCI handler
and the exception handler.
Classical UC always leads to panic. That was true before anyways
because the existing CPUs always passed a PCC with it.
Also corrects the rules whether to kill in user or kernel context
and how to handle missing RIPV.
The machine check handler largely uses the mce-severity grading
engine now instead of making its own decisions. This means the logic
is centralized in one place. This is useful because it has to be
evaluated multiple times.
v2: Some rule fixes; Add AO events
Fix RIPV, RIPV|EIPV order (Ying Huang)
Fix UCNA with AR=1 message (Ying Huang)
Add comment about panicing in m_c_p.
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Signed-off-by: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'arch/x86/include/asm/mce.h')
-rw-r--r-- | arch/x86/include/asm/mce.h | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/arch/x86/include/asm/mce.h b/arch/x86/include/asm/mce.h index ba1f8890cf51..afd3cdf6f8ad 100644 --- a/arch/x86/include/asm/mce.h +++ b/arch/x86/include/asm/mce.h | |||
@@ -15,6 +15,7 @@ | |||
15 | #define MCG_EXT_CNT_MASK 0xff0000 /* Number of Extended registers */ | 15 | #define MCG_EXT_CNT_MASK 0xff0000 /* Number of Extended registers */ |
16 | #define MCG_EXT_CNT_SHIFT 16 | 16 | #define MCG_EXT_CNT_SHIFT 16 |
17 | #define MCG_EXT_CNT(c) (((c) & MCG_EXT_CNT_MASK) >> MCG_EXT_CNT_SHIFT) | 17 | #define MCG_EXT_CNT(c) (((c) & MCG_EXT_CNT_MASK) >> MCG_EXT_CNT_SHIFT) |
18 | #define MCG_SER_P (1ULL<<24) /* MCA recovery/new status bits */ | ||
18 | 19 | ||
19 | #define MCG_STATUS_RIPV (1ULL<<0) /* restart ip valid */ | 20 | #define MCG_STATUS_RIPV (1ULL<<0) /* restart ip valid */ |
20 | #define MCG_STATUS_EIPV (1ULL<<1) /* ip points to correct instruction */ | 21 | #define MCG_STATUS_EIPV (1ULL<<1) /* ip points to correct instruction */ |
@@ -27,6 +28,15 @@ | |||
27 | #define MCI_STATUS_MISCV (1ULL<<59) /* misc error reg. valid */ | 28 | #define MCI_STATUS_MISCV (1ULL<<59) /* misc error reg. valid */ |
28 | #define MCI_STATUS_ADDRV (1ULL<<58) /* addr reg. valid */ | 29 | #define MCI_STATUS_ADDRV (1ULL<<58) /* addr reg. valid */ |
29 | #define MCI_STATUS_PCC (1ULL<<57) /* processor context corrupt */ | 30 | #define MCI_STATUS_PCC (1ULL<<57) /* processor context corrupt */ |
31 | #define MCI_STATUS_S (1ULL<<56) /* Signaled machine check */ | ||
32 | #define MCI_STATUS_AR (1ULL<<55) /* Action required */ | ||
33 | |||
34 | /* MISC register defines */ | ||
35 | #define MCM_ADDR_SEGOFF 0 /* segment offset */ | ||
36 | #define MCM_ADDR_LINEAR 1 /* linear address */ | ||
37 | #define MCM_ADDR_PHYS 2 /* physical address */ | ||
38 | #define MCM_ADDR_MEM 3 /* memory address */ | ||
39 | #define MCM_ADDR_GENERIC 7 /* generic */ | ||
30 | 40 | ||
31 | /* Fields are zero when not available */ | 41 | /* Fields are zero when not available */ |
32 | struct mce { | 42 | struct mce { |