EDAC, mce_amd_inj: Enable direct writes to MCE MSRs
authorBorislav Petkov <bp@suse.de>
Sat, 22 Nov 2014 10:22:35 +0000 (11:22 +0100)
committerBorislav Petkov <bp@suse.de>
Tue, 25 Nov 2014 12:09:37 +0000 (13:09 +0100)
Normally, writing those causes a #GP but HWCR[McStatusWrEn] controls
that. Provide a knob.

Signed-off-by: Borislav Petkov <bp@suse.de>
drivers/edac/mce_amd_inj.c

index 9b5023d6f5530bb867f2a3cb951a8456825d98b3..9b5ca92737a23314994a54295fc82a60f33b129f 100644 (file)
@@ -54,6 +54,30 @@ DEFINE_SIMPLE_ATTRIBUTE(status_fops, inj_status_get, inj_status_set, "%llx\n");
 DEFINE_SIMPLE_ATTRIBUTE(misc_fops, inj_misc_get, inj_misc_set, "%llx\n");
 DEFINE_SIMPLE_ATTRIBUTE(addr_fops, inj_addr_get, inj_addr_set, "%llx\n");
 
+/*
+ * Caller needs to be make sure this cpu doesn't disappear
+ * from under us, i.e.: get_cpu/put_cpu.
+ */
+static int toggle_hw_mce_inject(unsigned int cpu, bool enable)
+{
+       u32 l, h;
+       int err;
+
+       err = rdmsr_on_cpu(cpu, MSR_K7_HWCR, &l, &h);
+       if (err) {
+               pr_err("%s: error reading HWCR\n", __func__);
+               return err;
+       }
+
+       enable ? (l |= BIT(18)) : (l &= ~BIT(18));
+
+       err = wrmsr_on_cpu(cpu, MSR_K7_HWCR, l, h);
+       if (err)
+               pr_err("%s: error writing HWCR\n", __func__);
+
+       return err;
+}
+
 /*
  * This denotes into which bank we're injecting and triggers
  * the injection, at the same time.