x86, MCE, AMD: Assign interrupt handler only when bank supports it

There are some AMD CPU models which have thresholding banks but which
cannot generate a thresholding interrupt. This is denoted by the bit
MCi_MISC[IntP]. Make sure to check that bit before assigning the
thresholding interrupt handler.

Signed-off-by: Chen Yucong <slaoub@gmail.com>
[ Boris: save an indentation level and rewrite commit message. ]
Link: http://lkml.kernel.org/r/1412662128.28440.18.camel@debian
Signed-off-by: Borislav Petkov <bp@suse.de>
This commit is contained in:
Chen Yucong 2014-11-01 11:23:32 +01:00 committed by Borislav Petkov
parent a3a529d104
commit 8dcf32ea22
1 changed files with 10 additions and 7 deletions

View File

@ -212,7 +212,7 @@ void mce_amd_feature_init(struct cpuinfo_x86 *c)
unsigned int cpu = smp_processor_id(); unsigned int cpu = smp_processor_id();
u32 low = 0, high = 0, address = 0; u32 low = 0, high = 0, address = 0;
unsigned int bank, block; unsigned int bank, block;
int offset = -1; int offset = -1, new;
for (bank = 0; bank < mca_cfg.banks; ++bank) { for (bank = 0; bank < mca_cfg.banks; ++bank) {
for (block = 0; block < NR_BLOCKS; ++block) { for (block = 0; block < NR_BLOCKS; ++block) {
@ -247,15 +247,18 @@ void mce_amd_feature_init(struct cpuinfo_x86 *c)
b.address = address; b.address = address;
b.interrupt_capable = lvt_interrupt_supported(bank, high); b.interrupt_capable = lvt_interrupt_supported(bank, high);
if (b.interrupt_capable) { if (!b.interrupt_capable)
int new = (high & MASK_LVTOFF_HI) >> 20; goto init;
offset = setup_APIC_mce(offset, new);
}
mce_threshold_block_init(&b, offset); new = (high & MASK_LVTOFF_HI) >> 20;
offset = setup_APIC_mce(offset, new);
if (mce_threshold_vector != amd_threshold_interrupt) if ((offset == new) &&
(mce_threshold_vector != amd_threshold_interrupt))
mce_threshold_vector = amd_threshold_interrupt; mce_threshold_vector = amd_threshold_interrupt;
init:
mce_threshold_block_init(&b, offset);
} }
} }
} }