Commit 33e5f4e5 authored by Marc Zyngier's avatar Marc Zyngier Committed by Will Deacon

KVM: arm64: Rework detection of SVE, !VHE systems

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: default avatarChristoffer Dall <christoffer.dall@arm.com>
Reviewed-by: default avatarJames Morse <james.morse@arm.com>
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
Signed-off-by: default avatarWill Deacon <will.deacon@arm.com>
parent c987876a
...@@ -285,7 +285,7 @@ void kvm_mmu_wp_memory_region(struct kvm *kvm, int slot); ...@@ -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); 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_hardware_unsetup(void) {}
static inline void kvm_arch_sync_events(struct kvm *kvm) {} static inline void kvm_arch_sync_events(struct kvm *kvm) {}
static inline void kvm_arch_vcpu_uninit(struct kvm_vcpu *vcpu) {} static inline void kvm_arch_vcpu_uninit(struct kvm_vcpu *vcpu) {}
......
...@@ -422,7 +422,7 @@ static inline void __cpu_init_hyp_mode(phys_addr_t pgd_ptr, ...@@ -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 * The Arm architecture specifies that implementation of SVE
...@@ -430,9 +430,9 @@ static inline bool kvm_arch_check_sve_has_vhe(void) ...@@ -430,9 +430,9 @@ static inline bool kvm_arch_check_sve_has_vhe(void)
* relies on this when SVE is present: * relies on this when SVE is present:
*/ */
if (system_supports_sve()) if (system_supports_sve())
return has_vhe();
else
return true; return true;
return false;
} }
static inline void kvm_arch_hardware_unsetup(void) {} static inline void kvm_arch_hardware_unsetup(void) {}
......
...@@ -1640,8 +1640,10 @@ int kvm_arch_init(void *opaque) ...@@ -1640,8 +1640,10 @@ int kvm_arch_init(void *opaque)
return -ENODEV; return -ENODEV;
} }
if (!kvm_arch_check_sve_has_vhe()) { in_hyp_mode = is_kernel_in_hyp_mode();
kvm_pr_unimpl("SVE system without VHE unsupported. Broken cpu?");
if (!in_hyp_mode && kvm_arch_requires_vhe()) {
kvm_pr_unimpl("CPU unsupported in non-VHE mode, not initializing\n");
return -ENODEV; return -ENODEV;
} }
...@@ -1657,8 +1659,6 @@ int kvm_arch_init(void *opaque) ...@@ -1657,8 +1659,6 @@ int kvm_arch_init(void *opaque)
if (err) if (err)
return err; return err;
in_hyp_mode = is_kernel_in_hyp_mode();
if (!in_hyp_mode) { if (!in_hyp_mode) {
err = init_hyp_mode(); err = init_hyp_mode();
if (err) if (err)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment