aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBlue Swirl <blauwirbel@gmail.com>2009-08-31 19:30:18 +0000
committerBlue Swirl <blauwirbel@gmail.com>2009-08-31 19:30:18 +0000
commitf4b19cd02152652e818f072ebb40db87a78bcc73 (patch)
tree23fd7d8b94f4bc0f8c21b43dd9b3ace2746b23f6
parent9ebec28b6c61bcdcd90c7bd87ffc24a4dc4dd182 (diff)
downloadqemu-f4b19cd02152652e818f072ebb40db87a78bcc73.zip
qemu-f4b19cd02152652e818f072ebb40db87a78bcc73.tar.gz
qemu-f4b19cd02152652e818f072ebb40db87a78bcc73.tar.bz2
Sparc32: port timers to VMState design
Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
-rw-r--r--hw/slavio_timer.c62
1 files changed, 25 insertions, 37 deletions
diff --git a/hw/slavio_timer.c b/hw/slavio_timer.c
index 0244efa..b745a4b 100644
--- a/hw/slavio_timer.c
+++ b/hw/slavio_timer.c
@@ -334,44 +334,33 @@ static CPUWriteMemoryFunc * const slavio_timer_mem_write[3] = {
slavio_timer_mem_writel,
};
-static void slavio_timer_save(QEMUFile *f, void *opaque)
-{
- SLAVIO_TIMERState *s = opaque;
- unsigned int i;
- CPUTimerState *curr_timer;
-
- for (i = 0; i <= MAX_CPUS; i++) {
- curr_timer = &s->cputimer[i];
- qemu_put_be64s(f, &curr_timer->limit);
- qemu_put_be32s(f, &curr_timer->count);
- qemu_put_be32s(f, &curr_timer->counthigh);
- qemu_put_be32s(f, &curr_timer->reached);
- qemu_put_be32s(f, &curr_timer->running);
- qemu_put_ptimer(f, curr_timer->timer);
+static const VMStateDescription vmstate_timer = {
+ .name ="timer",
+ .version_id = 3,
+ .minimum_version_id = 3,
+ .minimum_version_id_old = 3,
+ .fields = (VMStateField []) {
+ VMSTATE_UINT64(limit, CPUTimerState),
+ VMSTATE_UINT32(count, CPUTimerState),
+ VMSTATE_UINT32(counthigh, CPUTimerState),
+ VMSTATE_UINT32(reached, CPUTimerState),
+ VMSTATE_UINT32(running, CPUTimerState),
+ VMSTATE_PTIMER(timer, CPUTimerState),
+ VMSTATE_END_OF_LIST()
}
-}
-
-static int slavio_timer_load(QEMUFile *f, void *opaque, int version_id)
-{
- SLAVIO_TIMERState *s = opaque;
- unsigned int i;
- CPUTimerState *curr_timer;
-
- if (version_id != 3)
- return -EINVAL;
+};
- for (i = 0; i <= MAX_CPUS; i++) {
- curr_timer = &s->cputimer[i];
- qemu_get_be64s(f, &curr_timer->limit);
- qemu_get_be32s(f, &curr_timer->count);
- qemu_get_be32s(f, &curr_timer->counthigh);
- qemu_get_be32s(f, &curr_timer->reached);
- qemu_get_be32s(f, &curr_timer->running);
- qemu_get_ptimer(f, curr_timer->timer);
+static const VMStateDescription vmstate_slavio_timer = {
+ .name ="slavio_timer",
+ .version_id = 3,
+ .minimum_version_id = 3,
+ .minimum_version_id_old = 3,
+ .fields = (VMStateField []) {
+ VMSTATE_STRUCT_ARRAY(cputimer, SLAVIO_TIMERState, MAX_CPUS + 1, 3,
+ vmstate_timer, CPUTimerState),
+ VMSTATE_END_OF_LIST()
}
-
- return 0;
-}
+};
static void slavio_timer_reset(void *opaque)
{
@@ -422,8 +411,7 @@ static int slavio_timer_init1(SysBusDevice *dev)
sysbus_init_irq(dev, &s->cputimer[i].irq);
}
- register_savevm("slavio_timer", -1, 3, slavio_timer_save,
- slavio_timer_load, s);
+ vmstate_register(-1, &vmstate_slavio_timer, s);
qemu_register_reset(slavio_timer_reset, s);
slavio_timer_reset(s);
return 0;