|
@@ -258,14 +258,23 @@ static void versal_create_gems(Versal *s, qemu_irq *pic)
|
|
char *name = g_strdup_printf("gem%d", i);
|
|
char *name = g_strdup_printf("gem%d", i);
|
|
DeviceState *dev;
|
|
DeviceState *dev;
|
|
MemoryRegion *mr;
|
|
MemoryRegion *mr;
|
|
|
|
+ OrIRQState *or_irq;
|
|
|
|
|
|
object_initialize_child(OBJECT(s), name, &s->lpd.iou.gem[i],
|
|
object_initialize_child(OBJECT(s), name, &s->lpd.iou.gem[i],
|
|
TYPE_CADENCE_GEM);
|
|
TYPE_CADENCE_GEM);
|
|
|
|
+ or_irq = &s->lpd.iou.gem_irq_orgate[i];
|
|
|
|
+ object_initialize_child(OBJECT(s), "gem-irq-orgate[*]",
|
|
|
|
+ or_irq, TYPE_OR_IRQ);
|
|
dev = DEVICE(&s->lpd.iou.gem[i]);
|
|
dev = DEVICE(&s->lpd.iou.gem[i]);
|
|
qemu_configure_nic_device(dev, true, NULL);
|
|
qemu_configure_nic_device(dev, true, NULL);
|
|
object_property_set_int(OBJECT(dev), "phy-addr", 23, &error_abort);
|
|
object_property_set_int(OBJECT(dev), "phy-addr", 23, &error_abort);
|
|
object_property_set_int(OBJECT(dev), "num-priority-queues", 2,
|
|
object_property_set_int(OBJECT(dev), "num-priority-queues", 2,
|
|
&error_abort);
|
|
&error_abort);
|
|
|
|
+ object_property_set_int(OBJECT(or_irq),
|
|
|
|
+ "num-lines", 2, &error_fatal);
|
|
|
|
+ qdev_realize(DEVICE(or_irq), NULL, &error_fatal);
|
|
|
|
+ qdev_connect_gpio_out(DEVICE(or_irq), 0, pic[irqs[i]]);
|
|
|
|
+
|
|
object_property_set_link(OBJECT(dev), "dma", OBJECT(&s->mr_ps),
|
|
object_property_set_link(OBJECT(dev), "dma", OBJECT(&s->mr_ps),
|
|
&error_abort);
|
|
&error_abort);
|
|
sysbus_realize(SYS_BUS_DEVICE(dev), &error_fatal);
|
|
sysbus_realize(SYS_BUS_DEVICE(dev), &error_fatal);
|
|
@@ -273,7 +282,8 @@ static void versal_create_gems(Versal *s, qemu_irq *pic)
|
|
mr = sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0);
|
|
mr = sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0);
|
|
memory_region_add_subregion(&s->mr_ps, addrs[i], mr);
|
|
memory_region_add_subregion(&s->mr_ps, addrs[i], mr);
|
|
|
|
|
|
- sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, pic[irqs[i]]);
|
|
|
|
|
|
+ sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, qdev_get_gpio_in(DEVICE(or_irq), 0));
|
|
|
|
+ sysbus_connect_irq(SYS_BUS_DEVICE(dev), 1, qdev_get_gpio_in(DEVICE(or_irq), 1));
|
|
g_free(name);
|
|
g_free(name);
|
|
}
|
|
}
|
|
}
|
|
}
|