@@ -83,10 +83,8 @@
#define EXYNOS4210_NUM_SPLITTERS (EXYNOS4210_MAX_EXT_COMBINER_IN_IRQ + 38)
struct Exynos4210State {
- /*< private >*/
SysBusDevice parent_obj;
- /*< public >*/
- ARMCPU *cpu[EXYNOS4210_NCPUS];
+
qemu_irq irq_table[EXYNOS4210_MAX_INT_COMBINER_IN_IRQ];
MemoryRegion chipid_mem;
@@ -501,12 +501,6 @@ void exynos4210_write_secondary(ARMCPU *cpu,
info->smp_loader_start);
}
-static uint64_t exynos4210_calc_affinity(int cpu)
-{
- /* Exynos4210 has 0x9 as cluster ID */
- return (0x9 << ARM_AFF1_SHIFT) | cpu;
-}
-
static DeviceState *pl330_create(uint32_t base, OrIRQState *orgate,
qemu_irq irq, int nreq, int nevents, int width)
{
@@ -549,26 +543,25 @@ static void exynos4210_realize(DeviceState *socdev, Error **errp)
MemoryRegion *system_mem = get_system_memory();
SysBusDevice *busdev;
DeviceState *dev, *mpdev, *uart[4], *pl330[3];
+ CortexMPPrivState *mpcore;
int i, n;
- for (n = 0; n < EXYNOS4210_NCPUS; n++) {
- Object *cpuobj = object_new(ARM_CPU_TYPE_NAME("cortex-a9"));
-
- /* By default A9 CPUs have EL3 enabled. This board does not currently
- * support EL3 so the CPU EL3 property is disabled before realization.
- */
- if (object_property_find(cpuobj, "has_el3")) {
- object_property_set_bool(cpuobj, "has_el3", false, &error_fatal);
- }
-
- s->cpu[n] = ARM_CPU(cpuobj);
- object_property_set_int(cpuobj, "mp-affinity",
- exynos4210_calc_affinity(n), &error_abort);
- object_property_set_int(cpuobj, "reset-cbar",
- EXYNOS4210_SMP_PRIVATE_BASE_ADDR,
- &error_abort);
- qdev_realize(DEVICE(cpuobj), NULL, &error_fatal);
- }
+ /* Private memory region and Internal GIC */
+ mpdev = DEVICE(&s->a9mpcore);
+ mpcore = CORTEX_MPCORE_PRIV(&s->a9mpcore);
+ /* Exynos4210 has 0x9 as cluster ID */
+ qdev_prop_set_uint32(mpdev, "cluster-id", 0x9);
+ qdev_prop_set_uint32(mpdev, "num-cores", EXYNOS4210_NCPUS);
+ /*
+ * By default A9 CPUs have EL3 enabled. This board does not currently
+ * support EL3 so the CPU EL3 property is disabled before realization.
+ */
+ qdev_prop_set_bit(mpdev, "cpu-has-el3", false);
+ qdev_prop_set_uint64(mpdev, "cpu-reset-cbar",
+ EXYNOS4210_SMP_PRIVATE_BASE_ADDR);
+ busdev = SYS_BUS_DEVICE(&s->a9mpcore);
+ sysbus_realize(busdev, &error_fatal);
+ sysbus_mmio_map(busdev, 0, EXYNOS4210_SMP_PRIVATE_BASE_ADDR);
/* IRQ Gate */
for (i = 0; i < EXYNOS4210_NCPUS; i++) {
@@ -578,23 +571,10 @@ static void exynos4210_realize(DeviceState *socdev, Error **errp)
&error_abort);
qdev_realize(orgate, NULL, &error_abort);
qdev_connect_gpio_out(orgate, 0,
- qdev_get_gpio_in(DEVICE(s->cpu[i]), ARM_CPU_IRQ));
- }
-
- /* Private memory region and Internal GIC */
- mpdev = DEVICE(&s->a9mpcore);
- qdev_prop_set_uint32(mpdev, "num-cores", EXYNOS4210_NCPUS);
- /*
- * By default A9 CPUs have EL3 enabled. This board does not currently
- * support EL3 so the CPU EL3 property is disabled before realization.
- */
- qdev_prop_set_bit(mpdev, "cpu-has-el3", false);
- busdev = SYS_BUS_DEVICE(&s->a9mpcore);
- sysbus_realize(busdev, &error_fatal);
- sysbus_mmio_map(busdev, 0, EXYNOS4210_SMP_PRIVATE_BASE_ADDR);
- for (n = 0; n < EXYNOS4210_NCPUS; n++) {
- sysbus_connect_irq(busdev, n,
- qdev_get_gpio_in(DEVICE(&s->cpu_irq_orgate[n]), 0));
+ qdev_get_gpio_in(DEVICE(mpcore->cpu[i]),
+ ARM_CPU_IRQ));
+ sysbus_connect_irq(busdev, i,
+ qdev_get_gpio_in(DEVICE(&s->cpu_irq_orgate[i]), 0));
}
/* Cache controller */
@@ -136,18 +136,20 @@ static void nuri_init(MachineState *machine)
{
Exynos4BoardState *s = exynos4_boards_init_common(machine,
EXYNOS4_BOARD_NURI);
+ CortexMPPrivState *mp = CORTEX_MPCORE_PRIV(&s->soc.a9mpcore);
- arm_load_kernel(s->soc.cpu[0], machine, &exynos4_board_binfo);
+ arm_load_kernel(mp->cpu[0], machine, &exynos4_board_binfo);
}
static void smdkc210_init(MachineState *machine)
{
Exynos4BoardState *s = exynos4_boards_init_common(machine,
EXYNOS4_BOARD_SMDKC210);
+ CortexMPPrivState *mp = CORTEX_MPCORE_PRIV(&s->soc.a9mpcore);
lan9215_init(SMDK_LAN9118_BASE_ADDR,
qemu_irq_invert(s->soc.irq_table[exynos4210_get_irq(37, 1)]));
- arm_load_kernel(s->soc.cpu[0], machine, &exynos4_board_binfo);
+ arm_load_kernel(mp->cpu[0], machine, &exynos4_board_binfo);
}
static void nuri_class_init(ObjectClass *oc, void *data)
Set the properties on the a9mpcore object to let it create and wire the CPU cores. Remove the redundant code. Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> --- include/hw/arm/exynos4210.h | 4 +-- hw/arm/exynos4210.c | 62 +++++++++++++------------------------ hw/arm/exynos4_boards.c | 6 ++-- 3 files changed, 26 insertions(+), 46 deletions(-)