Commit cbfa482f authored by Tony Luck's avatar Tony Luck Committed by Borislav Petkov

EDAC, skx_common: Add code to recognise new compound error code

A new error code for systems that use DRAM as an extra level of cache
looks like:

    000F 0010 1MMM CCCC

where the MMM and CCCC bits are used for the same purpose as the
original code. For this new class of errors the ADXL translation will
provide details of both the DIMM used as cache for the error location
and the component that is being cached.

Note: This new error code is first supported in Skylake. Older EDAC
drivers do not need to be updated.
Signed-off-by: default avatarTony Luck <tony.luck@intel.com>
Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
Cc: Aristeu Rozanski <aris@redhat.com>
Cc: James Morse <james.morse@arm.com>
Cc: Mauro Carvalho Chehab <mchehab@kernel.org>
Cc: Qiuxu Zhuo <qiuxu.zhuo@intel.com>
Cc: linux-edac <linux-edac@vger.kernel.org>
Link: https://lkml.kernel.org/r/20190205182109.27828-1-tony.luck@intel.com
parent d6a9f733
...@@ -494,9 +494,11 @@ static void skx_mce_output_error(struct mem_ctl_info *mci, ...@@ -494,9 +494,11 @@ static void skx_mce_output_error(struct mem_ctl_info *mci,
} }
/* /*
* According with Table 15-9 of the Intel Architecture spec vol 3A, * According to Intel Architecture spec vol 3B,
* memory errors should fit in this mask: * Table 15-10 "IA32_MCi_Status [15:0] Compound Error Code Encoding"
* memory errors should fit one of these masks:
* 000f 0000 1mmm cccc (binary) * 000f 0000 1mmm cccc (binary)
* 000f 0010 1mmm cccc (binary) [RAM used as cache]
* where: * where:
* f = Correction Report Filtering Bit. If 1, subsequent errors * f = Correction Report Filtering Bit. If 1, subsequent errors
* won't be shown * won't be shown
...@@ -504,7 +506,7 @@ static void skx_mce_output_error(struct mem_ctl_info *mci, ...@@ -504,7 +506,7 @@ static void skx_mce_output_error(struct mem_ctl_info *mci,
* cccc = channel * cccc = channel
* If the mask doesn't match, report an error to the parsing logic * If the mask doesn't match, report an error to the parsing logic
*/ */
if (!((errcode & 0xef80) == 0x80)) { if (!((errcode & 0xef80) == 0x80 || (errcode & 0xef80) == 0x280)) {
optype = "Can't parse: it is not a mem"; optype = "Can't parse: it is not a mem";
} else { } else {
switch (optypenum) { switch (optypenum) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment