hw/sparc/leon3: Initialize GPIO before realizing CPU devices
Inline cpu_create() in order to call qdev_init_gpio_in_named() before the CPU is realized. Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Message-Id: <20240215144623.76233-4-philmd@linaro.org>
This commit is contained in:
parent
08507399ab
commit
0f0554c6fa
@ -277,7 +277,10 @@ static void leon3_generic_hw_init(MachineState *machine)
|
||||
|
||||
for (i = 0; i < machine->smp.cpus; i++) {
|
||||
/* Init CPU */
|
||||
cpu = SPARC_CPU(cpu_create(machine->cpu_type));
|
||||
cpu = SPARC_CPU(object_new(machine->cpu_type));
|
||||
qdev_init_gpio_in_named(DEVICE(cpu), leon3_start_cpu, "start_cpu", 1);
|
||||
qdev_init_gpio_in_named(DEVICE(cpu), leon3_set_pil_in, "pil", 1);
|
||||
qdev_realize(DEVICE(cpu), NULL, &error_fatal);
|
||||
env = &cpu->env;
|
||||
|
||||
cpu_sparc_set_id(env, i);
|
||||
@ -311,11 +314,9 @@ static void leon3_generic_hw_init(MachineState *machine)
|
||||
for (i = 0; i < machine->smp.cpus; i++) {
|
||||
cpu = reset_info->info[i].cpu;
|
||||
env = &cpu->env;
|
||||
qdev_init_gpio_in_named(DEVICE(cpu), leon3_start_cpu, "start_cpu", 1);
|
||||
qdev_connect_gpio_out_named(irqmpdev, "grlib-start-cpu", i,
|
||||
qdev_get_gpio_in_named(DEVICE(cpu),
|
||||
"start_cpu", 0));
|
||||
qdev_init_gpio_in_named(DEVICE(cpu), leon3_set_pil_in, "pil", 1);
|
||||
qdev_connect_gpio_out_named(irqmpdev, "grlib-irq", i,
|
||||
qdev_get_gpio_in_named(DEVICE(cpu),
|
||||
"pil", 0));
|
||||
|
Loading…
Reference in New Issue
Block a user