qemu-discuss
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

How 'qdev_realize_and_unref' work?


From: Zongyuan Li
Subject: How 'qdev_realize_and_unref' work?
Date: Tue, 22 Mar 2022 20:27:46 +0800

I recently read the following code in hw/openrisc/openrisc_sim.c:

>  if (num_cpus > 1) {
>        DeviceState *splitter = qdev_new(TYPE_SPLIT_IRQ);
>        qdev_prop_set_uint32(splitter, "num-lines", num_cpus);
>        qdev_realize_and_unref(splitter, NULL, &error_fatal);
>        for (i = 0; i < num_cpus; i++) {
>            qdev_connect_gpio_out(splitter, i, get_cpu_irq(cpus, i, irq_pin));
>        }
>        serial_irq = qdev_get_gpio_in(splitter, 0);
>    } else {
>        serial_irq = get_cpu_irq(cpus, 0, irq_pin);
>    }

'splitter' will be used after 'qdev_realize_and_unref', which will
drop the only reference it takes.
But since the memory will be freed, it seems illegal to use
'splitter'. Can anyone explain if I am missing something?

Thanks a lot,
Li



reply via email to

[Prev in Thread] Current Thread [Next in Thread]