[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 9/8] kvm: Save/restore TSC counter
From: |
Jan Kiszka |
Subject: |
[Qemu-devel] [PATCH 9/8] kvm: Save/restore TSC counter |
Date: |
Sat, 02 May 2009 00:49:37 +0200 |
User-agent: |
Mozilla/5.0 (X11; U; Linux i686 (x86_64); de; rv:1.8.1.12) Gecko/20080226 SUSE/2.0.0.12-1.1 Thunderbird/2.0.0.12 Mnenhy/0.7.5.666 |
This bit was still missing for stable save/restore or migrate. Only KVM
uses CPUState::tsc, so this value was not yet included into the CPU
snapshot.
---
target-i386/cpu.h | 2 +-
target-i386/machine.c | 8 ++++++--
2 files changed, 7 insertions(+), 3 deletions(-)
diff --git a/target-i386/cpu.h b/target-i386/cpu.h
index c6bca94..538cbb1 100644
--- a/target-i386/cpu.h
+++ b/target-i386/cpu.h
@@ -837,7 +837,7 @@ static inline int cpu_get_time_fast(void)
#define cpu_signal_handler cpu_x86_signal_handler
#define cpu_list x86_cpu_list
-#define CPU_SAVE_VERSION 8
+#define CPU_SAVE_VERSION 9
/* MMU modes definitions */
#define MMU_MODE0_SUFFIX _kernel
diff --git a/target-i386/machine.c b/target-i386/machine.c
index 4fc7335..27aebf4 100644
--- a/target-i386/machine.c
+++ b/target-i386/machine.c
@@ -149,6 +149,8 @@ void cpu_save(QEMUFile *f, void *opaque)
qemu_put_be64s(f, &env->mtrr_var[i].base);
qemu_put_be64s(f, &env->mtrr_var[i].mask);
}
+
+ qemu_put_be64s(f, &env->tsc);
}
#ifdef USE_X86LDOUBLE
@@ -183,8 +185,7 @@ int cpu_load(QEMUFile *f, void *opaque, int version_id)
uint16_t fpus, fpuc, fptag, fpregs_format;
int32_t a20_mask;
- if (version_id != 3 && version_id != 4 && version_id != 5
- && version_id != 6 && version_id != 7 && version_id != 8)
+ if (version_id < 3 || version_id > CPU_SAVE_VERSION)
return -EINVAL;
for(i = 0; i < CPU_NB_REGS; i++)
qemu_get_betls(f, &env->regs[i]);
@@ -328,6 +329,9 @@ int cpu_load(QEMUFile *f, void *opaque, int version_id)
qemu_get_be64s(f, &env->mtrr_var[i].mask);
}
}
+ if (version_id >= 9) {
+ qemu_get_be64s(f, &env->tsc);
+ }
/* XXX: ensure compatiblity for halted bit ? */
/* XXX: compute redundant hflags bits */
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and livemigration, (continued)
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and live migration, Avi Kivity, 2009/05/03
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and live migration, Gleb Natapov, 2009/05/03
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and live migration, Avi Kivity, 2009/05/03
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and live migration, Gleb Natapov, 2009/05/03
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and live migration, Avi Kivity, 2009/05/03
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and live migration, Gleb Natapov, 2009/05/03
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and live migration, Avi Kivity, 2009/05/03
- Re: [Qemu-devel] Re: [PATCH 0/8] kvm: Fixes, cleanups and live migration, Gleb Natapov, 2009/05/03
[Qemu-devel] [PATCH 9/8] kvm: Save/restore TSC counter,
Jan Kiszka <=
[Qemu-devel] [PATCH 9/8] kvm: x86: Save/restore KVM-specific CPU states, Jan Kiszka, 2009/05/01