mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-25 14:31:21 +02:00 
			
		
		
		
	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.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright 2010-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, 4),
 | |
| 	SET_QP_INFO(11, 12,  6, 5),
 | |
| 	SET_QP_INFO(13, 14,  7, 6),
 | |
| 	SET_QP_INFO(15, 16,  8, 7),
 | |
| 	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_1(1, 198),
 | |
| 	SET_SRIO_LIODN_1(2, 199),
 | |
| };
 | |
| int srio_liodn_tbl_sz = ARRAY_SIZE(srio_liodn_tbl);
 | |
| 
 | |
| struct liodn_id_table liodn_tbl[] = {
 | |
| 	SET_USB_LIODN(1, "fsl-usb2-mph", 127),
 | |
| 	SET_USB_LIODN(2, "fsl-usb2-dr", 157),
 | |
| 
 | |
| 	SET_SDHC_LIODN(1, 156),
 | |
| 
 | |
| 	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", 196),
 | |
| 	SET_DMA_LIODN(2, "fsl,eloplus-dma", 197),
 | |
| 
 | |
| 	SET_GUTS_LIODN("fsl,srio-rmu", 200, rmuliodnr, 0xd3000),
 | |
| 
 | |
| #ifdef CONFIG_SYS_DPAA_QBMAN
 | |
| 	SET_QMAN_LIODN(31),
 | |
| 	SET_BMAN_LIODN(32),
 | |
| #endif
 | |
| 	SET_PME_LIODN(128),
 | |
| };
 | |
| 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, 11),
 | |
| 	SET_FMAN_RX_1G_LIODN(1, 1, 12),
 | |
| 	SET_FMAN_RX_1G_LIODN(1, 2, 13),
 | |
| 	SET_FMAN_RX_1G_LIODN(1, 3, 14),
 | |
| 	SET_FMAN_RX_10G_LIODN(1, 0, 15),
 | |
| };
 | |
| int fman1_liodn_tbl_sz = ARRAY_SIZE(fman1_liodn_tbl);
 | |
| 
 | |
| #if (CONFIG_SYS_NUM_FMAN == 2)
 | |
| struct liodn_id_table fman2_liodn_tbl[] = {
 | |
| 	SET_FMAN_RX_1G_LIODN(2, 0, 16),
 | |
| 	SET_FMAN_RX_1G_LIODN(2, 1, 17),
 | |
| 	SET_FMAN_RX_1G_LIODN(2, 2, 18),
 | |
| 	SET_FMAN_RX_1G_LIODN(2, 3, 19),
 | |
| 	SET_FMAN_RX_10G_LIODN(2, 0, 20),
 | |
| };
 | |
| int fman2_liodn_tbl_sz = ARRAY_SIZE(fman2_liodn_tbl);
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| struct liodn_id_table sec_liodn_tbl[] = {
 | |
| 	/*
 | |
| 	 * We assume currently that all JR are in the same partition
 | |
| 	 * and as such they need to represent the same LIODN due to
 | |
| 	 * a 4080 rev.2 h/w requirement that DECOs sharing from themselves
 | |
| 	 * or from another DECO have the two Non-SEQ LIODN values equal
 | |
| 	 */
 | |
| 	SET_SEC_JR_LIODN_ENTRY(0, 146, 154), /* (0, 146, 154), */
 | |
| 	SET_SEC_JR_LIODN_ENTRY(1, 146, 154), /* (1, 147, 155), */
 | |
| 	SET_SEC_JR_LIODN_ENTRY(2, 146, 154), /* (2, 178, 186), */
 | |
| 	SET_SEC_JR_LIODN_ENTRY(3, 146, 154), /* (3, 179, 187), */
 | |
| 	SET_SEC_RTIC_LIODN_ENTRY(a, 144),
 | |
| 	SET_SEC_RTIC_LIODN_ENTRY(b, 145),
 | |
| 	SET_SEC_RTIC_LIODN_ENTRY(c, 176),
 | |
| 	SET_SEC_RTIC_LIODN_ENTRY(d, 177),
 | |
| 	SET_SEC_DECO_LIODN_ENTRY(0, 129, 161),
 | |
| 	SET_SEC_DECO_LIODN_ENTRY(1, 130, 162),
 | |
| 	SET_SEC_DECO_LIODN_ENTRY(2, 131, 163),
 | |
| 	SET_SEC_DECO_LIODN_ENTRY(3, 132, 164),
 | |
| 	SET_SEC_DECO_LIODN_ENTRY(4, 133, 165),
 | |
| };
 | |
| int sec_liodn_tbl_sz = ARRAY_SIZE(sec_liodn_tbl);
 | |
| 
 | |
| struct liodn_id_table liodn_bases[] = {
 | |
| 	[FSL_HW_PORTAL_SEC]  = SET_LIODN_BASE_2(96, 106),
 | |
| #ifdef CONFIG_SYS_DPAA_FMAN
 | |
| 	[FSL_HW_PORTAL_FMAN1] = SET_LIODN_BASE_1(32),
 | |
| #if (CONFIG_SYS_NUM_FMAN == 2)
 | |
| 	[FSL_HW_PORTAL_FMAN2] = SET_LIODN_BASE_1(64),
 | |
| #endif
 | |
| #endif
 | |
| #ifdef CONFIG_SYS_DPAA_PME
 | |
| 	[FSL_HW_PORTAL_PME]   = SET_LIODN_BASE_2(116, 133),
 | |
| #endif
 | |
| };
 |