[RFC PATCH v3 01/29] KVM: arm64: Add has_reset_once flag for vcpu
Reiji Watanabe
reijiw at google.com
Tue Nov 16 22:43:31 PST 2021
Introduce 'has_reset_once' flag in kvm_vcpu_arch, which indicates
if the vCPU reset has been done once, for later use.
Signed-off-by: Reiji Watanabe <reijiw at google.com>
Reviewed-by: Oliver Upton <oupton at google.com>
---
arch/arm64/include/asm/kvm_host.h | 2 ++
arch/arm64/kvm/reset.c | 4 ++++
2 files changed, 6 insertions(+)
diff --git a/arch/arm64/include/asm/kvm_host.h b/arch/arm64/include/asm/kvm_host.h
index 2a5f7f38006f..edbe2cb21947 100644
--- a/arch/arm64/include/asm/kvm_host.h
+++ b/arch/arm64/include/asm/kvm_host.h
@@ -385,6 +385,7 @@ struct kvm_vcpu_arch {
u64 last_steal;
gpa_t base;
} steal;
+ bool has_reset_once;
};
/* Pointer to the vcpu's SVE FFR for sve_{save,load}_state() */
@@ -450,6 +451,7 @@ struct kvm_vcpu_arch {
#define vcpu_has_sve(vcpu) (system_supports_sve() && \
((vcpu)->arch.flags & KVM_ARM64_GUEST_HAS_SVE))
+#define vcpu_has_reset_once(vcpu) ((vcpu)->arch.has_reset_once)
#ifdef CONFIG_ARM64_PTR_AUTH
#define vcpu_has_ptrauth(vcpu) \
diff --git a/arch/arm64/kvm/reset.c b/arch/arm64/kvm/reset.c
index 426bd7fbc3fd..c3a91ab370fa 100644
--- a/arch/arm64/kvm/reset.c
+++ b/arch/arm64/kvm/reset.c
@@ -305,6 +305,10 @@ int kvm_reset_vcpu(struct kvm_vcpu *vcpu)
if (loaded)
kvm_arch_vcpu_load(vcpu, smp_processor_id());
preempt_enable();
+
+ if (!ret && !vcpu->arch.has_reset_once)
+ vcpu->arch.has_reset_once = true;
+
return ret;
}
--
2.34.0.rc1.387.gb447b232ab-goog
More information about the linux-arm-kernel
mailing list