提交 7783e9f0 编写于 作者: P pbrook

Keyboard savevm fix (malc).


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1797 c046a42c-6fe2-441c-8c8c-71466251a162
上级 33698e5f
...@@ -118,7 +118,7 @@ typedef struct KBDState { ...@@ -118,7 +118,7 @@ typedef struct KBDState {
uint8_t status; uint8_t status;
uint8_t mode; uint8_t mode;
/* Bitmask of devices with data available. */ /* Bitmask of devices with data available. */
int pending; uint8_t pending;
void *kbd; void *kbd;
void *mouse; void *mouse;
} KBDState; } KBDState;
...@@ -337,17 +337,19 @@ static void kbd_save(QEMUFile* f, void* opaque) ...@@ -337,17 +337,19 @@ static void kbd_save(QEMUFile* f, void* opaque)
qemu_put_8s(f, &s->write_cmd); qemu_put_8s(f, &s->write_cmd);
qemu_put_8s(f, &s->status); qemu_put_8s(f, &s->status);
qemu_put_8s(f, &s->mode); qemu_put_8s(f, &s->mode);
qemu_put_8s(f, &s->pending);
} }
static int kbd_load(QEMUFile* f, void* opaque, int version_id) static int kbd_load(QEMUFile* f, void* opaque, int version_id)
{ {
KBDState *s = (KBDState*)opaque; KBDState *s = (KBDState*)opaque;
if (version_id != 2) if (version_id != 3)
return -EINVAL; return -EINVAL;
qemu_get_8s(f, &s->write_cmd); qemu_get_8s(f, &s->write_cmd);
qemu_get_8s(f, &s->status); qemu_get_8s(f, &s->status);
qemu_get_8s(f, &s->mode); qemu_get_8s(f, &s->mode);
qemu_get_8s(f, &s->pending);
return 0; return 0;
} }
...@@ -356,7 +358,7 @@ void kbd_init(void) ...@@ -356,7 +358,7 @@ void kbd_init(void)
KBDState *s = &kbd_state; KBDState *s = &kbd_state;
kbd_reset(s); kbd_reset(s);
register_savevm("pckbd", 0, 2, kbd_save, kbd_load, s); register_savevm("pckbd", 0, 3, kbd_save, kbd_load, s);
register_ioport_read(0x60, 1, 1, kbd_read_data, s); register_ioport_read(0x60, 1, 1, kbd_read_data, s);
register_ioport_write(0x60, 1, 1, kbd_write_data, s); register_ioport_write(0x60, 1, 1, kbd_write_data, s);
register_ioport_read(0x64, 1, 1, kbd_read_status, s); register_ioport_read(0x64, 1, 1, kbd_read_status, s);
......
...@@ -461,19 +461,38 @@ static void ps2_reset(void *opaque) ...@@ -461,19 +461,38 @@ static void ps2_reset(void *opaque)
q->count = 0; q->count = 0;
} }
static void ps2_common_save (QEMUFile *f, PS2State *s)
{
qemu_put_be32s (f, &s->write_cmd);
qemu_put_be32s (f, &s->queue.rptr);
qemu_put_be32s (f, &s->queue.wptr);
qemu_put_be32s (f, &s->queue.count);
qemu_put_buffer (f, s->queue.data, sizeof (s->queue.data));
}
static void ps2_common_load (QEMUFile *f, PS2State *s)
{
qemu_get_be32s (f, &s->write_cmd);
qemu_get_be32s (f, &s->queue.rptr);
qemu_get_be32s (f, &s->queue.wptr);
qemu_get_be32s (f, &s->queue.count);
qemu_get_buffer (f, s->queue.data, sizeof (s->queue.data));
}
static void ps2_kbd_save(QEMUFile* f, void* opaque) static void ps2_kbd_save(QEMUFile* f, void* opaque)
{ {
PS2KbdState *s = (PS2KbdState*)opaque; PS2KbdState *s = (PS2KbdState*)opaque;
qemu_put_be32s(f, &s->common.write_cmd); ps2_common_save (f, &s->common);
qemu_put_be32s(f, &s->scan_enabled); qemu_put_be32s(f, &s->scan_enabled);
qemu_put_be32s(f, &s->translate);
} }
static void ps2_mouse_save(QEMUFile* f, void* opaque) static void ps2_mouse_save(QEMUFile* f, void* opaque)
{ {
PS2MouseState *s = (PS2MouseState*)opaque; PS2MouseState *s = (PS2MouseState*)opaque;
qemu_put_be32s(f, &s->common.write_cmd); ps2_common_save (f, &s->common);
qemu_put_8s(f, &s->mouse_status); qemu_put_8s(f, &s->mouse_status);
qemu_put_8s(f, &s->mouse_resolution); qemu_put_8s(f, &s->mouse_resolution);
qemu_put_8s(f, &s->mouse_sample_rate); qemu_put_8s(f, &s->mouse_sample_rate);
...@@ -489,21 +508,24 @@ static void ps2_mouse_save(QEMUFile* f, void* opaque) ...@@ -489,21 +508,24 @@ static void ps2_mouse_save(QEMUFile* f, void* opaque)
static int ps2_kbd_load(QEMUFile* f, void* opaque, int version_id) static int ps2_kbd_load(QEMUFile* f, void* opaque, int version_id)
{ {
PS2KbdState *s = (PS2KbdState*)opaque; PS2KbdState *s = (PS2KbdState*)opaque;
if (version_id != 1) if (version_id != 2)
return -EINVAL; return -EINVAL;
qemu_get_be32s(f, &s->common.write_cmd);
ps2_common_load (f, &s->common);
qemu_get_be32s(f, &s->scan_enabled); qemu_get_be32s(f, &s->scan_enabled);
qemu_get_be32s(f, &s->translate);
return 0; return 0;
} }
static int ps2_mouse_load(QEMUFile* f, void* opaque, int version_id) static int ps2_mouse_load(QEMUFile* f, void* opaque, int version_id)
{ {
PS2MouseState *s = (PS2MouseState*)opaque; PS2MouseState *s = (PS2MouseState*)opaque;
if (version_id != 1) if (version_id != 2)
return -EINVAL; return -EINVAL;
qemu_get_be32s(f, &s->common.write_cmd);
ps2_common_load (f, &s->common);
qemu_get_8s(f, &s->mouse_status); qemu_get_8s(f, &s->mouse_status);
qemu_get_8s(f, &s->mouse_resolution); qemu_get_8s(f, &s->mouse_resolution);
qemu_get_8s(f, &s->mouse_sample_rate); qemu_get_8s(f, &s->mouse_sample_rate);
...@@ -524,7 +546,7 @@ void *ps2_kbd_init(void (*update_irq)(void *, int), void *update_arg) ...@@ -524,7 +546,7 @@ void *ps2_kbd_init(void (*update_irq)(void *, int), void *update_arg)
s->common.update_irq = update_irq; s->common.update_irq = update_irq;
s->common.update_arg = update_arg; s->common.update_arg = update_arg;
ps2_reset(&s->common); ps2_reset(&s->common);
register_savevm("ps2kbd", 0, 1, ps2_kbd_save, ps2_kbd_load, s); register_savevm("ps2kbd", 0, 2, ps2_kbd_save, ps2_kbd_load, s);
qemu_add_kbd_event_handler(ps2_put_keycode, s); qemu_add_kbd_event_handler(ps2_put_keycode, s);
qemu_register_reset(ps2_reset, &s->common); qemu_register_reset(ps2_reset, &s->common);
return s; return s;
...@@ -537,7 +559,7 @@ void *ps2_mouse_init(void (*update_irq)(void *, int), void *update_arg) ...@@ -537,7 +559,7 @@ void *ps2_mouse_init(void (*update_irq)(void *, int), void *update_arg)
s->common.update_irq = update_irq; s->common.update_irq = update_irq;
s->common.update_arg = update_arg; s->common.update_arg = update_arg;
ps2_reset(&s->common); ps2_reset(&s->common);
register_savevm("ps2mouse", 0, 1, ps2_mouse_save, ps2_mouse_load, s); register_savevm("ps2mouse", 0, 2, ps2_mouse_save, ps2_mouse_load, s);
qemu_add_mouse_event_handler(ps2_mouse_event, s); qemu_add_mouse_event_handler(ps2_mouse_event, s);
qemu_register_reset(ps2_reset, &s->common); qemu_register_reset(ps2_reset, &s->common);
return s; return s;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册