On Wed, Jul 16, 2025 at 11:54:01AM +0200, Luc Michel wrote:
> Refactor the CRL device creation using the VersalMap structure. The
> connections to the RPU CPUs are temporarily removed and will be
> reintroduced with next refactoring commits.
>
> Signed-off-by: Luc Michel <luc.michel@amd.com>
Reviewed-by: Francisco Iglesias <francisco.iglesias@amd.com>
> ---
> include/hw/arm/xlnx-versal.h | 3 ---
> hw/arm/xlnx-versal.c | 36 +++++++++++++++++++-----------------
> 2 files changed, 19 insertions(+), 20 deletions(-)
>
> diff --git a/include/hw/arm/xlnx-versal.h b/include/hw/arm/xlnx-versal.h
> index 5a685aea6d4..d3ce13e69de 100644
> --- a/include/hw/arm/xlnx-versal.h
> +++ b/include/hw/arm/xlnx-versal.h
> @@ -15,11 +15,10 @@
>
> #include "hw/sysbus.h"
> #include "hw/cpu/cluster.h"
> #include "hw/intc/arm_gicv3.h"
> #include "qom/object.h"
> -#include "hw/misc/xlnx-versal-crl.h"
> #include "net/can_emu.h"
> #include "target/arm/cpu.h"
> #include "hw/arm/xlnx-versal-version.h"
>
> #define TYPE_XLNX_VERSAL_BASE "xlnx-versal-base"
> @@ -69,12 +68,10 @@ struct Versal {
> MemoryRegion mr_ps_alias;
>
> CPUClusterState cluster;
> ARMCPU cpu[XLNX_VERSAL_NR_RCPUS];
> } rpu;
> -
> - XlnxVersalCRL crl;
> } lpd;
>
> struct {
> uint32_t clk_25mhz;
> uint32_t clk_125mhz;
> diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
> index 2128dbbad92..ff55ec62301 100644
> --- a/hw/arm/xlnx-versal.c
> +++ b/hw/arm/xlnx-versal.c
> @@ -40,10 +40,11 @@
> #include "hw/misc/xlnx-versal-trng.h"
> #include "hw/rtc/xlnx-zynqmp-rtc.h"
> #include "hw/misc/xlnx-versal-cfu.h"
> #include "hw/misc/xlnx-versal-cframe-reg.h"
> #include "hw/or-irq.h"
> +#include "hw/misc/xlnx-versal-crl.h"
>
> #define XLNX_VERSAL_ACPU_TYPE ARM_CPU_TYPE_NAME("cortex-a72")
> #define XLNX_VERSAL_RCPU_TYPE ARM_CPU_TYPE_NAME("cortex-r5f")
> #define GEM_REVISION 0x40070106
>
> @@ -149,10 +150,12 @@ typedef struct VersalMap {
> size_t num_cframe;
> struct VersalCfuCframeCfg {
> uint32_t blktype_frames[7];
> } cframe_cfg[15];
> } cfu;
> +
> + VersalSimplePeriphMap crl;
> } VersalMap;
>
> static const VersalMap VERSAL_MAP = {
> .uart[0] = { 0xff000000, 18 },
> .uart[1] = { 0xff010000, 19 },
> @@ -213,10 +216,12 @@ static const VersalMap VERSAL_MAP = {
> { { 38498, 3841, 15361, 13, 7, 3, 1 } },
> { { 38498, 3841, 15361, 13, 7, 3, 1 } },
> { { 38498, 3841, 15361, 13, 7, 3, 1 } },
> },
> },
> +
> + .crl = { 0xff5e0000, 10 },
> };
>
> static const VersalMap *VERSION_TO_MAP[] = {
> [VERSAL_VER_VERSAL] = &VERSAL_MAP,
> };
> @@ -1106,31 +1111,28 @@ static void versal_create_cfu(Versal *s, const struct VersalCfuMap *map)
> sysbus_realize_and_unref(sbd, &error_fatal);
> memory_region_add_subregion(&s->mr_ps, map->cfu_sfr,
> sysbus_mmio_get_region(sbd, 0));
> }
>
> -static void versal_create_crl(Versal *s, qemu_irq *pic)
> +static inline void versal_create_crl(Versal *s)
> {
> - SysBusDevice *sbd;
> - int i;
> + const VersalMap *map;
> + const char *crl_class;
> + DeviceState *dev;
>
> - object_initialize_child(OBJECT(s), "crl", &s->lpd.crl,
> - TYPE_XLNX_VERSAL_CRL);
> - sbd = SYS_BUS_DEVICE(&s->lpd.crl);
> + map = versal_get_map(s);
>
> - for (i = 0; i < ARRAY_SIZE(s->lpd.rpu.cpu); i++) {
> - g_autofree gchar *name = g_strdup_printf("cpu_r5[%d]", i);
> + crl_class = TYPE_XLNX_VERSAL_CRL;
> + dev = qdev_new(crl_class);
> + object_property_add_child(OBJECT(s), "crl", OBJECT(dev));
>
> - object_property_set_link(OBJECT(&s->lpd.crl),
> - name, OBJECT(&s->lpd.rpu.cpu[i]),
> - &error_abort);
> - }
> + sysbus_realize_and_unref(SYS_BUS_DEVICE(dev), &error_abort);
>
> - sysbus_realize(sbd, &error_fatal);
> - memory_region_add_subregion(&s->mr_ps, MM_CRL,
> - sysbus_mmio_get_region(sbd, 0));
> - sysbus_connect_irq(sbd, 0, pic[VERSAL_CRL_IRQ]);
> + memory_region_add_subregion(&s->mr_ps, map->crl.addr,
> + sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0));
> +
> + versal_sysbus_connect_irq(s, SYS_BUS_DEVICE(dev), 0, map->crl.irq);
> }
>
> /* This takes the board allocated linear DDR memory and creates aliases
> * for each split DDR range/aperture on the Versal address map.
> */
> @@ -1327,12 +1329,12 @@ static void versal_realize(DeviceState *dev, Error **errp)
>
> versal_create_bbram(s, &map->bbram);
> versal_create_trng(s, &map->trng);
> versal_create_rtc(s, &map->rtc);
> versal_create_cfu(s, &map->cfu);
> + versal_create_crl(s);
>
> - versal_create_crl(s, pic);
> versal_map_ddr(s);
> versal_unimp(s);
>
> /* Create the On Chip Memory (OCM). */
> memory_region_init_ram(&s->lpd.mr_ocm, OBJECT(s), "ocm",
> --
> 2.50.0
>