KVM: arm64: Rework detection of SVE, !VHE systems
authorMarc Zyngier <marc.zyngier@arm.com>
Thu, 6 Dec 2018 17:31:20 +0000 (17:31 +0000)
committerWill Deacon <will.deacon@arm.com>
Mon, 10 Dec 2018 11:57:52 +0000 (11:57 +0000)
An SVE system is so far the only case where we mandate VHE. As we're
starting to grow this requirements, let's slightly rework the way we
deal with that situation, allowing for easy extension of this check.

Acked-by: Christoffer Dall <christoffer.dall@arm.com>
Reviewed-by: James Morse <james.morse@arm.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
arch/arm/include/asm/kvm_host.h
arch/arm64/include/asm/kvm_host.h
virt/kvm/arm/arm.c

index 5ca5d9af0c26eade774f336aa7159b55ec06d5cd..2184d9ddb418b8bf4251cef54288c79ca17f22f1 100644 (file)
@@ -285,7 +285,7 @@ void kvm_mmu_wp_memory_region(struct kvm *kvm, int slot);
 
 struct kvm_vcpu *kvm_mpidr_to_vcpu(struct kvm *kvm, unsigned long mpidr);
 
-static inline bool kvm_arch_check_sve_has_vhe(void) { return true; }
+static inline bool kvm_arch_requires_vhe(void) { return false; }
 static inline void kvm_arch_hardware_unsetup(void) {}
 static inline void kvm_arch_sync_events(struct kvm *kvm) {}
 static inline void kvm_arch_vcpu_uninit(struct kvm_vcpu *vcpu) {}
index 52fbc823ff8c7f52dcd924fe94bb0be603150e1f..d6d9aa76a943faf5ac4bea506e344e175cbf920b 100644 (file)
@@ -422,7 +422,7 @@ static inline void __cpu_init_hyp_mode(phys_addr_t pgd_ptr,
        }
 }
 
-static inline bool kvm_arch_check_sve_has_vhe(void)
+static inline bool kvm_arch_requires_vhe(void)
 {
        /*
         * The Arm architecture specifies that implementation of SVE
@@ -430,9 +430,9 @@ static inline bool kvm_arch_check_sve_has_vhe(void)
         * relies on this when SVE is present:
         */
        if (system_supports_sve())
-               return has_vhe();
-       else
                return true;
+
+       return false;
 }
 
 static inline void kvm_arch_hardware_unsetup(void) {}
index 23774970c9df66fb771210df9374bf10c0abbffa..36165748a315962b438a358eeec0020193ea330a 100644 (file)
@@ -1640,8 +1640,10 @@ int kvm_arch_init(void *opaque)
                return -ENODEV;
        }
 
-       if (!kvm_arch_check_sve_has_vhe()) {
-               kvm_pr_unimpl("SVE system without VHE unsupported.  Broken cpu?");
+       in_hyp_mode = is_kernel_in_hyp_mode();
+
+       if (!in_hyp_mode && kvm_arch_requires_vhe()) {
+               kvm_pr_unimpl("CPU unsupported in non-VHE mode, not initializing\n");
                return -ENODEV;
        }
 
@@ -1657,8 +1659,6 @@ int kvm_arch_init(void *opaque)
        if (err)
                return err;
 
-       in_hyp_mode = is_kernel_in_hyp_mode();
-
        if (!in_hyp_mode) {
                err = init_hyp_mode();
                if (err)