Skip to content

Commit

Permalink
xlnx-zynqmp: Connect the IPI device to the ZynqMP SoC
Browse files Browse the repository at this point in the history
Signed-off-by: Alistair Francis <[email protected]>
Reviewed-by: Edgar E. Iglesias <[email protected]>
Reviewed-by: Philippe Mathieu-Daudé <[email protected]>
Signed-off-by: Edgar E. Iglesias <[email protected]>
  • Loading branch information
alistair23 authored and edgarigl committed Jan 26, 2018
1 parent 07b3020 commit 0ab7bbc
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 0 deletions.
14 changes: 14 additions & 0 deletions hw/arm/xlnx-zynqmp.c
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,9 @@
#define DPDMA_ADDR 0xfd4c0000
#define DPDMA_IRQ 116

#define IPI_ADDR 0xFF300000
#define IPI_IRQ 64

static const uint64_t gem_addr[XLNX_ZYNQMP_NUM_GEMS] = {
0xFF0B0000, 0xFF0C0000, 0xFF0D0000, 0xFF0E0000,
};
Expand Down Expand Up @@ -183,6 +186,9 @@ static void xlnx_zynqmp_init(Object *obj)

object_initialize(&s->dpdma, sizeof(s->dpdma), TYPE_XLNX_DPDMA);
qdev_set_parent_bus(DEVICE(&s->dpdma), sysbus_get_default());

object_initialize(&s->ipi, sizeof(s->ipi), TYPE_XLNX_ZYNQMP_IPI);
qdev_set_parent_bus(DEVICE(&s->ipi), sysbus_get_default());
}

static void xlnx_zynqmp_realize(DeviceState *dev, Error **errp)
Expand Down Expand Up @@ -454,6 +460,14 @@ static void xlnx_zynqmp_realize(DeviceState *dev, Error **errp)
&error_abort);
sysbus_mmio_map(SYS_BUS_DEVICE(&s->dpdma), 0, DPDMA_ADDR);
sysbus_connect_irq(SYS_BUS_DEVICE(&s->dpdma), 0, gic_spi[DPDMA_IRQ]);

object_property_set_bool(OBJECT(&s->ipi), true, "realized", &err);
if (err) {
error_propagate(errp, err);
return;
}
sysbus_mmio_map(SYS_BUS_DEVICE(&s->ipi), 0, IPI_ADDR);
sysbus_connect_irq(SYS_BUS_DEVICE(&s->ipi), 0, gic_spi[IPI_IRQ]);
}

static Property xlnx_zynqmp_props[] = {
Expand Down
2 changes: 2 additions & 0 deletions include/hw/arm/xlnx-zynqmp.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
#include "hw/ssi/xilinx_spips.h"
#include "hw/dma/xlnx_dpdma.h"
#include "hw/display/xlnx_dp.h"
#include "hw/intc/xlnx-zynqmp-ipi.h"

#define TYPE_XLNX_ZYNQMP "xlnx,zynqmp"
#define XLNX_ZYNQMP(obj) OBJECT_CHECK(XlnxZynqMPState, (obj), \
Expand Down Expand Up @@ -90,6 +91,7 @@ typedef struct XlnxZynqMPState {
XlnxZynqMPQSPIPS qspi;
XlnxDPState dp;
XlnxDPDMAState dpdma;
XlnxZynqMPIPI ipi;

char *boot_cpu;
ARMCPU *boot_cpu_ptr;
Expand Down

0 comments on commit 0ab7bbc

Please sign in to comment.