|
@@ -165,15 +165,19 @@ static struct severity {
|
|
};
|
|
};
|
|
|
|
|
|
/*
|
|
/*
|
|
- * If the EIPV bit is set, it means the saved IP is the
|
|
|
|
- * instruction which caused the MCE.
|
|
|
|
|
|
+ * If mcgstatus indicated that ip/cs on the stack were
|
|
|
|
+ * no good, then "m->cs" will be zero and we will have
|
|
|
|
+ * to assume the worst case (IN_KERNEL) as we actually
|
|
|
|
+ * have no idea what we were executing when the machine
|
|
|
|
+ * check hit.
|
|
|
|
+ * If we do have a good "m->cs" (or a faked one in the
|
|
|
|
+ * case we were executing in VM86 mode) we can use it to
|
|
|
|
+ * distinguish an exception taken in user from from one
|
|
|
|
+ * taken in the kernel.
|
|
*/
|
|
*/
|
|
static int error_context(struct mce *m)
|
|
static int error_context(struct mce *m)
|
|
{
|
|
{
|
|
- if (m->mcgstatus & MCG_STATUS_EIPV)
|
|
|
|
- return (m->ip && (m->cs & 3) == 3) ? IN_USER : IN_KERNEL;
|
|
|
|
- /* Unknown, assume kernel */
|
|
|
|
- return IN_KERNEL;
|
|
|
|
|
|
+ return ((m->cs & 3) == 3) ? IN_USER : IN_KERNEL;
|
|
}
|
|
}
|
|
|
|
|
|
int mce_severity(struct mce *m, int tolerant, char **msg)
|
|
int mce_severity(struct mce *m, int tolerant, char **msg)
|