From c71b5b4a9c4ee680bc48eb02386f1dc4311e0fdb Mon Sep 17 00:00:00 2001 From: Blue Swirl Date: Fri, 25 Dec 2009 18:18:29 +0000 Subject: PCI: partially revert 2e01c8cf4b076b05013c87723e3fc710b50a0a7a Bus address conversion was not correct. Signed-off-by: Blue Swirl --- hw/pci.c | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) (limited to 'hw/pci.c') diff --git a/hw/pci.c b/hw/pci.c index b0c32c6..9722fce 100644 --- a/hw/pci.c +++ b/hw/pci.c @@ -899,7 +899,7 @@ static void pci_update_mappings(PCIDevice *d) { PCIIORegion *r; int i; - pcibus_t new_addr, filtered_size, bus_addr; + pcibus_t new_addr, filtered_size; for(i = 0; i < PCI_NUM_REGIONS; i++) { r = &d->io_regions[i]; @@ -921,7 +921,6 @@ static void pci_update_mappings(PCIDevice *d) continue; /* now do the real mapping */ - bus_addr = r->addr; if (r->addr != PCI_BAR_UNMAPPED) { if (r->type & PCI_BASE_ADDRESS_SPACE_IO) { int class; @@ -934,8 +933,7 @@ static void pci_update_mappings(PCIDevice *d) isa_unassign_ioport(r->addr, r->filtered_size); } } else { - bus_addr = pci_to_cpu_addr(d->bus, r->addr); - cpu_register_physical_memory(bus_addr, + cpu_register_physical_memory(pci_to_cpu_addr(d->bus, r->addr), r->filtered_size, IO_MEM_UNASSIGNED); qemu_unregister_coalesced_mmio(r->addr, r->filtered_size); @@ -951,7 +949,7 @@ static void pci_update_mappings(PCIDevice *d) * Teach them such cases, such that filtered_size < size and * addr & (size - 1) != 0. */ - r->map_func(d, i, bus_addr, r->filtered_size, r->type); + r->map_func(d, i, r->addr, r->filtered_size, r->type); } } } -- cgit v1.1