]> git.proxmox.com Git - mirror_qemu.git/commitdiff
sun4u: switch second PCI-ebus bridge BAR over to PCI IO space
authorMark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
Mon, 4 Aug 2014 17:13:11 +0000 (18:13 +0100)
committerMark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
Sun, 17 Aug 2014 12:12:52 +0000 (13:12 +0100)
The ebus is the sun4u equivalent of the old ISA bus which is already mapped at
the beginning of PCI IO space within QEMU. NetBSD attempts to find the physical
addresses of devices connected to the ebus by parsing the BARs of the PCI-ebus
bridge and using the base address found by matching both the address space
type and range for a particular ebus address.

Since the second PCI-ebus bridge BAR is already aliased onto IO space, switch
the BAR over to match and reduce the size to 0x1000 which is enough to cover
all the legacy ioport devices whilst leaving the remaining IO space for other
PCI devices. This allows NetBSD SPARC64 to correctly detect and access devices
on the ebus.

Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
hw/sparc64/sun4u.c

index 33c311bf289f02bb8c29356a1932ffc9178bde3e..b9f3bee9ae6a078192d995d92c9775823f7fb651 100644 (file)
@@ -609,8 +609,8 @@ pci_ebus_init1(PCIDevice *pci_dev)
                              0, 0x1000000);
     pci_register_bar(pci_dev, 0, PCI_BASE_ADDRESS_SPACE_MEMORY, &s->bar0);
     memory_region_init_alias(&s->bar1, OBJECT(s), "bar1", get_system_io(),
-                             0, 0x800000);
-    pci_register_bar(pci_dev, 1, PCI_BASE_ADDRESS_SPACE_MEMORY, &s->bar1);
+                             0, 0x1000);
+    pci_register_bar(pci_dev, 1, PCI_BASE_ADDRESS_SPACE_IO, &s->bar1);
     return 0;
 }