mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-15 09:27:35 +00:00
8d3eaa9709
Newer qoriq socs have an updated dma ip block with a different compatible. Let's make sure we use the proper string so that the dmas get their liodn. In order to have the means to specify the compatible string, the liodn setting macros were updated to receive a new parameter for it. The following SoCs were changed to use the new compatible: T1023/4, T1040, T2080/1, T4240, B4860. Signed-off-by: Laurentiu Tudor <Laurentiu.Tudor@freescale.com> Reviewed-by: York Sun <yorksun@freescale.com>
113 lines
3 KiB
C
113 lines
3 KiB
C
/*
|
|
* Copyright 2011 Freescale Semiconductor, Inc.
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <asm/fsl_portals.h>
|
|
#include <asm/fsl_liodn.h>
|
|
|
|
#ifdef CONFIG_SYS_DPAA_QBMAN
|
|
struct qportal_info qp_info[CONFIG_SYS_QMAN_NUM_PORTALS] = {
|
|
/* dqrr liodn, frame data liodn, liodn off, sdest */
|
|
SET_QP_INFO(1, 2, 1, 0),
|
|
SET_QP_INFO(3, 4, 2, 1),
|
|
SET_QP_INFO(5, 6, 3, 2),
|
|
SET_QP_INFO(7, 8, 4, 3),
|
|
SET_QP_INFO(9, 10, 5, 0),
|
|
SET_QP_INFO(11, 12, 6, 1),
|
|
SET_QP_INFO(13, 14, 7, 2),
|
|
SET_QP_INFO(15, 16, 8, 3),
|
|
SET_QP_INFO(17, 18, 9, 0), /* for now sdest to 0 */
|
|
SET_QP_INFO(19, 20, 10, 0), /* for now sdest to 0 */
|
|
};
|
|
#endif
|
|
|
|
struct srio_liodn_id_table srio_liodn_tbl[] = {
|
|
SET_SRIO_LIODN_2(1, 199, 200),
|
|
SET_SRIO_LIODN_2(2, 201, 202),
|
|
};
|
|
int srio_liodn_tbl_sz = ARRAY_SIZE(srio_liodn_tbl);
|
|
|
|
struct liodn_id_table liodn_tbl[] = {
|
|
#ifdef CONFIG_SYS_DPAA_QBMAN
|
|
SET_QMAN_LIODN(31),
|
|
SET_BMAN_LIODN(32),
|
|
#endif
|
|
|
|
SET_SDHC_LIODN(1, 64),
|
|
|
|
SET_PME_LIODN(117),
|
|
|
|
SET_USB_LIODN(1, "fsl-usb2-mph", 125),
|
|
SET_USB_LIODN(2, "fsl-usb2-dr", 126),
|
|
|
|
SET_SATA_LIODN(1, 127),
|
|
SET_SATA_LIODN(2, 128),
|
|
|
|
SET_PCI_LIODN(CONFIG_SYS_FSL_PCIE_COMPAT, 1, 193),
|
|
SET_PCI_LIODN(CONFIG_SYS_FSL_PCIE_COMPAT, 2, 194),
|
|
SET_PCI_LIODN(CONFIG_SYS_FSL_PCIE_COMPAT, 3, 195),
|
|
|
|
SET_DMA_LIODN(1, "fsl,eloplus-dma", 197),
|
|
SET_DMA_LIODN(2, "fsl,eloplus-dma", 198),
|
|
|
|
SET_GUTS_LIODN("fsl,rapidio-delta", 199, rio1liodnr, 0),
|
|
SET_GUTS_LIODN(NULL, 200, rio2liodnr, 0),
|
|
SET_GUTS_LIODN(NULL, 201, rio1maintliodnr, 0),
|
|
SET_GUTS_LIODN(NULL, 202, rio2maintliodnr, 0),
|
|
};
|
|
int liodn_tbl_sz = ARRAY_SIZE(liodn_tbl);
|
|
|
|
#ifdef CONFIG_SYS_DPAA_FMAN
|
|
struct liodn_id_table fman1_liodn_tbl[] = {
|
|
SET_FMAN_RX_1G_LIODN(1, 0, 10),
|
|
SET_FMAN_RX_1G_LIODN(1, 1, 11),
|
|
SET_FMAN_RX_1G_LIODN(1, 2, 12),
|
|
SET_FMAN_RX_1G_LIODN(1, 3, 13),
|
|
SET_FMAN_RX_1G_LIODN(1, 4, 14),
|
|
#if (CONFIG_SYS_NUM_FM1_10GEC == 1)
|
|
SET_FMAN_RX_10G_LIODN(1, 0, 15),
|
|
#endif
|
|
};
|
|
int fman1_liodn_tbl_sz = ARRAY_SIZE(fman1_liodn_tbl);
|
|
#endif
|
|
|
|
struct liodn_id_table sec_liodn_tbl[] = {
|
|
SET_SEC_JR_LIODN_ENTRY(0, 129, 130),
|
|
SET_SEC_JR_LIODN_ENTRY(1, 131, 132),
|
|
SET_SEC_JR_LIODN_ENTRY(2, 133, 134),
|
|
SET_SEC_JR_LIODN_ENTRY(3, 135, 136),
|
|
SET_SEC_RTIC_LIODN_ENTRY(a, 154),
|
|
SET_SEC_RTIC_LIODN_ENTRY(b, 155),
|
|
SET_SEC_RTIC_LIODN_ENTRY(c, 156),
|
|
SET_SEC_RTIC_LIODN_ENTRY(d, 157),
|
|
SET_SEC_DECO_LIODN_ENTRY(0, 97, 98),
|
|
SET_SEC_DECO_LIODN_ENTRY(1, 99, 100),
|
|
};
|
|
int sec_liodn_tbl_sz = ARRAY_SIZE(sec_liodn_tbl);
|
|
|
|
#ifdef CONFIG_SYS_DPAA_RMAN
|
|
struct liodn_id_table rman_liodn_tbl[] = {
|
|
/* Set RMan block 0-3 liodn offset */
|
|
SET_RMAN_LIODN(0, 6),
|
|
SET_RMAN_LIODN(1, 7),
|
|
SET_RMAN_LIODN(2, 8),
|
|
SET_RMAN_LIODN(3, 9),
|
|
};
|
|
int rman_liodn_tbl_sz = ARRAY_SIZE(rman_liodn_tbl);
|
|
#endif
|
|
|
|
struct liodn_id_table liodn_bases[] = {
|
|
[FSL_HW_PORTAL_SEC] = SET_LIODN_BASE_2(64, 100),
|
|
#ifdef CONFIG_SYS_DPAA_FMAN
|
|
[FSL_HW_PORTAL_FMAN1] = SET_LIODN_BASE_1(32),
|
|
#endif
|
|
#ifdef CONFIG_SYS_DPAA_PME
|
|
[FSL_HW_PORTAL_PME] = SET_LIODN_BASE_2(136, 172),
|
|
#endif
|
|
#ifdef CONFIG_SYS_DPAA_RMAN
|
|
[FSL_HW_PORTAL_RMAN] = SET_LIODN_BASE_1(80),
|
|
#endif
|
|
};
|