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:
parent
a3a529d104
commit
8dcf32ea22
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue