x86, mce: Xeon75xx specific interface to get corrected memory error information
[linux-flexiantxendom0-natty.git] / arch / x86 / kernel / cpu / mcheck / mce-internal.h
1 #include <linux/sysdev.h>
2 #include <asm/mce.h>
3
4 enum severity_level {
5         MCE_NO_SEVERITY,
6         MCE_KEEP_SEVERITY,
7         MCE_SOME_SEVERITY,
8         MCE_AO_SEVERITY,
9         MCE_UC_SEVERITY,
10         MCE_AR_SEVERITY,
11         MCE_PANIC_SEVERITY,
12 };
13
14 #define ATTR_LEN                16
15
16 /* One object for each MCE bank, shared by all CPUs */
17 struct mce_bank {
18         u64                     ctl;                    /* subevents to enable */
19         unsigned char init;                             /* initialise bank? */
20         struct sysdev_attribute attr;                   /* sysdev attribute */
21         char                    attrname[ATTR_LEN];     /* attribute name */
22 };
23
24 int mce_severity(struct mce *a, int tolerant, char **msg);
25 struct dentry *mce_get_debugfs_dir(void);
26
27 extern int mce_ser;
28
29 extern struct mce_bank *mce_banks;
30
31 extern void (*cpu_specific_poll)(struct mce *);
32
33 #ifdef CONFIG_ACPI_APEI
34 int apei_write_mce(struct mce *m);
35 ssize_t apei_read_mce(struct mce *m, u64 *record_id);
36 int apei_check_mce(void);
37 int apei_clear_mce(u64 record_id);
38 #else
39 static inline int apei_write_mce(struct mce *m)
40 {
41         return -EINVAL;
42 }
43 static inline ssize_t apei_read_mce(struct mce *m, u64 *record_id)
44 {
45         return 0;
46 }
47 static inline int apei_check_mce(void)
48 {
49         return 0;
50 }
51 static inline int apei_clear_mce(u64 record_id)
52 {
53         return -EINVAL;
54 }
55 #endif