diff options
author | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2004-07-10 13:39:53 +0000 |
---|---|---|
committer | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2004-07-10 13:39:53 +0000 |
commit | 675376f2b450e22cba45e0617f34ab8454219ef5 (patch) | |
tree | b23225721a77f5a8f758538e63c3ebe1666f63ad /hw | |
parent | 15a34c63642d8b70ad90bfbb2c2f823753e2dbf4 (diff) | |
download | qemu-675376f2b450e22cba45e0617f34ab8454219ef5.zip qemu-675376f2b450e22cba45e0617f34ab8454219ef5.tar.gz qemu-675376f2b450e22cba45e0617f34ab8454219ef5.tar.bz2 |
kbd save/restore
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@991 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'hw')
-rw-r--r-- | hw/pckbd.c | 48 |
1 files changed, 48 insertions, 0 deletions
@@ -642,11 +642,59 @@ static void kbd_reset(void *opaque) q->count = 0; } +static void kbd_save(QEMUFile* f, void* opaque) +{ + KBDState *s = (KBDState*)opaque; + + qemu_put_8s(f, &s->write_cmd); + qemu_put_8s(f, &s->status); + qemu_put_8s(f, &s->mode); + qemu_put_be32s(f, &s->kbd_write_cmd); + qemu_put_be32s(f, &s->scan_enabled); + qemu_put_be32s(f, &s->mouse_write_cmd); + qemu_put_8s(f, &s->mouse_status); + qemu_put_8s(f, &s->mouse_resolution); + qemu_put_8s(f, &s->mouse_sample_rate); + qemu_put_8s(f, &s->mouse_wrap); + qemu_put_8s(f, &s->mouse_type); + qemu_put_8s(f, &s->mouse_detect_state); + qemu_put_be32s(f, &s->mouse_dx); + qemu_put_be32s(f, &s->mouse_dy); + qemu_put_be32s(f, &s->mouse_dz); + qemu_put_8s(f, &s->mouse_buttons); +} + +static int kbd_load(QEMUFile* f, void* opaque, int version_id) +{ + KBDState *s = (KBDState*)opaque; + + if (version_id != 1) + return -EINVAL; + qemu_get_8s(f, &s->write_cmd); + qemu_get_8s(f, &s->status); + qemu_get_8s(f, &s->mode); + qemu_get_be32s(f, &s->kbd_write_cmd); + qemu_get_be32s(f, &s->scan_enabled); + qemu_get_be32s(f, &s->mouse_write_cmd); + qemu_get_8s(f, &s->mouse_status); + qemu_get_8s(f, &s->mouse_resolution); + qemu_get_8s(f, &s->mouse_sample_rate); + qemu_get_8s(f, &s->mouse_wrap); + qemu_get_8s(f, &s->mouse_type); + qemu_get_8s(f, &s->mouse_detect_state); + qemu_get_be32s(f, &s->mouse_dx); + qemu_get_be32s(f, &s->mouse_dy); + qemu_get_be32s(f, &s->mouse_dz); + qemu_get_8s(f, &s->mouse_buttons); + return 0; +} + void kbd_init(void) { KBDState *s = &kbd_state; kbd_reset(s); + register_savevm("pckbd", 0, 1, kbd_save, kbd_load, s); register_ioport_read(0x60, 1, 1, kbd_read_data, s); register_ioport_write(0x60, 1, 1, kbd_write_data, s); register_ioport_read(0x64, 1, 1, kbd_read_status, s); |