diff options
author | Pavel Dovgalyuk <Pavel.Dovgaluk@ispras.ru> | 2014-09-01 09:34:49 +0400 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2014-09-11 12:20:32 +0200 |
commit | 4603ea01055ac3b6bca8b6c6f9e265c00955ce8f (patch) | |
tree | 5807bc72bc3f5e69bbb1c3cec47c833119f9c9dc /cpus.c | |
parent | a6dead43e6b3b01122f700e9e5736a1255561965 (diff) | |
download | qemu-4603ea01055ac3b6bca8b6c6f9e265c00955ce8f.zip qemu-4603ea01055ac3b6bca8b6c6f9e265c00955ce8f.tar.gz qemu-4603ea01055ac3b6bca8b6c6f9e265c00955ce8f.tar.bz2 |
cpu: init vmstate for ticks and clock offset
Ticks and clock offset used by CPU timers have to be saved in vmstate.
But vmstate for these fields registered only in icount mode.
Missing registration leads to breaking the continuity when vmstate is loaded.
This patch introduces new initialization function which fixes this.
Signed-off-by: Pavel Dovgalyuk <Pavel.Dovgaluk@ispras.ru>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'cpus.c')
-rw-r--r-- | cpus.c | 8 |
1 files changed, 6 insertions, 2 deletions
@@ -493,13 +493,17 @@ static const VMStateDescription vmstate_timers = { } }; +void cpu_ticks_init(void) +{ + seqlock_init(&timers_state.vm_clock_seqlock, NULL); + vmstate_register(NULL, 0, &vmstate_timers, &timers_state); +} + void configure_icount(QemuOpts *opts, Error **errp) { const char *option; char *rem_str = NULL; - seqlock_init(&timers_state.vm_clock_seqlock, NULL); - vmstate_register(NULL, 0, &vmstate_timers, &timers_state); option = qemu_opt_get(opts, "shift"); if (!option) { if (qemu_opt_get(opts, "align") != NULL) { |