]> git.baikalelectronics.ru Git - kernel.git/commit
x86/apic: Mask IOAPIC entries when disabling the local APIC
authorTony W Wang-oc <TonyWWang-oc@zhaoxin.com>
Wed, 15 Jan 2020 08:22:19 +0000 (16:22 +0800)
committerThomas Gleixner <tglx@linutronix.de>
Fri, 7 Feb 2020 14:32:16 +0000 (15:32 +0100)
commit780a1f39c95a4dd3beeee820dbe6283f0f3b44bd
tree7b69609200913e2fd5e3f1f886de6de997461206
parent98e292da8cc558d3b2627e3ffb50560cadf467e9
x86/apic: Mask IOAPIC entries when disabling the local APIC

When a system suspends, the local APIC is disabled in the suspend sequence,
but the IOAPIC is left in the current state. This means unmasked interrupt
lines stay unmasked. This is usually the case for IOAPIC pin 9 to which the
ACPI interrupt is connected.

That means that in suspended state the IOAPIC can respond to an external
interrupt, e.g. the wakeup via keyboard/RTC/ACPI, but the interrupt message
cannot be handled by the disabled local APIC. As a consequence the Remote
IRR bit is set, but the local APIC does not send an EOI to acknowledge
it. This causes the affected interrupt line to become stale and the stale
Remote IRR bit will cause a hang when __synchronize_hardirq() is invoked
for that interrupt line.

To prevent this, mask all IOAPIC entries before disabling the local
APIC. The resume code already has the unmask operation inside.

[ tglx: Massaged changelog ]

Signed-off-by: Tony W Wang-oc <TonyWWang-oc@zhaoxin.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Link: https://lore.kernel.org/r/1579076539-7267-1-git-send-email-TonyWWang-oc@zhaoxin.com
arch/x86/kernel/apic/apic.c