[PATCH] x86: bug fix in P6 Machine check initialization
Make P6 MCA initialization code complaint with guidelines in IA-32 SDM Vol3. Bank 0 control register should not be set by OS and clear status registers on all banks on reset. This will prevent false MCE alarms on the systems that has some non-MCE information left-over in MC0_STATUS on reboot. Signed-off-by: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
251e6912df
commit
434440a280
1 changed files with 8 additions and 3 deletions
|
@ -102,11 +102,16 @@ void __devinit intel_p6_mcheck_init(struct cpuinfo_x86 *c)
|
||||||
wrmsr(MSR_IA32_MCG_CTL, 0xffffffff, 0xffffffff);
|
wrmsr(MSR_IA32_MCG_CTL, 0xffffffff, 0xffffffff);
|
||||||
nr_mce_banks = l & 0xff;
|
nr_mce_banks = l & 0xff;
|
||||||
|
|
||||||
/* Don't enable bank 0 on intel P6 cores, it goes bang quickly. */
|
/*
|
||||||
for (i=1; i<nr_mce_banks; i++) {
|
* Following the example in IA-32 SDM Vol 3:
|
||||||
|
* - MC0_CTL should not be written
|
||||||
|
* - Status registers on all banks should be cleared on reset
|
||||||
|
*/
|
||||||
|
for (i=1; i<nr_mce_banks; i++)
|
||||||
wrmsr (MSR_IA32_MC0_CTL+4*i, 0xffffffff, 0xffffffff);
|
wrmsr (MSR_IA32_MC0_CTL+4*i, 0xffffffff, 0xffffffff);
|
||||||
|
|
||||||
|
for (i=0; i<nr_mce_banks; i++)
|
||||||
wrmsr (MSR_IA32_MC0_STATUS+4*i, 0x0, 0x0);
|
wrmsr (MSR_IA32_MC0_STATUS+4*i, 0x0, 0x0);
|
||||||
}
|
|
||||||
|
|
||||||
set_in_cr4 (X86_CR4_MCE);
|
set_in_cr4 (X86_CR4_MCE);
|
||||||
printk (KERN_INFO "Intel machine check reporting enabled on CPU#%d.\n",
|
printk (KERN_INFO "Intel machine check reporting enabled on CPU#%d.\n",
|
||||||
|
|
Loading…
Reference in a new issue