[PATCH v6 03/39] KVM: arm64: Return early from kvm_finalize_sys_regs() if guest has run

Jonathan Cameron jonathan.cameron at huawei.com
Thu Mar 19 03:12:29 PDT 2026


On Tue, 17 Mar 2026 11:40:44 +0000
Sascha Bischoff <Sascha.Bischoff at arm.com> wrote:

> If the guest has already run, we have no business finalizing the
> system register state - it is too late. Therefore, check early and
> bail if the VM has already run.
Given it isn't in the scope below, might be worth calling out that
this is skipping kvm_init_nv_sysregs()  So on non NV setups isn't
changing anything but on those it's indeed skipping setup of system
registers.

Seems correct to me, but is this a fix?  So should it have a fixes tag?


> 
> Signed-off-by: Sascha Bischoff <sascha.bischoff at arm.com>
> ---
>  arch/arm64/kvm/sys_regs.c | 5 ++++-
>  1 file changed, 4 insertions(+), 1 deletion(-)
> 
> diff --git a/arch/arm64/kvm/sys_regs.c b/arch/arm64/kvm/sys_regs.c
> index 0acd10e50aaba..42c84b7900ff5 100644
> --- a/arch/arm64/kvm/sys_regs.c
> +++ b/arch/arm64/kvm/sys_regs.c
> @@ -5659,11 +5659,14 @@ int kvm_finalize_sys_regs(struct kvm_vcpu *vcpu)
>  
>  	guard(mutex)(&kvm->arch.config_lock);
>  
> +	if (kvm_vm_has_ran_once(kvm))
> +		return 0;
> +
>  	/*
>  	 * This hacks into the ID registers, so only perform it when the
>  	 * first vcpu runs, or the kvm_set_vm_id_reg() helper will scream.
>  	 */
> -	if (!irqchip_in_kernel(kvm) && !kvm_vm_has_ran_once(kvm)) {
> +	if (!irqchip_in_kernel(kvm)) {
>  		u64 val;
>  
>  		val = kvm_read_vm_id_reg(kvm, SYS_ID_AA64PFR0_EL1) & ~ID_AA64PFR0_EL1_GIC;




More information about the linux-arm-kernel mailing list