提交 f9695df4 编写于 作者: A Andi Kleen 提交者: H. Peter Anvin

x86, mce, cmci: avoid potential reentry of threshold interrupt

Impact: minor bugfix

The threshold handler on AMD (and soon on Intel) could be theoretically
reentered by the hardware. This could lead to corrupted events
because the machine check poll code assumes it is not reentered.

Move the APIC ACK to the end of the interrupt handler to let
the hardware avoid that.
Signed-off-by: NAndi Kleen <ak@linux.intel.com>
Signed-off-by: NH. Peter Anvin <hpa@zytor.com>
上级 b2762686
...@@ -15,10 +15,11 @@ void (*mce_threshold_vector)(void) = default_threshold_interrupt; ...@@ -15,10 +15,11 @@ void (*mce_threshold_vector)(void) = default_threshold_interrupt;
asmlinkage void mce_threshold_interrupt(void) asmlinkage void mce_threshold_interrupt(void)
{ {
ack_APIC_irq();
exit_idle(); exit_idle();
irq_enter(); irq_enter();
inc_irq_stat(irq_threshold_count); inc_irq_stat(irq_threshold_count);
mce_threshold_vector(); mce_threshold_vector();
irq_exit(); irq_exit();
/* Ack only at the end to avoid potential reentry */
ack_APIC_irq();
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册