From: aliguori Date: Fri, 17 Apr 2009 14:26:37 +0000 (+0000) Subject: vga: Fix inconsistent tracking of map_addr (Jan Kiszka) X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=e7f3dcc4a7e60291d206669dc1cb10285351e35c;p=qemu-xen-4.1-testing.git vga: Fix inconsistent tracking of map_addr (Jan Kiszka) Only track video RAM mapping in map_addr and use the correct RAM size. Furthermore, make sure the reset the address in case unmapping took place via PCI reconfiguration. Signed-off-by: Jan Kiszka Signed-off-by: Anthony Liguori git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@7140 c046a42c-6fe2-441c-8c8c-71466251a162 --- diff --git a/hw/vga.c b/hw/vga.c index b53b743e6..a4831682f 100644 --- a/hw/vga.c +++ b/hw/vga.c @@ -2258,12 +2258,10 @@ static void vga_map(PCIDevice *pci_dev, int region_num, cpu_register_physical_memory(addr, s->bios_size, s->bios_offset); } else { cpu_register_physical_memory(addr, s->vram_size, s->vram_offset); + s->map_addr = addr; + s->map_end = addr + s->vram_size; + vga_dirty_log_start(s); } - - s->map_addr = addr; - s->map_end = addr + VGA_RAM_SIZE; - - vga_dirty_log_start(s); } void vga_common_init(VGAState *s, int vga_ram_size) @@ -2493,6 +2491,8 @@ static void pci_vga_write_config(PCIDevice *d, vga_dirty_log_stop(s); pci_default_write_config(d, address, val, len); + if (s->map_addr && pvs->dev.io_regions[0].addr == -1) + s->map_addr = 0; vga_dirty_log_start(s); }