KVM: arm/arm64: vgic-its: Invalidate MSI-LPI translation cache on ITS disable
authorMarc Zyngier <maz@kernel.org>
Wed, 22 May 2019 17:16:49 +0000 (18:16 +0100)
committerMarc Zyngier <maz@kernel.org>
Sun, 18 Aug 2019 17:38:49 +0000 (18:38 +0100)
If an ITS gets disabled, we need to make sure that further interrupts
won't hit in the cache. For that, we invalidate the translation cache
when the ITS is disabled.

Tested-by: Andre Przywara <andre.przywara@arm.com>
Reviewed-by: Eric Auger <eric.auger@redhat.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
virt/kvm/arm/vgic/vgic-its.c

index 09a1798..05406bd 100644 (file)
@@ -1597,6 +1597,8 @@ static void vgic_mmio_write_its_ctlr(struct kvm *kvm, struct vgic_its *its,
                goto out;
 
        its->enabled = !!(val & GITS_CTLR_ENABLE);
+       if (!its->enabled)
+               vgic_its_invalidate_cache(kvm);
 
        /*
         * Try to process any pending commands. This function bails out early