diff options
author | Gerd Hoffmann <kraxel@redhat.com> | 2010-09-06 12:02:21 +0200 |
---|---|---|
committer | Gerd Hoffmann <kraxel@redhat.com> | 2010-09-06 15:31:23 +0200 |
commit | 6e406d7c62453f30d4b0ab71544c12ff64f25512 (patch) | |
tree | 0ba5647055d4bf9913918f2261335c343782c915 | |
parent | a3d83de052786854a312b72ca266521cee679759 (diff) |
[rhel6 compat]: qxl: compat io size
-rw-r--r-- | hw/qxl.c | 9 |
1 files changed, 7 insertions, 2 deletions
@@ -1162,6 +1162,7 @@ static int qxl_init(PCIDevice *dev) ram_addr_t ram_size = msb_mask(qxl->vga.vram_size * 2 - 1); uint32_t pci_device_id; uint32_t pci_device_rev; + uint32_t io_size; if (device_id == 0 && dev->qdev.hotplugged) { device_id++; @@ -1247,9 +1248,13 @@ static int qxl_init(PCIDevice *dev) qxl->vram_size = msb_mask(qxl->vram_size * 2 - 1); qxl->vram_offset = qemu_ram_alloc(&qxl->pci.qdev, "qxl.vram", qxl->vram_size); + io_size = msb_mask(QXL_IO_RANGE_SIZE * 2 - 1); + if (qxl->revision == 1) { + io_size = 8; + } + pci_register_bar(&qxl->pci, QXL_IO_RANGE_INDEX, - msb_mask(QXL_IO_RANGE_SIZE * 2 - 1), - PCI_BASE_ADDRESS_SPACE_IO, qxl_map); + io_size, PCI_BASE_ADDRESS_SPACE_IO, qxl_map); pci_register_bar(&qxl->pci, QXL_ROM_RANGE_INDEX, qxl->rom_size, PCI_BASE_ADDRESS_SPACE_MEMORY, |