q35: Use QOM realize for q35 host bridge
And split off MemoryRegion initialization into instance_init. Signed-off-by: Hu Tao <hutao@cn.fujitsu.com> Signed-off-by: Andreas Färber <afaerber@suse.de>
This commit is contained in:
parent
ce88812f57
commit
62d92e432f
@ -34,31 +34,27 @@
|
|||||||
* Q35 host
|
* Q35 host
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static int q35_host_init(SysBusDevice *dev)
|
static void q35_host_realize(DeviceState *dev, Error **errp)
|
||||||
{
|
{
|
||||||
PCIHostState *pci = PCI_HOST_BRIDGE(dev);
|
PCIHostState *pci = PCI_HOST_BRIDGE(dev);
|
||||||
Q35PCIHost *s = Q35_HOST_DEVICE(dev);
|
Q35PCIHost *s = Q35_HOST_DEVICE(dev);
|
||||||
|
SysBusDevice *sbd = SYS_BUS_DEVICE(dev);
|
||||||
|
|
||||||
memory_region_init_io(&pci->conf_mem, OBJECT(pci), &pci_host_conf_le_ops, pci,
|
sysbus_add_io(sbd, MCH_HOST_BRIDGE_CONFIG_ADDR, &pci->conf_mem);
|
||||||
"pci-conf-idx", 4);
|
sysbus_init_ioports(sbd, MCH_HOST_BRIDGE_CONFIG_ADDR, 4);
|
||||||
sysbus_add_io(dev, MCH_HOST_BRIDGE_CONFIG_ADDR, &pci->conf_mem);
|
|
||||||
sysbus_init_ioports(dev, MCH_HOST_BRIDGE_CONFIG_ADDR, 4);
|
|
||||||
|
|
||||||
memory_region_init_io(&pci->data_mem, OBJECT(pci), &pci_host_data_le_ops, pci,
|
sysbus_add_io(sbd, MCH_HOST_BRIDGE_CONFIG_DATA, &pci->data_mem);
|
||||||
"pci-conf-data", 4);
|
sysbus_init_ioports(sbd, MCH_HOST_BRIDGE_CONFIG_DATA, 4);
|
||||||
sysbus_add_io(dev, MCH_HOST_BRIDGE_CONFIG_DATA, &pci->data_mem);
|
|
||||||
sysbus_init_ioports(dev, MCH_HOST_BRIDGE_CONFIG_DATA, 4);
|
|
||||||
|
|
||||||
if (pcie_host_init(PCIE_HOST_BRIDGE(s)) < 0) {
|
if (pcie_host_init(PCIE_HOST_BRIDGE(s)) < 0) {
|
||||||
return -1;
|
error_setg(errp, "failed to initialize pcie host");
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
pci->bus = pci_bus_new(DEVICE(s), "pcie.0",
|
pci->bus = pci_bus_new(DEVICE(s), "pcie.0",
|
||||||
s->mch.pci_address_space, s->mch.address_space_io,
|
s->mch.pci_address_space, s->mch.address_space_io,
|
||||||
0, TYPE_PCIE_BUS);
|
0, TYPE_PCIE_BUS);
|
||||||
qdev_set_parent_bus(DEVICE(&s->mch), BUS(pci->bus));
|
qdev_set_parent_bus(DEVICE(&s->mch), BUS(pci->bus));
|
||||||
qdev_init_nofail(DEVICE(&s->mch));
|
qdev_init_nofail(DEVICE(&s->mch));
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *q35_host_root_bus_path(PCIHostState *host_bridge,
|
static const char *q35_host_root_bus_path(PCIHostState *host_bridge,
|
||||||
@ -77,11 +73,10 @@ static Property mch_props[] = {
|
|||||||
static void q35_host_class_init(ObjectClass *klass, void *data)
|
static void q35_host_class_init(ObjectClass *klass, void *data)
|
||||||
{
|
{
|
||||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||||
SysBusDeviceClass *k = SYS_BUS_DEVICE_CLASS(klass);
|
|
||||||
PCIHostBridgeClass *hc = PCI_HOST_BRIDGE_CLASS(klass);
|
PCIHostBridgeClass *hc = PCI_HOST_BRIDGE_CLASS(klass);
|
||||||
|
|
||||||
hc->root_bus_path = q35_host_root_bus_path;
|
hc->root_bus_path = q35_host_root_bus_path;
|
||||||
k->init = q35_host_init;
|
dc->realize = q35_host_realize;
|
||||||
dc->props = mch_props;
|
dc->props = mch_props;
|
||||||
dc->fw_name = "pci";
|
dc->fw_name = "pci";
|
||||||
}
|
}
|
||||||
@ -89,6 +84,12 @@ static void q35_host_class_init(ObjectClass *klass, void *data)
|
|||||||
static void q35_host_initfn(Object *obj)
|
static void q35_host_initfn(Object *obj)
|
||||||
{
|
{
|
||||||
Q35PCIHost *s = Q35_HOST_DEVICE(obj);
|
Q35PCIHost *s = Q35_HOST_DEVICE(obj);
|
||||||
|
PCIHostState *phb = PCI_HOST_BRIDGE(obj);
|
||||||
|
|
||||||
|
memory_region_init_io(&phb->conf_mem, obj, &pci_host_conf_le_ops, phb,
|
||||||
|
"pci-conf-idx", 4);
|
||||||
|
memory_region_init_io(&phb->data_mem, obj, &pci_host_data_le_ops, phb,
|
||||||
|
"pci-conf-data", 4);
|
||||||
|
|
||||||
object_initialize(&s->mch, TYPE_MCH_PCI_DEVICE);
|
object_initialize(&s->mch, TYPE_MCH_PCI_DEVICE);
|
||||||
object_property_add_child(OBJECT(s), "mch", OBJECT(&s->mch), NULL);
|
object_property_add_child(OBJECT(s), "mch", OBJECT(&s->mch), NULL);
|
||||||
|
Loading…
Reference in New Issue
Block a user