[PATCH 1/2] arm/arm64: kvm: Move initialization completion message

Marc Zyngier marc.zyngier at arm.com
Fri Oct 20 01:57:50 PDT 2017


On 19/10/17 16:45, Julien Thierry wrote:
> KVM is being a bit too optimistic, Hyp mode is said to be initialized
> when Hyp segments have only been mapped.
> 
> Notify KVM's successful initialization only once it is really fully
> initialized.
> 
> Signed-off-by: Julien Thierry <julien.thierry at arm.com>
> Cc: Marc Zyngier <marc.zyngier at arm.com>
> Cc: Christoffer Dall <christoffer.dall at linaro.org>
> ---
>  virt/kvm/arm/arm.c | 31 ++++++++++++++-----------------
>  1 file changed, 14 insertions(+), 17 deletions(-)
> 
> diff --git a/virt/kvm/arm/arm.c b/virt/kvm/arm/arm.c
> index b9f68e4..95cba07 100644
> --- a/virt/kvm/arm/arm.c
> +++ b/virt/kvm/arm/arm.c
> @@ -1326,21 +1326,12 @@ static void teardown_hyp_mode(void)
>  {
>  	int cpu;
> 
> -	if (is_kernel_in_hyp_mode())
> -		return;
> -
>  	free_hyp_pgds();
>  	for_each_possible_cpu(cpu)
>  		free_page(per_cpu(kvm_arm_hyp_stack_page, cpu));
>  	hyp_cpu_pm_exit();
>  }
> 
> -static int init_vhe_mode(void)
> -{
> -	kvm_info("VHE mode initialized successfully\n");
> -	return 0;
> -}
> -
>  /**
>   * Inits Hyp-mode on all online CPUs
>   */
> @@ -1421,8 +1412,6 @@ static int init_hyp_mode(void)
>  		}
>  	}
> 
> -	kvm_info("Hyp mode initialized successfully\n");
> -
>  	return 0;
> 
>  out_err:
> @@ -1456,6 +1445,7 @@ int kvm_arch_init(void *opaque)
>  {
>  	int err;
>  	int ret, cpu;
> +	bool in_hyp_mode;
> 
>  	if (!is_hyp_mode_available()) {
>  		kvm_err("HYP mode not available\n");
> @@ -1474,21 +1464,28 @@ int kvm_arch_init(void *opaque)
>  	if (err)
>  		return err;
> 
> -	if (is_kernel_in_hyp_mode())
> -		err = init_vhe_mode();
> -	else
> +	in_hyp_mode = is_kernel_in_hyp_mode();
> +
> +	if (!in_hyp_mode) {
>  		err = init_hyp_mode();
> -	if (err)
> -		goto out_err;
> +		if (err)
> +			goto out_err;
> +	}
> 
>  	err = init_subsystems();
>  	if (err)
>  		goto out_hyp;
> 
> +	if (in_hyp_mode)
> +		kvm_info("VHE mode initialized successfully\n");
> +	else
> +		kvm_info("Hyp mode initialized successfully\n");
> +
>  	return 0;
> 
>  out_hyp:
> -	teardown_hyp_mode();
> +	if (!in_hyp_mode)
> +		teardown_hyp_mode();
>  out_err:
>  	teardown_common_resources();
>  	return err;
> --
> 1.9.1
> 

Acked-by: Marc Zyngier <marc.zyngier at arm.com>

	M.
-- 
Jazz is not dead. It just smells funny...



More information about the linux-arm-kernel mailing list