|
@@ -455,10 +455,9 @@ static void exynos4210_realize(DeviceState *socdev, Error **errp)
|
|
sysbus_create_simple("l2x0", EXYNOS4210_L2X0_BASE_ADDR, NULL);
|
|
sysbus_create_simple("l2x0", EXYNOS4210_L2X0_BASE_ADDR, NULL);
|
|
|
|
|
|
/* External GIC */
|
|
/* External GIC */
|
|
- dev = qdev_new("exynos4210.gic");
|
|
|
|
- qdev_prop_set_uint32(dev, "num-cpu", EXYNOS4210_NCPUS);
|
|
|
|
- busdev = SYS_BUS_DEVICE(dev);
|
|
|
|
- sysbus_realize_and_unref(busdev, &error_fatal);
|
|
|
|
|
|
+ qdev_prop_set_uint32(DEVICE(&s->ext_gic), "num-cpu", EXYNOS4210_NCPUS);
|
|
|
|
+ busdev = SYS_BUS_DEVICE(&s->ext_gic);
|
|
|
|
+ sysbus_realize(busdev, &error_fatal);
|
|
/* Map CPU interface */
|
|
/* Map CPU interface */
|
|
sysbus_mmio_map(busdev, 0, EXYNOS4210_EXT_GIC_CPU_BASE_ADDR);
|
|
sysbus_mmio_map(busdev, 0, EXYNOS4210_EXT_GIC_CPU_BASE_ADDR);
|
|
/* Map Distributer interface */
|
|
/* Map Distributer interface */
|
|
@@ -468,7 +467,7 @@ static void exynos4210_realize(DeviceState *socdev, Error **errp)
|
|
qdev_get_gpio_in(DEVICE(&s->cpu_irq_orgate[n]), 1));
|
|
qdev_get_gpio_in(DEVICE(&s->cpu_irq_orgate[n]), 1));
|
|
}
|
|
}
|
|
for (n = 0; n < EXYNOS4210_EXT_GIC_NIRQ; n++) {
|
|
for (n = 0; n < EXYNOS4210_EXT_GIC_NIRQ; n++) {
|
|
- s->irqs.ext_gic_irq[n] = qdev_get_gpio_in(dev, n);
|
|
|
|
|
|
+ s->irqs.ext_gic_irq[n] = qdev_get_gpio_in(DEVICE(&s->ext_gic), n);
|
|
}
|
|
}
|
|
|
|
|
|
/* Internal Interrupt Combiner */
|
|
/* Internal Interrupt Combiner */
|
|
@@ -686,6 +685,7 @@ static void exynos4210_init(Object *obj)
|
|
}
|
|
}
|
|
|
|
|
|
object_initialize_child(obj, "a9mpcore", &s->a9mpcore, TYPE_A9MPCORE_PRIV);
|
|
object_initialize_child(obj, "a9mpcore", &s->a9mpcore, TYPE_A9MPCORE_PRIV);
|
|
|
|
+ object_initialize_child(obj, "ext-gic", &s->ext_gic, TYPE_EXYNOS4210_GIC);
|
|
}
|
|
}
|
|
|
|
|
|
static void exynos4210_class_init(ObjectClass *klass, void *data)
|
|
static void exynos4210_class_init(ObjectClass *klass, void *data)
|