diff options
author | Marc Zyngier <maz@kernel.org> | 2022-03-17 10:49:02 +0100 |
---|---|---|
committer | Marc Zyngier <maz@kernel.org> | 2022-04-05 17:33:13 +0200 |
commit | af27e41612ec7e5b4783f589b753a7c31a37aac8 (patch) | |
tree | c8faa04942b674ff973e59afb75c0b37378972a4 /drivers/irqchip/irq-brcmstb-l2.c | |
parent | irqchip/irq-qcom-mpm: fix return value check in qcom_mpm_init() (diff) | |
download | linux-af27e41612ec7e5b4783f589b753a7c31a37aac8.tar.xz linux-af27e41612ec7e5b4783f589b753a7c31a37aac8.zip |
irqchip/gic-v4: Wait for GICR_VPENDBASER.Dirty to clear before descheduling
The way KVM drives GICv4.{0,1} is as follows:
- vcpu_load() makes the VPE resident, instructing the RD to start
scanning for interrupts
- just before entering the guest, we check that the RD has finished
scanning and that we can start running the vcpu
- on preemption, we deschedule the VPE by making it invalid on
the RD
However, we are preemptible between the first two steps. If it so
happens *and* that the RD was still scanning, we nonetheless write
to the GICR_VPENDBASER register while Dirty is set, and bad things
happen (we're in UNPRED land).
This affects both the 4.0 and 4.1 implementations.
Make sure Dirty is cleared before performing the deschedule,
meaning that its_clear_vpend_valid() becomes a sort of full VPE
residency barrier.
Reported-by: Jingyi Wang <wangjingyi11@huawei.com>
Tested-by: Nianyao Tang <tangnianyao@huawei.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Fixes: 57e3cebd022f ("KVM: arm64: Delay the polling of the GICR_VPENDBASER.Dirty bit")
Link: https://lore.kernel.org/r/4aae10ba-b39a-5f84-754b-69c2eb0a2c03@huawei.com
Diffstat (limited to 'drivers/irqchip/irq-brcmstb-l2.c')
0 files changed, 0 insertions, 0 deletions