KVM: arm64: vgic: Allow registration of a non-maskable maintenance interrupt
authorMarc Zyngier <maz@kernel.org>
Tue, 3 Jan 2023 09:50:21 +0000 (09:50 +0000)
committerOliver Upton <oliver.upton@linux.dev>
Thu, 12 Jan 2023 21:13:27 +0000 (21:13 +0000)
Our Apple M1/M2 friends do have a per-CPU maintenance interrupt,
but no mask to make use of it in the standard Linux framework.

Given that KVM directly drives the *source* of the interrupt and
leaves the GIC interrupt always enabled, there is no harm in tolerating
such a setup. It will become useful once we enable NV on M2 HW.

Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20230103095022.3230946-3-maz@kernel.org
Signed-off-by: Oliver Upton <oliver.upton@linux.dev>
arch/arm64/kvm/vgic/vgic-init.c

index f6d4f4052555c79aef58f3d7b87440dbe9c7c276..e61d9ca017684c2b240da01cb86ea788ac92026f 100644 (file)
@@ -572,7 +572,7 @@ int kvm_vgic_hyp_init(void)
        if (ret)
                return ret;
 
-       if (!has_mask)
+       if (!has_mask && !kvm_vgic_global_state.maint_irq)
                return 0;
 
        ret = request_percpu_irq(kvm_vgic_global_state.maint_irq,