> -----Original Message-----
> From: laurentiu.tu...@nxp.com [mailto:laurentiu.tu...@nxp.com]
> Sent: Tuesday, July 31, 2018 8:22 PM
> To: u-boot@lists.denx.de; Prabhakar Kushwaha
> <prabhakar.kushw...@nxp.com>; York Sun <york....@nxp.com>
> Cc: Bharat Bhushan <bharat.bhus...@nxp.com>; Horia Geanta
> <horia.gea...@nxp.com>; Laurentiu Tudor <laurentiu.tu...@nxp.com>
> Subject: [PATCH v6 6/8] armv8: ls1046a: add icid setup for qman portals
> 
> From: Laurentiu Tudor <laurentiu.tu...@nxp.com>
> 
> Add support for ICID setting of qman portals and the required device
> tree fixups. Also fix an endiness issue in portal setup code.
> 
> Signed-off-by: Laurentiu Tudor <laurentiu.tu...@nxp.com>

Reviewed-by: Bharat Bhushan <bharat.bhus...@nxp.com>

Thanks
-Bharat

> ---
>  .../arm/cpu/armv8/fsl-layerscape/ls1046_ids.c | 16 +++++++
>  .../asm/arch-fsl-layerscape/fsl_portals.h     | 24 +++++++++++
>  drivers/misc/fsl_portals.c                    | 43 +++++++++++++++----
>  3 files changed, 75 insertions(+), 8 deletions(-)
>  create mode 100644 arch/arm/include/asm/arch-fsl-layerscape/fsl_portals.h
> 
> diff --git a/arch/arm/cpu/armv8/fsl-layerscape/ls1046_ids.c
> b/arch/arm/cpu/armv8/fsl-layerscape/ls1046_ids.c
> index 1c528ab751..80e1ceadc0 100644
> --- a/arch/arm/cpu/armv8/fsl-layerscape/ls1046_ids.c
> +++ b/arch/arm/cpu/armv8/fsl-layerscape/ls1046_ids.c
> @@ -6,6 +6,22 @@
>  #include <common.h>
>  #include <asm/arch-fsl-layerscape/immap_lsch2.h>
>  #include <asm/arch-fsl-layerscape/fsl_icid.h>
> +#include <asm/arch-fsl-layerscape/fsl_portals.h>
> +
> +#ifdef CONFIG_SYS_DPAA_QBMAN
> +struct qportal_info qp_info[CONFIG_SYS_QMAN_NUM_PORTALS] = {
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +     SET_QP_INFO(FSL_DPAA1_STREAM_ID_END, 0),
> +};
> +#endif
> 
>  struct icid_id_table icid_tbl[] = {
>  #ifdef CONFIG_SYS_DPAA_QBMAN
> diff --git a/arch/arm/include/asm/arch-fsl-layerscape/fsl_portals.h
> b/arch/arm/include/asm/arch-fsl-layerscape/fsl_portals.h
> new file mode 100644
> index 0000000000..1577e935a6
> --- /dev/null
> +++ b/arch/arm/include/asm/arch-fsl-layerscape/fsl_portals.h
> @@ -0,0 +1,24 @@
> +/* SPDX-License-Identifier: GPL-2.0+ */
> +/*
> + * Copyright 2018 NXP
> + */
> +
> +#ifndef _FSL_PORTALS_H_
> +#define _FSL_PORTALS_H_
> +
> +struct qportal_info {
> +     u16     dicid;  /* DQRR ICID */
> +     u16     ficid;  /* frame data ICID */
> +     u16     icid;
> +     u8      sdest;
> +};
> +
> +#define SET_QP_INFO(streamid, dest) \
> +     { .dicid = (streamid), .ficid = (streamid), .icid = (streamid), \
> +     .sdest = (dest) }
> +
> +extern struct qportal_info qp_info[];
> +void fdt_portal(void *blob, const char *compat, const char *container,
> +             u64 addr, u32 size);
> +
> +#endif
> diff --git a/drivers/misc/fsl_portals.c b/drivers/misc/fsl_portals.c
> index 22faf16751..a524510707 100644
> --- a/drivers/misc/fsl_portals.c
> +++ b/drivers/misc/fsl_portals.c
> @@ -13,6 +13,9 @@
>  #ifdef CONFIG_PPC
>  #include <asm/fsl_portals.h>
>  #include <asm/fsl_liodn.h>
> +#else
> +#include <asm/arch-fsl-layerscape/fsl_portals.h>
> +#include <asm/arch-fsl-layerscape/fsl_icid.h>
>  #endif
>  #include <fsl_qbman.h>
> 
> @@ -45,6 +48,22 @@ void setup_qbman_portals(void)
>               /* set frame liodn */
>               out_be32(&qman->qcsp[i].qcsp_io_cfg, (sdest << 16) |
> fliodn);
>       }
> +#else
> +#ifdef CONFIG_ARM
> +     int i;
> +
> +     for (i = 0; i < CONFIG_SYS_QMAN_NUM_PORTALS; i++) {
> +             u8 sdest = qp_info[i].sdest;
> +             u16 ficid = qp_info[i].ficid;
> +             u16 dicid = qp_info[i].dicid;
> +             u16 icid = qp_info[i].icid;
> +
> +             out_be32(&qman->qcsp[i].qcsp_lio_cfg, (icid << 16) |
> +                                     dicid);
> +             /* set frame icid */
> +             out_be32(&qman->qcsp[i].qcsp_io_cfg, (sdest << 16) | ficid);
> +     }
> +#endif
>  #endif
> 
>       /* Change default state of BMan ISDR portals to all 1s */
> @@ -178,6 +197,10 @@ void fdt_fixup_qportals(void *blob)
>       char compat[64];
>       int compat_len;
> 
> +#ifndef CONFIG_PPC
> +     int smmu_ph = fdt_get_smmu_phandle(blob);
> +#endif
> +
>       maj = (rev_1 >> 8) & 0xff;
>       min = rev_1 & 0xff;
>       ip_cfg = rev_2 & 0xff;
> @@ -188,7 +211,6 @@ void fdt_fixup_qportals(void *blob)
> 
>       off = fdt_node_offset_by_compatible(blob, -1, "fsl,qman-portal");
>       while (off != -FDT_ERR_NOTFOUND) {
> -#ifdef CONFIG_PPC
>  #ifdef CONFIG_FSL_CORENET
>               u32 liodns[2];
>  #endif
> @@ -198,12 +220,7 @@ void fdt_fixup_qportals(void *blob)
>               if (!ci)
>                       goto err;
> 
> -             i = *ci;
> -#ifdef CONFIG_SYS_DPAA_FMAN
> -             int j;
> -#endif
> -
> -#endif /* CONFIG_PPC */
> +             i = fdt32_to_cpu(*ci);
>               err = fdt_setprop(blob, off, "compatible", compat,
> compat_len);
>               if (err < 0)
>                       goto err;
> @@ -235,7 +252,7 @@ void fdt_fixup_qportals(void *blob)
>  #endif
> 
>  #ifdef CONFIG_SYS_DPAA_FMAN
> -             for (j = 0; j < CONFIG_SYS_NUM_FMAN; j++) {
> +             for (int j = 0; j < CONFIG_SYS_NUM_FMAN; j++) {
>                       char name[] = "fman@0";
> 
>                       name[sizeof(name) - 2] = '0' + j;
> @@ -251,6 +268,16 @@ void fdt_fixup_qportals(void *blob)
>               if (err < 0)
>                       goto err;
>  #endif
> +#else
> +             if (smmu_ph >= 0) {
> +                     u32 icids[3];
> +
> +                     icids[0] = qp_info[i].icid;
> +                     icids[1] = qp_info[i].dicid;
> +                     icids[2] = qp_info[i].ficid;
> +
> +                     fdt_set_iommu_prop(blob, off, smmu_ph, icids, 3);
> +             }
>  #endif /* CONFIG_PPC */
> 
>  err:
> --
> 2.17.1

_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot

Reply via email to