Skip to content

Commit 5d96c93

Browse files
stellarhoppersuryasaimadhu
authored andcommitted
acpi/nfit, x86/mce: Handle only uncorrectable machine checks
The MCE handler for nfit devices is called for memory errors on a Non-Volatile DIMM and adds the error location to a 'badblocks' list. This list is used by the various NVDIMM drivers to avoid consuming known poison locations during IO. The MCE handler gets called for both corrected and uncorrectable errors. Until now, both kinds of errors have been added to the badblocks list. However, corrected memory errors indicate that the problem has already been fixed by hardware, and the resulting interrupt is merely a notification to Linux. As far as future accesses to that location are concerned, it is perfectly fine to use, and thus doesn't need to be included in the above badblocks list. Add a check in the nfit MCE handler to filter out corrected mce events, and only process uncorrectable errors. Fixes: 6839a6d ("nfit: do an ARS scrub on hitting a latent media error") Reported-by: Omar Avelar <omar.avelar@intel.com> Signed-off-by: Vishal Verma <vishal.l.verma@intel.com> Signed-off-by: Borislav Petkov <bp@suse.de> CC: Arnd Bergmann <arnd@arndb.de> CC: Dan Williams <dan.j.williams@intel.com> CC: Dave Jiang <dave.jiang@intel.com> CC: elliott@hpe.com CC: "H. Peter Anvin" <hpa@zytor.com> CC: Ingo Molnar <mingo@redhat.com> CC: Len Brown <lenb@kernel.org> CC: linux-acpi@vger.kernel.org CC: linux-edac <linux-edac@vger.kernel.org> CC: linux-nvdimm@lists.01.org CC: Qiuxu Zhuo <qiuxu.zhuo@intel.com> CC: "Rafael J. Wysocki" <rjw@rjwysocki.net> CC: Ross Zwisler <zwisler@kernel.org> CC: stable <stable@vger.kernel.org> CC: Thomas Gleixner <tglx@linutronix.de> CC: Tony Luck <tony.luck@intel.com> CC: x86-ml <x86@kernel.org> CC: Yazen Ghannam <yazen.ghannam@amd.com> Link: http://lkml.kernel.org/r/20181026003729.8420-1-vishal.l.verma@intel.com
1 parent 437e88a commit 5d96c93

File tree

3 files changed

+5
-3
lines changed

3 files changed

+5
-3
lines changed

arch/x86/include/asm/mce.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -221,6 +221,7 @@ static inline void mce_hygon_feature_init(struct cpuinfo_x86 *c) { return mce_am
221221

222222
int mce_available(struct cpuinfo_x86 *c);
223223
bool mce_is_memory_error(struct mce *m);
224+
bool mce_is_correctable(struct mce *m);
224225

225226
DECLARE_PER_CPU(unsigned, mce_exception_count);
226227
DECLARE_PER_CPU(unsigned, mce_poll_count);

arch/x86/kernel/cpu/mcheck/mce.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -534,7 +534,7 @@ bool mce_is_memory_error(struct mce *m)
534534
}
535535
EXPORT_SYMBOL_GPL(mce_is_memory_error);
536536

537-
static bool mce_is_correctable(struct mce *m)
537+
bool mce_is_correctable(struct mce *m)
538538
{
539539
if (m->cpuvendor == X86_VENDOR_AMD && m->status & MCI_STATUS_DEFERRED)
540540
return false;
@@ -547,6 +547,7 @@ static bool mce_is_correctable(struct mce *m)
547547

548548
return true;
549549
}
550+
EXPORT_SYMBOL_GPL(mce_is_correctable);
550551

551552
static bool cec_add_mce(struct mce *m)
552553
{

drivers/acpi/nfit/mce.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -25,8 +25,8 @@ static int nfit_handle_mce(struct notifier_block *nb, unsigned long val,
2525
struct acpi_nfit_desc *acpi_desc;
2626
struct nfit_spa *nfit_spa;
2727

28-
/* We only care about memory errors */
29-
if (!mce_is_memory_error(mce))
28+
/* We only care about uncorrectable memory errors */
29+
if (!mce_is_memory_error(mce) || mce_is_correctable(mce))
3030
return NOTIFY_DONE;
3131

3232
/*

0 commit comments

Comments
 (0)