mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-08 02:03:56 -06:00
macio: move heathrow PIC inside macio-oldworld device
The heathrow PIC is located within the macio device on real hardware so make it a child of the macio-oldworld device. This also removes the need for setting and checking a separate PIC object property link on the macio-oldworld 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-4-mark.cave-ayland@ilande.co.uk> Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
This commit is contained in:
parent
49ac51ae80
commit
370022ce31
3 changed files with 43 additions and 45 deletions
|
@ -140,7 +140,7 @@ static void macio_oldworld_realize(PCIDevice *d, Error **errp)
|
|||
{
|
||||
MacIOState *s = MACIO(d);
|
||||
OldWorldMacIOState *os = OLDWORLD_MACIO(d);
|
||||
DeviceState *pic_dev = DEVICE(os->pic);
|
||||
DeviceState *pic_dev = DEVICE(&os->pic);
|
||||
Error *err = NULL;
|
||||
SysBusDevice *sysbus_dev;
|
||||
|
||||
|
@ -150,6 +150,14 @@ static void macio_oldworld_realize(PCIDevice *d, Error **errp)
|
|||
return;
|
||||
}
|
||||
|
||||
/* Heathrow PIC */
|
||||
if (!qdev_realize(DEVICE(&os->pic), BUS(&s->macio_bus), errp)) {
|
||||
return;
|
||||
}
|
||||
sysbus_dev = SYS_BUS_DEVICE(&os->pic);
|
||||
memory_region_add_subregion(&s->bar, 0x0,
|
||||
sysbus_mmio_get_region(sysbus_dev, 0));
|
||||
|
||||
qdev_prop_set_uint64(DEVICE(&s->cuda), "timebase-frequency",
|
||||
s->frequency);
|
||||
if (!qdev_realize(DEVICE(&s->cuda), BUS(&s->macio_bus), errp)) {
|
||||
|
@ -175,11 +183,6 @@ static void macio_oldworld_realize(PCIDevice *d, Error **errp)
|
|||
sysbus_mmio_get_region(sysbus_dev, 0));
|
||||
pmac_format_nvram_partition(&os->nvram, os->nvram.size);
|
||||
|
||||
/* Heathrow PIC */
|
||||
sysbus_dev = SYS_BUS_DEVICE(os->pic);
|
||||
memory_region_add_subregion(&s->bar, 0x0,
|
||||
sysbus_mmio_get_region(sysbus_dev, 0));
|
||||
|
||||
/* IDE buses */
|
||||
macio_realize_ide(s, &os->ide[0],
|
||||
qdev_get_gpio_in(pic_dev, OLDWORLD_IDE0_IRQ),
|
||||
|
@ -218,10 +221,7 @@ static void macio_oldworld_init(Object *obj)
|
|||
DeviceState *dev;
|
||||
int i;
|
||||
|
||||
object_property_add_link(obj, "pic", TYPE_HEATHROW,
|
||||
(Object **) &os->pic,
|
||||
qdev_prop_allow_set_link_before_realize,
|
||||
0);
|
||||
object_initialize_child(OBJECT(s), "pic", &os->pic, TYPE_HEATHROW);
|
||||
|
||||
object_initialize_child(OBJECT(s), "cuda", &s->cuda, TYPE_CUDA);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue