diff options
Diffstat (limited to 'arch/arm64/kvm/arm.c')
| -rw-r--r-- | arch/arm64/kvm/arm.c | 16 | 
1 files changed, 11 insertions, 5 deletions
| diff --git a/arch/arm64/kvm/arm.c b/arch/arm64/kvm/arm.c index 400bb0fe2745..83a7f61354d3 100644 --- a/arch/arm64/kvm/arm.c +++ b/arch/arm64/kvm/arm.c @@ -150,8 +150,10 @@ int kvm_arch_init_vm(struct kvm *kvm, unsigned long type)  	if (ret)  		goto out_free_stage2_pgd; -	if (!zalloc_cpumask_var(&kvm->arch.supported_cpus, GFP_KERNEL)) +	if (!zalloc_cpumask_var(&kvm->arch.supported_cpus, GFP_KERNEL)) { +		ret = -ENOMEM;  		goto out_free_stage2_pgd; +	}  	cpumask_copy(kvm->arch.supported_cpus, cpu_possible_mask);  	kvm_vgic_early_init(kvm); @@ -2110,11 +2112,11 @@ static int finalize_hyp_mode(void)  		return 0;  	/* -	 * Exclude HYP BSS from kmemleak so that it doesn't get peeked -	 * at, which would end badly once the section is inaccessible. -	 * None of other sections should ever be introspected. +	 * Exclude HYP sections from kmemleak so that they don't get peeked +	 * at, which would end badly once inaccessible.  	 */  	kmemleak_free_part(__hyp_bss_start, __hyp_bss_end - __hyp_bss_start); +	kmemleak_free_part(__va(hyp_mem_base), hyp_mem_size);  	return pkvm_drop_host_privileges();  } @@ -2271,7 +2273,11 @@ static int __init early_kvm_mode_cfg(char *arg)  		return -EINVAL;  	if (strcmp(arg, "protected") == 0) { -		kvm_mode = KVM_MODE_PROTECTED; +		if (!is_kernel_in_hyp_mode()) +			kvm_mode = KVM_MODE_PROTECTED; +		else +			pr_warn_once("Protected KVM not available with VHE\n"); +  		return 0;  	} | 
