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>
 
 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) {}
 
        }
 }
 
-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
         * 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) {}
 
                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;
        }
 
        if (err)
                return err;
 
-       in_hyp_mode = is_kernel_in_hyp_mode();
-
        if (!in_hyp_mode) {
                err = init_hyp_mode();
                if (err)