diff options
author | Juan Quintela <quintela@redhat.com> | 2009-10-15 00:49:17 +0200 |
---|---|---|
committer | Anthony Liguori <aliguori@us.ibm.com> | 2009-10-27 12:28:47 -0500 |
commit | f309270bee241bbf83fc2a1a7acf0abb37debf85 (patch) | |
tree | fcce7141ac4b96750afd31d4b66b4bd4acd13c4a /hw/wdt_ib700.c | |
parent | 048eabcb0bc84424ef44e96085741a385360cf39 (diff) |
ib700: Introduce IB700State
Signed-off-by: Juan Quintela <quintela@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
Diffstat (limited to 'hw/wdt_ib700.c')
-rw-r--r-- | hw/wdt_ib700.c | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/hw/wdt_ib700.c b/hw/wdt_ib700.c index 0ee3a5cc06..e598df5381 100644 --- a/hw/wdt_ib700.c +++ b/hw/wdt_ib700.c @@ -35,6 +35,10 @@ #define ib700_debug(fs,...) #endif +typedef struct IB700state { + ISADevice dev; +} IB700State; + /* This is the timer. We use a global here because the watchdog * code ensures there is only one watchdog (it is located at a fixed, * unchangable IO port, so there could only ever be one anyway). @@ -90,10 +94,12 @@ static int ib700_load(QEMUFile *f, void *vp, int version) static int wdt_ib700_init(ISADevice *dev) { - timer = qemu_new_timer(vm_clock, ib700_timer_expired, NULL); - register_savevm("ib700_wdt", -1, 0, ib700_save, ib700_load, NULL); - register_ioport_write(0x441, 2, 1, ib700_write_disable_reg, NULL); - register_ioport_write(0x443, 2, 1, ib700_write_enable_reg, NULL); + IB700State *s = DO_UPCAST(IB700State, dev, dev); + + timer = qemu_new_timer(vm_clock, ib700_timer_expired, s); + register_savevm("ib700_wdt", -1, 0, ib700_save, ib700_load, s); + register_ioport_write(0x441, 2, 1, ib700_write_disable_reg, s); + register_ioport_write(0x443, 2, 1, ib700_write_enable_reg, s); return 0; } @@ -105,7 +111,7 @@ static WatchdogTimerModel model = { static ISADeviceInfo wdt_ib700_info = { .qdev.name = "ib700", - .qdev.size = sizeof(ISADevice), + .qdev.size = sizeof(IB700State), .init = wdt_ib700_init, }; |