]> git.baikalelectronics.ru Git - kernel.git/commit
powerpc/64: Fix __check_irq_replay missing decrementer interrupt
authorNicholas Piggin <npiggin@gmail.com>
Tue, 1 Aug 2017 13:59:28 +0000 (23:59 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Fri, 4 Aug 2017 02:55:49 +0000 (12:55 +1000)
commitb2918c8ddacebe931dff6e300a8d9ad3ccaadc43
tree2196c3e40ef7d75b372018fae21ad0bbb1731ee1
parent4477e93bed1d95c43af36121783ddfaff117cbd1
powerpc/64: Fix __check_irq_replay missing decrementer interrupt

If the decrementer wraps again and de-asserts the decrementer
exception while hard-disabled, __check_irq_replay() has a test to
notice the wrap when interrupts are re-enabled.

The decrementer check must be done when clearing the PACA_IRQ_HARD_DIS
flag, not when the PACA_IRQ_DEC flag is tested. Previously this worked
because the decrementer interrupt was always the first one checked
after clearing the hard disable flag, but HMI check was moved ahead of
that, which introduced this bug.

This can cause a missed decrementer interrupt if we soft-disable
interrupts then take an HMI which is recorded in irq_happened, then
hard-disable interrupts for > 4s to wrap the decrementer.

Fixes: 42fae450515b ("powerpc/64: Replay hypervisor maintenance interrupt first")
Cc: stable@vger.kernel.org # v4.9+
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/kernel/irq.c