diff options
author | Yonit Halperin <yhalperi@redhat.com> | 2011-07-04 15:08:01 +0300 |
---|---|---|
committer | Gerd Hoffmann <kraxel@redhat.com> | 2011-07-04 15:35:12 +0200 |
commit | 868379ce6994a72c617fbc29bcc95e8166833400 (patch) | |
tree | b7a28ba28865656d279d416a0f0195c604e1255f /hw/qxl.c | |
parent | 6ebebb551ad1a5c4e24d3fccd246c5111450c1b3 (diff) | |
download | qemu-868379ce6994a72c617fbc29bcc95e8166833400.zip qemu-868379ce6994a72c617fbc29bcc95e8166833400.tar.gz qemu-868379ce6994a72c617fbc29bcc95e8166833400.tar.bz2 |
qxl: make sure primary surface is saved on migration
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Diffstat (limited to 'hw/qxl.c')
-rw-r--r-- | hw/qxl.c | 9 |
1 files changed, 6 insertions, 3 deletions
@@ -1184,11 +1184,14 @@ static void qxl_vm_change_state_handler(void *opaque, int running, int reason) qemu_spice_vm_change_state_handler(&qxl->ssd, running, reason); if (!running && qxl->mode == QXL_MODE_NATIVE) { - /* dirty all vram (which holds surfaces) to make sure it is saved */ + /* dirty all vram (which holds surfaces) and devram (primary surface) + * to make sure they are saved */ /* FIXME #1: should go out during "live" stage */ /* FIXME #2: we only need to save the areas which are actually used */ - ram_addr_t addr = qxl->vram_offset; - qxl_set_dirty(addr, addr + qxl->vram_size); + ram_addr_t vram_addr = qxl->vram_offset; + ram_addr_t surface0_addr = qxl->vga.vram_offset + qxl->shadow_rom.draw_area_offset; + qxl_set_dirty(vram_addr, vram_addr + qxl->vram_size); + qxl_set_dirty(surface0_addr, surface0_addr + qxl->shadow_rom.surface0_area_size); } } |