KVM: arm64: Explicitly map 'kvm_vgic_global_state' at EL2
authorQuentin Perret <qperret@google.com>
Thu, 10 Nov 2022 19:02:56 +0000 (19:02 +0000)
committerMarc Zyngier <maz@kernel.org>
Fri, 11 Nov 2022 17:19:35 +0000 (17:19 +0000)
The pkvm hypervisor at EL2 may need to read the 'kvm_vgic_global_state'
variable from the host, for example when saving and restoring the state
of the virtual GIC.

Explicitly map 'kvm_vgic_global_state' in the stage-1 page-table of the
pKVM hypervisor rather than relying on mapping all of the host '.rodata'
section.

Tested-by: Vincent Donnefort <vdonnefort@google.com>
Signed-off-by: Quentin Perret <qperret@google.com>
Signed-off-by: Will Deacon <will@kernel.org>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20221110190259.26861-24-will@kernel.org
arch/arm64/kvm/hyp/nvhe/setup.c

index 0f69c13..5a371ab 100644 (file)
@@ -161,6 +161,11 @@ static int recreate_hyp_mappings(phys_addr_t phys, unsigned long size,
        if (ret)
                return ret;
 
+       ret = pkvm_create_mappings(&kvm_vgic_global_state,
+                                  &kvm_vgic_global_state + 1, prot);
+       if (ret)
+               return ret;
+
        return 0;
 }