mirror of https://github.com/xqemu/xqemu.git
Sparc32: port timers to VMState design
Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
This commit is contained in:
parent
9ebec28b6c
commit
f4b19cd021
|
@ -334,44 +334,33 @@ static CPUWriteMemoryFunc * const slavio_timer_mem_write[3] = {
|
||||||
slavio_timer_mem_writel,
|
slavio_timer_mem_writel,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void slavio_timer_save(QEMUFile *f, void *opaque)
|
static const VMStateDescription vmstate_timer = {
|
||||||
{
|
.name ="timer",
|
||||||
SLAVIO_TIMERState *s = opaque;
|
.version_id = 3,
|
||||||
unsigned int i;
|
.minimum_version_id = 3,
|
||||||
CPUTimerState *curr_timer;
|
.minimum_version_id_old = 3,
|
||||||
|
.fields = (VMStateField []) {
|
||||||
for (i = 0; i <= MAX_CPUS; i++) {
|
VMSTATE_UINT64(limit, CPUTimerState),
|
||||||
curr_timer = &s->cputimer[i];
|
VMSTATE_UINT32(count, CPUTimerState),
|
||||||
qemu_put_be64s(f, &curr_timer->limit);
|
VMSTATE_UINT32(counthigh, CPUTimerState),
|
||||||
qemu_put_be32s(f, &curr_timer->count);
|
VMSTATE_UINT32(reached, CPUTimerState),
|
||||||
qemu_put_be32s(f, &curr_timer->counthigh);
|
VMSTATE_UINT32(running, CPUTimerState),
|
||||||
qemu_put_be32s(f, &curr_timer->reached);
|
VMSTATE_PTIMER(timer, CPUTimerState),
|
||||||
qemu_put_be32s(f, &curr_timer->running);
|
VMSTATE_END_OF_LIST()
|
||||||
qemu_put_ptimer(f, curr_timer->timer);
|
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
static int slavio_timer_load(QEMUFile *f, void *opaque, int version_id)
|
static const VMStateDescription vmstate_slavio_timer = {
|
||||||
{
|
.name ="slavio_timer",
|
||||||
SLAVIO_TIMERState *s = opaque;
|
.version_id = 3,
|
||||||
unsigned int i;
|
.minimum_version_id = 3,
|
||||||
CPUTimerState *curr_timer;
|
.minimum_version_id_old = 3,
|
||||||
|
.fields = (VMStateField []) {
|
||||||
if (version_id != 3)
|
VMSTATE_STRUCT_ARRAY(cputimer, SLAVIO_TIMERState, MAX_CPUS + 1, 3,
|
||||||
return -EINVAL;
|
vmstate_timer, CPUTimerState),
|
||||||
|
VMSTATE_END_OF_LIST()
|
||||||
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);
|
|
||||||
}
|
}
|
||||||
|
};
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void slavio_timer_reset(void *opaque)
|
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);
|
sysbus_init_irq(dev, &s->cputimer[i].irq);
|
||||||
}
|
}
|
||||||
|
|
||||||
register_savevm("slavio_timer", -1, 3, slavio_timer_save,
|
vmstate_register(-1, &vmstate_slavio_timer, s);
|
||||||
slavio_timer_load, s);
|
|
||||||
qemu_register_reset(slavio_timer_reset, s);
|
qemu_register_reset(slavio_timer_reset, s);
|
||||||
slavio_timer_reset(s);
|
slavio_timer_reset(s);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in New Issue