[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v2 1/1] xlnx-zynqmp: Connect the four OCM banks
From: |
Alistair Francis |
Subject: |
Re: [Qemu-devel] [PATCH v2 1/1] xlnx-zynqmp: Connect the four OCM banks |
Date: |
Fri, 14 Aug 2015 10:10:52 -0700 |
On Mon, Jul 13, 2015 at 1:56 PM, Alistair Francis
<address@hidden> wrote:
> On Mon, Jul 13, 2015 at 12:48 PM, Peter Crosthwaite
> <address@hidden> wrote:
>> On Mon, Jul 13, 2015 at 11:54 AM, Alistair Francis
>> <address@hidden> wrote:
>>> The Xilinx EP108 has four separate OCM banks which are located
>>> adjacent to each other. This patch adds the four banks to
>>> the ZynqMP SoC.
>>>
>>> Signed-off-by: Alistair Francis <address@hidden>
>>
>> Reviewed-by: Peter Crosthwaite <address@hidden>
Hello Peter Maydell,
Can this be added to your pull queue?
Thanks,
Alistair
>
> Thanks Peter,
>
> I guess this will have to wait until the next window to be accepted right?
>
> Thanks,
>
> Alistair
>
>>
>>> ---
>>> V2:
>>> - Localise ocm_name
>>> - Use g_strdup_printf()
>>>
>>> hw/arm/xlnx-zynqmp.c | 15 +++++++++++++++
>>> include/hw/arm/xlnx-zynqmp.h | 6 ++++++
>>> 2 files changed, 21 insertions(+), 0 deletions(-)
>>>
>>> diff --git a/hw/arm/xlnx-zynqmp.c b/hw/arm/xlnx-zynqmp.c
>>> index 5e72078..235d8b6 100644
>>> --- a/hw/arm/xlnx-zynqmp.c
>>> +++ b/hw/arm/xlnx-zynqmp.c
>>> @@ -101,6 +101,21 @@ static void xlnx_zynqmp_realize(DeviceState *dev,
>>> Error **errp)
>>> qemu_irq gic_spi[GIC_NUM_SPI_INTR];
>>> Error *err = NULL;
>>>
>>> + /* Create the four OCM banks */
>>> + for (i = 0; i < XLNX_ZYNQMP_NUM_OCM_BANKS; i++) {
>>> + char *ocm_name = g_strdup_printf("zynqmp.ocm_ram_bank_%d", i);
>>> +
>>> + memory_region_init_ram(&s->ocm_ram[i], NULL, ocm_name,
>>> + XLNX_ZYNQMP_OCM_RAM_SIZE, &error_abort);
>>> + vmstate_register_ram_global(&s->ocm_ram[i]);
>>> + memory_region_add_subregion(get_system_memory(),
>>> + XLNX_ZYNQMP_OCM_RAM_0_ADDRESS +
>>> + i * XLNX_ZYNQMP_OCM_RAM_SIZE,
>>> + &s->ocm_ram[i]);
>>> +
>>> + g_free(ocm_name);
>>> + }
>>> +
>>> qdev_prop_set_uint32(DEVICE(&s->gic), "num-irq", GIC_NUM_SPI_INTR +
>>> 32);
>>> qdev_prop_set_uint32(DEVICE(&s->gic), "revision", 2);
>>> qdev_prop_set_uint32(DEVICE(&s->gic), "num-cpu",
>>> XLNX_ZYNQMP_NUM_APU_CPUS);
>>> diff --git a/include/hw/arm/xlnx-zynqmp.h b/include/hw/arm/xlnx-zynqmp.h
>>> index c379632..6ccb57b 100644
>>> --- a/include/hw/arm/xlnx-zynqmp.h
>>> +++ b/include/hw/arm/xlnx-zynqmp.h
>>> @@ -32,6 +32,10 @@
>>> #define XLNX_ZYNQMP_NUM_GEMS 4
>>> #define XLNX_ZYNQMP_NUM_UARTS 2
>>>
>>> +#define XLNX_ZYNQMP_NUM_OCM_BANKS 4
>>> +#define XLNX_ZYNQMP_OCM_RAM_0_ADDRESS 0xFFFC0000
>>> +#define XLNX_ZYNQMP_OCM_RAM_SIZE 0x10000
>>> +
>>> #define XLNX_ZYNQMP_GIC_REGIONS 2
>>>
>>> /* ZynqMP maps the ARM GIC regions (GICC, GICD ...) at consecutive 64k
>>> offsets
>>> @@ -52,6 +56,8 @@ typedef struct XlnxZynqMPState {
>>> ARMCPU rpu_cpu[XLNX_ZYNQMP_NUM_RPU_CPUS];
>>> GICState gic;
>>> MemoryRegion gic_mr[XLNX_ZYNQMP_GIC_REGIONS][XLNX_ZYNQMP_GIC_ALIASES];
>>> + MemoryRegion ocm_ram[XLNX_ZYNQMP_NUM_OCM_BANKS];
>>> +
>>> CadenceGEMState gem[XLNX_ZYNQMP_NUM_GEMS];
>>> CadenceUARTState uart[XLNX_ZYNQMP_NUM_UARTS];
>>>
>>> --
>>> 1.7.1
>>>
>>>
>>
- Re: [Qemu-devel] [PATCH v2 1/1] xlnx-zynqmp: Connect the four OCM banks,
Alistair Francis <=