[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [xen staging] update system time immediately when VCPUOP_register_vcpu_info
commit b67f09721f136cc3a9afcb6a82466d1bd27aa6c0 Author: Dongli Zhang <dongli.zhang@xxxxxxxxxx> AuthorDate: Wed Nov 3 10:19:06 2021 +0100 Commit: Jan Beulich <jbeulich@xxxxxxxx> CommitDate: Wed Nov 3 10:19:06 2021 +0100 update system time immediately when VCPUOP_register_vcpu_info The guest may access the pv vcpu_time_info immediately after VCPUOP_register_vcpu_info. This is to borrow the idea of VCPUOP_register_vcpu_time_memory_area, where the force_update_vcpu_system_time() is called immediately when the new memory area is registered. Otherwise, we may observe clock drift at the VM side if the VM accesses the clocksource immediately after VCPUOP_register_vcpu_info(). Reference: https://lists.xenproject.org/archives/html/xen-devel/2021-10/msg00571.html Signed-off-by: Dongli Zhang <dongli.zhang@xxxxxxxxxx> Acked-by: Stefano Stabellini <sstabellini@xxxxxxxxxx> Reviewed-by: Jan Beulich <jbeulich@xxxxxxxx> Release-Acked-by: Ian Jackson <iwj@xxxxxxxxxxxxxx> --- xen/arch/arm/time.c | 5 +++++ xen/common/domain.c | 2 ++ xen/include/asm-arm/time.h | 2 ++ 3 files changed, 9 insertions(+) diff --git a/xen/arch/arm/time.c b/xen/arch/arm/time.c index 7dbd363537..dec53b5f7d 100644 --- a/xen/arch/arm/time.c +++ b/xen/arch/arm/time.c @@ -351,6 +351,11 @@ void update_vcpu_system_time(struct vcpu *v) /* XXX update shared_info->wc_* */ } +void force_update_vcpu_system_time(struct vcpu *v) +{ + update_vcpu_system_time(v); +} + void domain_set_time_offset(struct domain *d, int64_t time_offset_seconds) { d->time_offset.seconds = time_offset_seconds; diff --git a/xen/common/domain.c b/xen/common/domain.c index 8b53c49d1e..d71fcab88c 100644 --- a/xen/common/domain.c +++ b/xen/common/domain.c @@ -1704,6 +1704,8 @@ long do_vcpu_op(int cmd, unsigned int vcpuid, XEN_GUEST_HANDLE_PARAM(void) arg) rc = map_vcpu_info(v, info.mfn, info.offset); domain_unlock(d); + force_update_vcpu_system_time(v); + break; } diff --git a/xen/include/asm-arm/time.h b/xen/include/asm-arm/time.h index 6b8fd839dd..4b401c1110 100644 --- a/xen/include/asm-arm/time.h +++ b/xen/include/asm-arm/time.h @@ -105,6 +105,8 @@ extern uint64_t ns_to_ticks(s_time_t ns); void preinit_xen_time(void); +void force_update_vcpu_system_time(struct vcpu *v); + #endif /* __ARM_TIME_H__ */ /* * Local variables: -- generated by git-patchbot for /home/xen/git/xen.git#staging
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |