提交 60a0e443 编写于 作者: A Alex Williamson 提交者: Michael S. Tsirkin

pci: Allow PCI bus creation interfaces to specify the type of bus

No change to any types.
Signed-off-by: NAlex Williamson <alex.williamson@redhat.com>
Signed-off-by: NMichael S. Tsirkin <mst@redhat.com>
上级 cf09458d
...@@ -775,7 +775,7 @@ PCIBus *typhoon_init(ram_addr_t ram_size, ISABus **isa_bus, ...@@ -775,7 +775,7 @@ PCIBus *typhoon_init(ram_addr_t ram_size, ISABus **isa_bus,
b = pci_register_bus(dev, "pci", b = pci_register_bus(dev, "pci",
typhoon_set_irq, sys_map_irq, s, typhoon_set_irq, sys_map_irq, s,
&s->pchip.reg_mem, addr_space_io, 0, 64); &s->pchip.reg_mem, addr_space_io, 0, 64, TYPE_PCI_BUS);
phb->bus = b; phb->bus = b;
/* Pchip0 PCI special/interrupt acknowledge, 0x801.F800.0000, 64MB. */ /* Pchip0 PCI special/interrupt acknowledge, 0x801.F800.0000, 64MB. */
......
...@@ -329,7 +329,7 @@ static int apb_pci_bridge_initfn(PCIDevice *dev) ...@@ -329,7 +329,7 @@ static int apb_pci_bridge_initfn(PCIDevice *dev)
{ {
int rc; int rc;
rc = pci_bridge_initfn(dev); rc = pci_bridge_initfn(dev, TYPE_PCI_BUS);
if (rc < 0) { if (rc < 0) {
return rc; return rc;
} }
...@@ -381,7 +381,7 @@ PCIBus *pci_apb_init(hwaddr special_base, ...@@ -381,7 +381,7 @@ PCIBus *pci_apb_init(hwaddr special_base,
pci_apb_set_irq, pci_pbm_map_irq, d, pci_apb_set_irq, pci_pbm_map_irq, d,
&d->pci_mmio, &d->pci_mmio,
get_system_io(), get_system_io(),
0, 32); 0, 32, TYPE_PCI_BUS);
*pbm_irqs = d->pbm_irqs; *pbm_irqs = d->pbm_irqs;
d->ivec_irqs = ivec_irqs; d->ivec_irqs = ivec_irqs;
......
...@@ -707,7 +707,7 @@ static int bonito_pcihost_initfn(SysBusDevice *dev) ...@@ -707,7 +707,7 @@ static int bonito_pcihost_initfn(SysBusDevice *dev)
phb->bus = pci_register_bus(DEVICE(dev), "pci", phb->bus = pci_register_bus(DEVICE(dev), "pci",
pci_bonito_set_irq, pci_bonito_map_irq, dev, pci_bonito_set_irq, pci_bonito_map_irq, dev,
get_system_memory(), get_system_io(), get_system_memory(), get_system_io(),
0x28, 32); 0x28, 32, TYPE_PCI_BUS);
return 0; return 0;
} }
......
...@@ -51,12 +51,17 @@ static int dec_map_irq(PCIDevice *pci_dev, int irq_num) ...@@ -51,12 +51,17 @@ static int dec_map_irq(PCIDevice *pci_dev, int irq_num)
return irq_num; return irq_num;
} }
static int dec_pci_bridge_initfn(PCIDevice *pci_dev)
{
return pci_bridge_initfn(pci_dev, TYPE_PCI_BUS);
}
static void dec_21154_pci_bridge_class_init(ObjectClass *klass, void *data) static void dec_21154_pci_bridge_class_init(ObjectClass *klass, void *data)
{ {
DeviceClass *dc = DEVICE_CLASS(klass); DeviceClass *dc = DEVICE_CLASS(klass);
PCIDeviceClass *k = PCI_DEVICE_CLASS(klass); PCIDeviceClass *k = PCI_DEVICE_CLASS(klass);
k->init = pci_bridge_initfn; k->init = dec_pci_bridge_initfn;
k->exit = pci_bridge_exitfn; k->exit = pci_bridge_exitfn;
k->vendor_id = PCI_VENDOR_ID_DEC; k->vendor_id = PCI_VENDOR_ID_DEC;
k->device_id = PCI_DEVICE_ID_DEC_21154; k->device_id = PCI_DEVICE_ID_DEC_21154;
......
...@@ -88,7 +88,7 @@ PCIBus *pci_grackle_init(uint32_t base, qemu_irq *pic, ...@@ -88,7 +88,7 @@ PCIBus *pci_grackle_init(uint32_t base, qemu_irq *pic,
pic, pic,
&d->pci_mmio, &d->pci_mmio,
address_space_io, address_space_io,
0, 4); 0, 4, TYPE_PCI_BUS);
pci_create_simple(phb->bus, 0, "grackle"); pci_create_simple(phb->bus, 0, "grackle");
......
...@@ -1107,7 +1107,7 @@ PCIBus *gt64120_register(qemu_irq *pic) ...@@ -1107,7 +1107,7 @@ PCIBus *gt64120_register(qemu_irq *pic)
pic, pic,
get_system_memory(), get_system_memory(),
get_system_io(), get_system_io(),
PCI_DEVFN(18, 0), 4); PCI_DEVFN(18, 0), 4, TYPE_PCI_BUS);
memory_region_init_io(&d->ISD_mem, &isd_mem_ops, d, "isd-mem", 0x1000); memory_region_init_io(&d->ISD_mem, &isd_mem_ops, d, "isd-mem", 0x1000);
pci_create_simple(phb->bus, PCI_DEVFN(0, 0), "gt64120_pci"); pci_create_simple(phb->bus, PCI_DEVFN(0, 0), "gt64120_pci");
......
...@@ -59,7 +59,7 @@ static int i82801b11_bridge_initfn(PCIDevice *d) ...@@ -59,7 +59,7 @@ static int i82801b11_bridge_initfn(PCIDevice *d)
{ {
int rc; int rc;
rc = pci_bridge_initfn(d); rc = pci_bridge_initfn(d, TYPE_PCI_BUS);
if (rc < 0) { if (rc < 0) {
return rc; return rc;
} }
......
...@@ -97,7 +97,7 @@ static int ioh3420_initfn(PCIDevice *d) ...@@ -97,7 +97,7 @@ static int ioh3420_initfn(PCIDevice *d)
PCIESlot *s = DO_UPCAST(PCIESlot, port, p); PCIESlot *s = DO_UPCAST(PCIESlot, port, p);
int rc; int rc;
rc = pci_bridge_initfn(d); rc = pci_bridge_initfn(d, TYPE_PCI_BUS);
if (rc < 0) { if (rc < 0) {
return rc; return rc;
} }
......
...@@ -301,9 +301,9 @@ void pci_bus_new_inplace(PCIBus *bus, DeviceState *parent, ...@@ -301,9 +301,9 @@ void pci_bus_new_inplace(PCIBus *bus, DeviceState *parent,
const char *name, const char *name,
MemoryRegion *address_space_mem, MemoryRegion *address_space_mem,
MemoryRegion *address_space_io, MemoryRegion *address_space_io,
uint8_t devfn_min) uint8_t devfn_min, const char *typename)
{ {
qbus_create_inplace(bus, TYPE_PCI_BUS, parent, name); qbus_create_inplace(bus, typename, parent, name);
pci_bus_init(bus, parent, name, address_space_mem, pci_bus_init(bus, parent, name, address_space_mem,
address_space_io, devfn_min); address_space_io, devfn_min);
} }
...@@ -311,11 +311,11 @@ void pci_bus_new_inplace(PCIBus *bus, DeviceState *parent, ...@@ -311,11 +311,11 @@ void pci_bus_new_inplace(PCIBus *bus, DeviceState *parent,
PCIBus *pci_bus_new(DeviceState *parent, const char *name, PCIBus *pci_bus_new(DeviceState *parent, const char *name,
MemoryRegion *address_space_mem, MemoryRegion *address_space_mem,
MemoryRegion *address_space_io, MemoryRegion *address_space_io,
uint8_t devfn_min) uint8_t devfn_min, const char *typename)
{ {
PCIBus *bus; PCIBus *bus;
bus = PCI_BUS(qbus_create(TYPE_PCI_BUS, parent, name)); bus = PCI_BUS(qbus_create(typename, parent, name));
pci_bus_init(bus, parent, name, address_space_mem, pci_bus_init(bus, parent, name, address_space_mem,
address_space_io, devfn_min); address_space_io, devfn_min);
return bus; return bus;
...@@ -343,12 +343,12 @@ PCIBus *pci_register_bus(DeviceState *parent, const char *name, ...@@ -343,12 +343,12 @@ PCIBus *pci_register_bus(DeviceState *parent, const char *name,
void *irq_opaque, void *irq_opaque,
MemoryRegion *address_space_mem, MemoryRegion *address_space_mem,
MemoryRegion *address_space_io, MemoryRegion *address_space_io,
uint8_t devfn_min, int nirq) uint8_t devfn_min, int nirq, const char *typename)
{ {
PCIBus *bus; PCIBus *bus;
bus = pci_bus_new(parent, name, address_space_mem, bus = pci_bus_new(parent, name, address_space_mem,
address_space_io, devfn_min); address_space_io, devfn_min, typename);
pci_bus_irqs(bus, set_irq, map_irq, irq_opaque, nirq); pci_bus_irqs(bus, set_irq, map_irq, irq_opaque, nirq);
return bus; return bus;
} }
......
...@@ -348,11 +348,11 @@ void pci_bus_new_inplace(PCIBus *bus, DeviceState *parent, ...@@ -348,11 +348,11 @@ void pci_bus_new_inplace(PCIBus *bus, DeviceState *parent,
const char *name, const char *name,
MemoryRegion *address_space_mem, MemoryRegion *address_space_mem,
MemoryRegion *address_space_io, MemoryRegion *address_space_io,
uint8_t devfn_min); uint8_t devfn_min, const char *typename);
PCIBus *pci_bus_new(DeviceState *parent, const char *name, PCIBus *pci_bus_new(DeviceState *parent, const char *name,
MemoryRegion *address_space_mem, MemoryRegion *address_space_mem,
MemoryRegion *address_space_io, MemoryRegion *address_space_io,
uint8_t devfn_min); uint8_t devfn_min, const char *typename);
void pci_bus_irqs(PCIBus *bus, pci_set_irq_fn set_irq, pci_map_irq_fn map_irq, void pci_bus_irqs(PCIBus *bus, pci_set_irq_fn set_irq, pci_map_irq_fn map_irq,
void *irq_opaque, int nirq); void *irq_opaque, int nirq);
int pci_bus_get_irq_level(PCIBus *bus, int irq_num); int pci_bus_get_irq_level(PCIBus *bus, int irq_num);
...@@ -364,7 +364,7 @@ PCIBus *pci_register_bus(DeviceState *parent, const char *name, ...@@ -364,7 +364,7 @@ PCIBus *pci_register_bus(DeviceState *parent, const char *name,
void *irq_opaque, void *irq_opaque,
MemoryRegion *address_space_mem, MemoryRegion *address_space_mem,
MemoryRegion *address_space_io, MemoryRegion *address_space_io,
uint8_t devfn_min, int nirq); uint8_t devfn_min, int nirq, const char *typename);
void pci_bus_set_route_irq_fn(PCIBus *, pci_route_irq_fn); void pci_bus_set_route_irq_fn(PCIBus *, pci_route_irq_fn);
PCIINTxRoute pci_device_route_intx_to_irq(PCIDevice *dev, int pin); PCIINTxRoute pci_device_route_intx_to_irq(PCIDevice *dev, int pin);
bool pci_intx_route_changed(PCIINTxRoute *old, PCIINTxRoute *new); bool pci_intx_route_changed(PCIINTxRoute *old, PCIINTxRoute *new);
......
...@@ -328,7 +328,7 @@ void pci_bridge_reset(DeviceState *qdev) ...@@ -328,7 +328,7 @@ void pci_bridge_reset(DeviceState *qdev)
} }
/* default qdev initialization function for PCI-to-PCI bridge */ /* default qdev initialization function for PCI-to-PCI bridge */
int pci_bridge_initfn(PCIDevice *dev) int pci_bridge_initfn(PCIDevice *dev, const char *typename)
{ {
PCIBus *parent = dev->bus; PCIBus *parent = dev->bus;
PCIBridge *br = DO_UPCAST(PCIBridge, dev, dev); PCIBridge *br = DO_UPCAST(PCIBridge, dev, dev);
...@@ -363,8 +363,7 @@ int pci_bridge_initfn(PCIDevice *dev) ...@@ -363,8 +363,7 @@ int pci_bridge_initfn(PCIDevice *dev)
br->bus_name = dev->qdev.id; br->bus_name = dev->qdev.id;
} }
qbus_create_inplace(&sec_bus->qbus, TYPE_PCI_BUS, &dev->qdev, qbus_create_inplace(&sec_bus->qbus, typename, &dev->qdev, br->bus_name);
br->bus_name);
sec_bus->parent_dev = dev; sec_bus->parent_dev = dev;
sec_bus->map_irq = br->map_irq ? br->map_irq : pci_swizzle_map_irq_fn; sec_bus->map_irq = br->map_irq ? br->map_irq : pci_swizzle_map_irq_fn;
sec_bus->address_space_mem = &br->address_space_mem; sec_bus->address_space_mem = &br->address_space_mem;
......
...@@ -43,7 +43,7 @@ void pci_bridge_disable_base_limit(PCIDevice *dev); ...@@ -43,7 +43,7 @@ void pci_bridge_disable_base_limit(PCIDevice *dev);
void pci_bridge_reset_reg(PCIDevice *dev); void pci_bridge_reset_reg(PCIDevice *dev);
void pci_bridge_reset(DeviceState *qdev); void pci_bridge_reset(DeviceState *qdev);
int pci_bridge_initfn(PCIDevice *pci_dev); int pci_bridge_initfn(PCIDevice *pci_dev, const char *typename);
void pci_bridge_exitfn(PCIDevice *pci_dev); void pci_bridge_exitfn(PCIDevice *pci_dev);
......
...@@ -42,7 +42,7 @@ static int pci_bridge_dev_initfn(PCIDevice *dev) ...@@ -42,7 +42,7 @@ static int pci_bridge_dev_initfn(PCIDevice *dev)
PCIBridgeDev *bridge_dev = DO_UPCAST(PCIBridgeDev, bridge, br); PCIBridgeDev *bridge_dev = DO_UPCAST(PCIBridgeDev, bridge, br);
int err; int err;
err = pci_bridge_initfn(dev); err = pci_bridge_initfn(dev, TYPE_PCI_BUS);
if (err) { if (err) {
goto bridge_error; goto bridge_error;
} }
......
...@@ -245,7 +245,7 @@ static PCIBus *i440fx_common_init(const char *device_name, ...@@ -245,7 +245,7 @@ static PCIBus *i440fx_common_init(const char *device_name,
dev = qdev_create(NULL, "i440FX-pcihost"); dev = qdev_create(NULL, "i440FX-pcihost");
s = PCI_HOST_BRIDGE(dev); s = PCI_HOST_BRIDGE(dev);
b = pci_bus_new(dev, NULL, pci_address_space, b = pci_bus_new(dev, NULL, pci_address_space,
address_space_io, 0); address_space_io, 0, TYPE_PCI_BUS);
s->bus = b; s->bus = b;
object_property_add_child(qdev_get_machine(), "i440fx", OBJECT(dev), NULL); object_property_add_child(qdev_get_machine(), "i440fx", OBJECT(dev), NULL);
qdev_init_nofail(dev); qdev_init_nofail(dev);
......
...@@ -349,7 +349,7 @@ static int ppc4xx_pcihost_initfn(SysBusDevice *dev) ...@@ -349,7 +349,7 @@ static int ppc4xx_pcihost_initfn(SysBusDevice *dev)
b = pci_register_bus(DEVICE(dev), NULL, ppc4xx_pci_set_irq, b = pci_register_bus(DEVICE(dev), NULL, ppc4xx_pci_set_irq,
ppc4xx_pci_map_irq, s->irq, get_system_memory(), ppc4xx_pci_map_irq, s->irq, get_system_memory(),
get_system_io(), 0, 4); get_system_io(), 0, 4, TYPE_PCI_BUS);
h->bus = b; h->bus = b;
pci_create_simple(b, 0, "ppc4xx-host-bridge"); pci_create_simple(b, 0, "ppc4xx-host-bridge");
......
...@@ -356,7 +356,7 @@ static int e500_pcihost_initfn(SysBusDevice *dev) ...@@ -356,7 +356,7 @@ static int e500_pcihost_initfn(SysBusDevice *dev)
b = pci_register_bus(DEVICE(dev), NULL, mpc85xx_pci_set_irq, b = pci_register_bus(DEVICE(dev), NULL, mpc85xx_pci_set_irq,
mpc85xx_pci_map_irq, s->irq, address_space_mem, mpc85xx_pci_map_irq, s->irq, address_space_mem,
&s->pio, PCI_DEVFN(s->first_slot, 0), 4); &s->pio, PCI_DEVFN(s->first_slot, 0), 4, TYPE_PCI_BUS);
h->bus = b; h->bus = b;
pci_create_simple(b, 0, "e500-host-bridge"); pci_create_simple(b, 0, "e500-host-bridge");
......
...@@ -154,7 +154,7 @@ static void raven_pcihost_initfn(Object *obj) ...@@ -154,7 +154,7 @@ static void raven_pcihost_initfn(Object *obj)
DeviceState *pci_dev; DeviceState *pci_dev;
pci_bus_new_inplace(&s->pci_bus, DEVICE(obj), NULL, pci_bus_new_inplace(&s->pci_bus, DEVICE(obj), NULL,
address_space_mem, address_space_io, 0); address_space_mem, address_space_io, 0, TYPE_PCI_BUS);
h->bus = &s->pci_bus; h->bus = &s->pci_bus;
object_initialize(&s->pci_dev, TYPE_RAVEN_PCI_DEVICE); object_initialize(&s->pci_dev, TYPE_RAVEN_PCI_DEVICE);
......
...@@ -54,7 +54,8 @@ static int q35_host_init(SysBusDevice *dev) ...@@ -54,7 +54,8 @@ static int q35_host_init(SysBusDevice *dev)
return -1; return -1;
} }
b = pci_bus_new(&s->host.pci.busdev.qdev, "pcie.0", b = pci_bus_new(&s->host.pci.busdev.qdev, "pcie.0",
s->mch.pci_address_space, s->mch.address_space_io, 0); s->mch.pci_address_space, s->mch.address_space_io,
0, TYPE_PCI_BUS);
s->host.pci.bus = b; s->host.pci.bus = b;
qdev_set_parent_bus(DEVICE(&s->mch), BUS(b)); qdev_set_parent_bus(DEVICE(&s->mch), BUS(b));
qdev_init_nofail(DEVICE(&s->mch)); qdev_init_nofail(DEVICE(&s->mch));
......
...@@ -124,7 +124,7 @@ static int sh_pci_device_init(SysBusDevice *dev) ...@@ -124,7 +124,7 @@ static int sh_pci_device_init(SysBusDevice *dev)
s->irq, s->irq,
get_system_memory(), get_system_memory(),
get_system_io(), get_system_io(),
PCI_DEVFN(0, 0), 4); PCI_DEVFN(0, 0), 4, TYPE_PCI_BUS);
memory_region_init_io(&s->memconfig_p4, &sh_pci_reg_ops, s, memory_region_init_io(&s->memconfig_p4, &sh_pci_reg_ops, s,
"sh_pci", 0x224); "sh_pci", 0x224);
memory_region_init_alias(&s->memconfig_a7, "sh_pci.2", &s->memconfig_p4, memory_region_init_alias(&s->memconfig_a7, "sh_pci.2", &s->memconfig_p4,
......
...@@ -624,7 +624,7 @@ static int spapr_phb_init(SysBusDevice *s) ...@@ -624,7 +624,7 @@ static int spapr_phb_init(SysBusDevice *s)
bus = pci_register_bus(DEVICE(s), sphb->busname, bus = pci_register_bus(DEVICE(s), sphb->busname,
pci_spapr_set_irq, pci_spapr_map_irq, sphb, pci_spapr_set_irq, pci_spapr_map_irq, sphb,
&sphb->memspace, &sphb->iospace, &sphb->memspace, &sphb->iospace,
PCI_DEVFN(0, 0), PCI_NUM_PINS); PCI_DEVFN(0, 0), PCI_NUM_PINS, TYPE_PCI_BUS);
phb->bus = bus; phb->bus = bus;
sphb->dma_window_start = 0; sphb->dma_window_start = 0;
......
...@@ -239,7 +239,7 @@ PCIBus *pci_pmac_init(qemu_irq *pic, ...@@ -239,7 +239,7 @@ PCIBus *pci_pmac_init(qemu_irq *pic,
pic, pic,
&d->pci_mmio, &d->pci_mmio,
address_space_io, address_space_io,
PCI_DEVFN(11, 0), 4); PCI_DEVFN(11, 0), 4, TYPE_PCI_BUS);
#if 0 #if 0
pci_create_simple(h->bus, PCI_DEVFN(11, 0), "uni-north"); pci_create_simple(h->bus, PCI_DEVFN(11, 0), "uni-north");
...@@ -305,7 +305,7 @@ PCIBus *pci_pmac_u3_init(qemu_irq *pic, ...@@ -305,7 +305,7 @@ PCIBus *pci_pmac_u3_init(qemu_irq *pic,
pic, pic,
&d->pci_mmio, &d->pci_mmio,
address_space_io, address_space_io,
PCI_DEVFN(11, 0), 4); PCI_DEVFN(11, 0), 4, TYPE_PCI_BUS);
sysbus_mmio_map(s, 0, 0xf0800000); sysbus_mmio_map(s, 0, 0xf0800000);
sysbus_mmio_map(s, 1, 0xf0c00000); sysbus_mmio_map(s, 1, 0xf0c00000);
......
...@@ -70,7 +70,7 @@ static int pci_vpb_init(SysBusDevice *dev) ...@@ -70,7 +70,7 @@ static int pci_vpb_init(SysBusDevice *dev)
bus = pci_register_bus(&dev->qdev, "pci", bus = pci_register_bus(&dev->qdev, "pci",
pci_vpb_set_irq, pci_vpb_map_irq, s->irq, pci_vpb_set_irq, pci_vpb_map_irq, s->irq,
get_system_memory(), get_system_io(), get_system_memory(), get_system_io(),
PCI_DEVFN(11, 0), 4); PCI_DEVFN(11, 0), 4, TYPE_PCI_BUS);
/* ??? Register memory space. */ /* ??? Register memory space. */
......
...@@ -61,7 +61,7 @@ static int xio3130_downstream_initfn(PCIDevice *d) ...@@ -61,7 +61,7 @@ static int xio3130_downstream_initfn(PCIDevice *d)
PCIESlot *s = DO_UPCAST(PCIESlot, port, p); PCIESlot *s = DO_UPCAST(PCIESlot, port, p);
int rc; int rc;
rc = pci_bridge_initfn(d); rc = pci_bridge_initfn(d, TYPE_PCI_BUS);
if (rc < 0) { if (rc < 0) {
return rc; return rc;
} }
......
...@@ -57,7 +57,7 @@ static int xio3130_upstream_initfn(PCIDevice *d) ...@@ -57,7 +57,7 @@ static int xio3130_upstream_initfn(PCIDevice *d)
PCIEPort *p = DO_UPCAST(PCIEPort, br, br); PCIEPort *p = DO_UPCAST(PCIEPort, br, br);
int rc; int rc;
rc = pci_bridge_initfn(d); rc = pci_bridge_initfn(d, TYPE_PCI_BUS);
if (rc < 0) { if (rc < 0) {
return rc; return rc;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部