[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PULL 01/11] kvmclock: Ensure time in migration never goes
From: |
Paolo Bonzini |
Subject: |
[Qemu-devel] [PULL 01/11] kvmclock: Ensure time in migration never goes backward |
Date: |
Wed, 4 Jun 2014 13:20:02 +0200 |
From: Alexander Graf <address@hidden>
When we migrate we ask the kernel about its current belief on what the guest
time would be. However, I've seen cases where the kvmclock guest structure
indicates a time more recent than the kvm returned time.
To make sure we never go backwards, calculate what the guest would have seen
as time at the point of migration and use that value instead of the kernel
returned one when it's more recent. This bases the view of the kvmclock
after migration on the same foundation in host as well as guest.
Signed-off-by: Alexander Graf <address@hidden>
Cc: address@hidden
Reviewed-by: Marcelo Tosatti <address@hidden>
Signed-off-by: Paolo Bonzini <address@hidden>
---
hw/i386/kvm/clock.c | 48 ++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 48 insertions(+)
diff --git a/hw/i386/kvm/clock.c b/hw/i386/kvm/clock.c
index 892aa02..6f4ed28a 100644
--- a/hw/i386/kvm/clock.c
+++ b/hw/i386/kvm/clock.c
@@ -14,6 +14,7 @@
*/
#include "qemu-common.h"
+#include "qemu/host-utils.h"
#include "sysemu/sysemu.h"
#include "sysemu/kvm.h"
#include "hw/sysbus.h"
@@ -34,6 +35,47 @@ typedef struct KVMClockState {
bool clock_valid;
} KVMClockState;
+struct pvclock_vcpu_time_info {
+ uint32_t version;
+ uint32_t pad0;
+ uint64_t tsc_timestamp;
+ uint64_t system_time;
+ uint32_t tsc_to_system_mul;
+ int8_t tsc_shift;
+ uint8_t flags;
+ uint8_t pad[2];
+} __attribute__((__packed__)); /* 32 bytes */
+
+static uint64_t kvmclock_current_nsec(KVMClockState *s)
+{
+ CPUState *cpu = first_cpu;
+ CPUX86State *env = cpu->env_ptr;
+ hwaddr kvmclock_struct_pa = env->system_time_msr & ~1ULL;
+ uint64_t migration_tsc = env->tsc;
+ struct pvclock_vcpu_time_info time;
+ uint64_t delta;
+ uint64_t nsec_lo;
+ uint64_t nsec_hi;
+ uint64_t nsec;
+
+ if (!(env->system_time_msr & 1ULL)) {
+ /* KVM clock not active */
+ return 0;
+ }
+
+ cpu_physical_memory_read(kvmclock_struct_pa, &time, sizeof(time));
+
+ delta = migration_tsc - time.tsc_timestamp;
+ if (time.tsc_shift < 0) {
+ delta >>= -time.tsc_shift;
+ } else {
+ delta <<= time.tsc_shift;
+ }
+
+ mulu64(&nsec_lo, &nsec_hi, delta, time.tsc_to_system_mul);
+ nsec = (nsec_lo >> 32) | (nsec_hi << 32);
+ return nsec + time.system_time;
+}
static void kvmclock_vm_state_change(void *opaque, int running,
RunState state)
@@ -45,9 +87,15 @@ static void kvmclock_vm_state_change(void *opaque, int
running,
if (running) {
struct kvm_clock_data data;
+ uint64_t time_at_migration = kvmclock_current_nsec(s);
s->clock_valid = false;
+ /* We can't rely on the migrated clock value, just discard it */
+ if (time_at_migration) {
+ s->clock = time_at_migration;
+ }
+
data.clock = s->clock;
data.flags = 0;
ret = kvm_vm_ioctl(kvm_state, KVM_SET_CLOCK, &data);
--
1.8.3.1
- [Qemu-devel] [PULL 00/11] KVM changes for 2014-06-04, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 01/11] kvmclock: Ensure time in migration never goes backward,
Paolo Bonzini <=
- [Qemu-devel] [PULL 03/11] target-i386: Fix vm86 mode regression introduced in fd460606fd6f., Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 05/11] target-i386: rework CPL checks during task switch, preparing for next patch, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 06/11] target-i386: get CPL from SS.DPL, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 07/11] target-i386: set CC_OP to CC_OP_EFLAGS in cpu_load_eflags, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 02/11] kvm_stat: allow choosing between tracepoints and old stats, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 10/11] kvmclock: Ensure proper env->tsc value for kvmclock_current_nsec calculation, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 04/11] target-i386: fix segment flags for SMM and VM86 mode, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 11/11] kvm: Fix eax for cpuid leaf 0x40000000, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 09/11] kvm: Enable -cpu option to hide KVM, Paolo Bonzini, 2014/06/04
- [Qemu-devel] [PULL 08/11] kvm: Ensure negative return value on kvm_init() error handling path, Paolo Bonzini, 2014/06/04