]> git.baikalelectronics.ru Git - kernel.git/commit
KVM: arm/arm64: vgic-v3: Always resample level interrupts
authorMarc Zyngier <marc.zyngier@arm.com>
Wed, 25 May 2016 14:26:36 +0000 (15:26 +0100)
committerChristoffer Dall <christoffer.dall@linaro.org>
Tue, 31 May 2016 14:12:16 +0000 (16:12 +0200)
commitc9400032ba4d8063a9f547639d6721ca0ef66599
tree3877decc283a8c351c2c6d55621cf56ee5d6f2ea
parent9af848b5bd297e94461ce45edb8908f576f1bcb4
KVM: arm/arm64: vgic-v3: Always resample level interrupts

When reading back from the list registers, we need to perform
two actions for level interrupts:
1) clear the soft-pending bit if the interrupt is not pending
   anymore *in the list register*
2) resample the line level and propagate it to the pending state

But these two actions shouldn't be linked, and we should *always*
resample the line level, no matter what state is in the list
register. Otherwise, we may end-up injecting spurious interrupts
that have been already retired.

Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
virt/kvm/arm/vgic/vgic-v3.c