mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 16:53:55 -06:00
macio: move OpenPIC inside macio-newworld device
The OpenPIC device is located within the macio device on real hardware so make it a child of the macio-newworld device. This also removes the need for setting and checking a separate PIC object property link on the macio-newworld device which currently causes the automated QOM introspection tests to fail. Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Reviewed-by: David Gibson <david@gibson.dropbear.id.au> Message-Id: <20201229175619.6051-6-mark.cave-ayland@ilande.co.uk> Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
This commit is contained in:
parent
6ce97b225e
commit
7e4d62dfee
3 changed files with 21 additions and 25 deletions
|
@ -273,7 +273,7 @@ static void macio_newworld_realize(PCIDevice *d, Error **errp)
|
|||
{
|
||||
MacIOState *s = MACIO(d);
|
||||
NewWorldMacIOState *ns = NEWWORLD_MACIO(d);
|
||||
DeviceState *pic_dev = DEVICE(ns->pic);
|
||||
DeviceState *pic_dev = DEVICE(&ns->pic);
|
||||
Error *err = NULL;
|
||||
SysBusDevice *sysbus_dev;
|
||||
MemoryRegion *timer_memory = NULL;
|
||||
|
@ -284,17 +284,19 @@ static void macio_newworld_realize(PCIDevice *d, Error **errp)
|
|||
return;
|
||||
}
|
||||
|
||||
/* OpenPIC */
|
||||
qdev_prop_set_uint32(pic_dev, "model", OPENPIC_MODEL_KEYLARGO);
|
||||
sysbus_dev = SYS_BUS_DEVICE(&ns->pic);
|
||||
sysbus_realize_and_unref(sysbus_dev, &error_fatal);
|
||||
memory_region_add_subregion(&s->bar, 0x40000,
|
||||
sysbus_mmio_get_region(sysbus_dev, 0));
|
||||
|
||||
sysbus_dev = SYS_BUS_DEVICE(&s->escc);
|
||||
sysbus_connect_irq(sysbus_dev, 0, qdev_get_gpio_in(pic_dev,
|
||||
NEWWORLD_ESCCB_IRQ));
|
||||
sysbus_connect_irq(sysbus_dev, 1, qdev_get_gpio_in(pic_dev,
|
||||
NEWWORLD_ESCCA_IRQ));
|
||||
|
||||
/* OpenPIC */
|
||||
sysbus_dev = SYS_BUS_DEVICE(ns->pic);
|
||||
memory_region_add_subregion(&s->bar, 0x40000,
|
||||
sysbus_mmio_get_region(sysbus_dev, 0));
|
||||
|
||||
/* IDE buses */
|
||||
macio_realize_ide(s, &ns->ide[0],
|
||||
qdev_get_gpio_in(pic_dev, NEWWORLD_IDE0_IRQ),
|
||||
|
@ -369,10 +371,7 @@ static void macio_newworld_init(Object *obj)
|
|||
NewWorldMacIOState *ns = NEWWORLD_MACIO(obj);
|
||||
int i;
|
||||
|
||||
object_property_add_link(obj, "pic", TYPE_OPENPIC,
|
||||
(Object **) &ns->pic,
|
||||
qdev_prop_allow_set_link_before_realize,
|
||||
0);
|
||||
object_initialize_child(OBJECT(s), "pic", &ns->pic, TYPE_OPENPIC);
|
||||
|
||||
object_initialize_child(OBJECT(s), "gpio", &ns->gpio, TYPE_MACIO_GPIO);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue