mirror of https://github.com/xqemu/xqemu.git
qdev: gpio: Register GPIO inputs as child objects
To the device that contains them. This will allow for referencing a GPIO input from it's canonical path (exciting for dynamic machine generation!) Reviewed-by: Alexander Graf <agraf@suse.de> Signed-off-by: Peter Crosthwaite <peter.crosthwaite@xilinx.com> Signed-off-by: Andreas Färber <afaerber@suse.de>
This commit is contained in:
parent
b235a71f52
commit
a69bef1cf1
|
@ -337,11 +337,20 @@ static NamedGPIOList *qdev_get_named_gpio_list(DeviceState *dev,
|
||||||
void qdev_init_gpio_in_named(DeviceState *dev, qemu_irq_handler handler,
|
void qdev_init_gpio_in_named(DeviceState *dev, qemu_irq_handler handler,
|
||||||
const char *name, int n)
|
const char *name, int n)
|
||||||
{
|
{
|
||||||
|
int i;
|
||||||
NamedGPIOList *gpio_list = qdev_get_named_gpio_list(dev, name);
|
NamedGPIOList *gpio_list = qdev_get_named_gpio_list(dev, name);
|
||||||
|
char *propname = g_strdup_printf("%s[*]", name ? name : "unnamed-gpio-in");
|
||||||
|
|
||||||
assert(gpio_list->num_out == 0 || !name);
|
assert(gpio_list->num_out == 0 || !name);
|
||||||
gpio_list->in = qemu_extend_irqs(gpio_list->in, gpio_list->num_in, handler,
|
gpio_list->in = qemu_extend_irqs(gpio_list->in, gpio_list->num_in, handler,
|
||||||
dev, n);
|
dev, n);
|
||||||
|
|
||||||
|
for (i = gpio_list->num_in; i < gpio_list->num_in + n; i++) {
|
||||||
|
object_property_add_child(OBJECT(dev), propname,
|
||||||
|
OBJECT(gpio_list->in[i]), &error_abort);
|
||||||
|
}
|
||||||
|
g_free(propname);
|
||||||
|
|
||||||
gpio_list->num_in += n;
|
gpio_list->num_in += n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue