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
@ -273,7 +273,7 @@ static void macio_newworld_realize(PCIDevice *d, Error **errp)
|
|||||||
{
|
{
|
||||||
MacIOState *s = MACIO(d);
|
MacIOState *s = MACIO(d);
|
||||||
NewWorldMacIOState *ns = NEWWORLD_MACIO(d);
|
NewWorldMacIOState *ns = NEWWORLD_MACIO(d);
|
||||||
DeviceState *pic_dev = DEVICE(ns->pic);
|
DeviceState *pic_dev = DEVICE(&ns->pic);
|
||||||
Error *err = NULL;
|
Error *err = NULL;
|
||||||
SysBusDevice *sysbus_dev;
|
SysBusDevice *sysbus_dev;
|
||||||
MemoryRegion *timer_memory = NULL;
|
MemoryRegion *timer_memory = NULL;
|
||||||
@ -284,17 +284,19 @@ static void macio_newworld_realize(PCIDevice *d, Error **errp)
|
|||||||
return;
|
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_dev = SYS_BUS_DEVICE(&s->escc);
|
||||||
sysbus_connect_irq(sysbus_dev, 0, qdev_get_gpio_in(pic_dev,
|
sysbus_connect_irq(sysbus_dev, 0, qdev_get_gpio_in(pic_dev,
|
||||||
NEWWORLD_ESCCB_IRQ));
|
NEWWORLD_ESCCB_IRQ));
|
||||||
sysbus_connect_irq(sysbus_dev, 1, qdev_get_gpio_in(pic_dev,
|
sysbus_connect_irq(sysbus_dev, 1, qdev_get_gpio_in(pic_dev,
|
||||||
NEWWORLD_ESCCA_IRQ));
|
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 */
|
/* IDE buses */
|
||||||
macio_realize_ide(s, &ns->ide[0],
|
macio_realize_ide(s, &ns->ide[0],
|
||||||
qdev_get_gpio_in(pic_dev, NEWWORLD_IDE0_IRQ),
|
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);
|
NewWorldMacIOState *ns = NEWWORLD_MACIO(obj);
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
object_property_add_link(obj, "pic", TYPE_OPENPIC,
|
object_initialize_child(OBJECT(s), "pic", &ns->pic, TYPE_OPENPIC);
|
||||||
(Object **) &ns->pic,
|
|
||||||
qdev_prop_allow_set_link_before_realize,
|
|
||||||
0);
|
|
||||||
|
|
||||||
object_initialize_child(OBJECT(s), "gpio", &ns->gpio, TYPE_MACIO_GPIO);
|
object_initialize_child(OBJECT(s), "gpio", &ns->gpio, TYPE_MACIO_GPIO);
|
||||||
|
|
||||||
|
@ -293,18 +293,6 @@ static void ppc_core99_init(MachineState *machine)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pic_dev = qdev_new(TYPE_OPENPIC);
|
|
||||||
qdev_prop_set_uint32(pic_dev, "model", OPENPIC_MODEL_KEYLARGO);
|
|
||||||
s = SYS_BUS_DEVICE(pic_dev);
|
|
||||||
sysbus_realize_and_unref(s, &error_fatal);
|
|
||||||
k = 0;
|
|
||||||
for (i = 0; i < smp_cpus; i++) {
|
|
||||||
for (j = 0; j < OPENPIC_OUTPUT_NB; j++) {
|
|
||||||
sysbus_connect_irq(s, k++, openpic_irqs[i].irq[j]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
g_free(openpic_irqs);
|
|
||||||
|
|
||||||
if (PPC_INPUT(env) == PPC_FLAGS_INPUT_970) {
|
if (PPC_INPUT(env) == PPC_FLAGS_INPUT_970) {
|
||||||
/* 970 gets a U3 bus */
|
/* 970 gets a U3 bus */
|
||||||
/* Uninorth AGP bus */
|
/* Uninorth AGP bus */
|
||||||
@ -378,8 +366,6 @@ static void ppc_core99_init(MachineState *machine)
|
|||||||
qdev_prop_set_uint64(dev, "frequency", tbfreq);
|
qdev_prop_set_uint64(dev, "frequency", tbfreq);
|
||||||
qdev_prop_set_bit(dev, "has-pmu", has_pmu);
|
qdev_prop_set_bit(dev, "has-pmu", has_pmu);
|
||||||
qdev_prop_set_bit(dev, "has-adb", has_adb);
|
qdev_prop_set_bit(dev, "has-adb", has_adb);
|
||||||
object_property_set_link(OBJECT(macio), "pic", OBJECT(pic_dev),
|
|
||||||
&error_abort);
|
|
||||||
|
|
||||||
escc = ESCC(object_resolve_path_component(OBJECT(macio), "escc"));
|
escc = ESCC(object_resolve_path_component(OBJECT(macio), "escc"));
|
||||||
qdev_prop_set_chr(DEVICE(escc), "chrA", serial_hd(0));
|
qdev_prop_set_chr(DEVICE(escc), "chrA", serial_hd(0));
|
||||||
@ -387,6 +373,7 @@ static void ppc_core99_init(MachineState *machine)
|
|||||||
|
|
||||||
pci_realize_and_unref(macio, pci_bus, &error_fatal);
|
pci_realize_and_unref(macio, pci_bus, &error_fatal);
|
||||||
|
|
||||||
|
pic_dev = DEVICE(object_resolve_path_component(OBJECT(macio), "pic"));
|
||||||
for (i = 0; i < 4; i++) {
|
for (i = 0; i < 4; i++) {
|
||||||
qdev_connect_gpio_out(DEVICE(uninorth_pci), i,
|
qdev_connect_gpio_out(DEVICE(uninorth_pci), i,
|
||||||
qdev_get_gpio_in(pic_dev, 0x1b + i));
|
qdev_get_gpio_in(pic_dev, 0x1b + i));
|
||||||
@ -407,6 +394,16 @@ static void ppc_core99_init(MachineState *machine)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* OpenPIC */
|
||||||
|
s = SYS_BUS_DEVICE(pic_dev);
|
||||||
|
k = 0;
|
||||||
|
for (i = 0; i < smp_cpus; i++) {
|
||||||
|
for (j = 0; j < OPENPIC_OUTPUT_NB; j++) {
|
||||||
|
sysbus_connect_irq(s, k++, openpic_irqs[i].irq[j]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_free(openpic_irqs);
|
||||||
|
|
||||||
/* We only emulate 2 out of 3 IDE controllers for now */
|
/* We only emulate 2 out of 3 IDE controllers for now */
|
||||||
ide_drive_get(hd, ARRAY_SIZE(hd));
|
ide_drive_get(hd, ARRAY_SIZE(hd));
|
||||||
|
|
||||||
|
@ -115,7 +115,7 @@ struct NewWorldMacIOState {
|
|||||||
|
|
||||||
bool has_pmu;
|
bool has_pmu;
|
||||||
bool has_adb;
|
bool has_adb;
|
||||||
OpenPICState *pic;
|
OpenPICState pic;
|
||||||
MACIOIDEState ide[2];
|
MACIOIDEState ide[2];
|
||||||
MacIOGPIOState gpio;
|
MacIOGPIOState gpio;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user