1*aa1a8ff2SEmmanuel Vadot /* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */ 2*aa1a8ff2SEmmanuel Vadot /* 3*aa1a8ff2SEmmanuel Vadot * Copyright (c) 2022 MediaTek Inc. 4*aa1a8ff2SEmmanuel Vadot * Author: Chengci Xu <chengci.xu@mediatek.com> 5*aa1a8ff2SEmmanuel Vadot */ 6*aa1a8ff2SEmmanuel Vadot #ifndef _DT_BINDINGS_MEMORY_MEDIATEK_MT8188_LARB_PORT_H_ 7*aa1a8ff2SEmmanuel Vadot #define _DT_BINDINGS_MEMORY_MEDIATEK_MT8188_LARB_PORT_H_ 8*aa1a8ff2SEmmanuel Vadot 9*aa1a8ff2SEmmanuel Vadot #include <dt-bindings/memory/mtk-memory-port.h> 10*aa1a8ff2SEmmanuel Vadot 11*aa1a8ff2SEmmanuel Vadot /* 12*aa1a8ff2SEmmanuel Vadot * MM IOMMU larbs: 13*aa1a8ff2SEmmanuel Vadot * From below, for example larb11 has larb11a/larb11b/larb11c, 14*aa1a8ff2SEmmanuel Vadot * the index of larb is not in order. So we reindexed these larbs from a 15*aa1a8ff2SEmmanuel Vadot * software view. 16*aa1a8ff2SEmmanuel Vadot */ 17*aa1a8ff2SEmmanuel Vadot #define SMI_L0_ID 0 18*aa1a8ff2SEmmanuel Vadot #define SMI_L1_ID 1 19*aa1a8ff2SEmmanuel Vadot #define SMI_L2_ID 2 20*aa1a8ff2SEmmanuel Vadot #define SMI_L3_ID 3 21*aa1a8ff2SEmmanuel Vadot #define SMI_L4_ID 4 22*aa1a8ff2SEmmanuel Vadot #define SMI_L5_ID 5 23*aa1a8ff2SEmmanuel Vadot #define SMI_L6_ID 6 24*aa1a8ff2SEmmanuel Vadot #define SMI_L7_ID 7 25*aa1a8ff2SEmmanuel Vadot #define SMI_L9_ID 8 26*aa1a8ff2SEmmanuel Vadot #define SMI_L10_ID 9 27*aa1a8ff2SEmmanuel Vadot #define SMI_L11A_ID 10 28*aa1a8ff2SEmmanuel Vadot #define SMI_L11B_ID 11 29*aa1a8ff2SEmmanuel Vadot #define SMI_L11C_ID 12 30*aa1a8ff2SEmmanuel Vadot #define SMI_L12_ID 13 31*aa1a8ff2SEmmanuel Vadot #define SMI_L13_ID 14 32*aa1a8ff2SEmmanuel Vadot #define SMI_L14_ID 15 33*aa1a8ff2SEmmanuel Vadot #define SMI_L15_ID 16 34*aa1a8ff2SEmmanuel Vadot #define SMI_L16A_ID 17 35*aa1a8ff2SEmmanuel Vadot #define SMI_L16B_ID 18 36*aa1a8ff2SEmmanuel Vadot #define SMI_L17A_ID 19 37*aa1a8ff2SEmmanuel Vadot #define SMI_L17B_ID 20 38*aa1a8ff2SEmmanuel Vadot #define SMI_L19_ID 21 39*aa1a8ff2SEmmanuel Vadot #define SMI_L21_ID 22 40*aa1a8ff2SEmmanuel Vadot #define SMI_L23_ID 23 41*aa1a8ff2SEmmanuel Vadot #define SMI_L27_ID 24 42*aa1a8ff2SEmmanuel Vadot #define SMI_L28_ID 25 43*aa1a8ff2SEmmanuel Vadot 44*aa1a8ff2SEmmanuel Vadot /* 45*aa1a8ff2SEmmanuel Vadot * MM IOMMU supports 16GB dma address. We separate it to four ranges: 46*aa1a8ff2SEmmanuel Vadot * 0 ~ 4G; 4G ~ 8G; 8G ~ 12G; 12G ~ 16G, we could adjust these masters 47*aa1a8ff2SEmmanuel Vadot * locate in anyone region. BUT: 48*aa1a8ff2SEmmanuel Vadot * a) Make sure all the ports inside a larb are in one range. 49*aa1a8ff2SEmmanuel Vadot * b) The iova of any master can NOT cross the 4G/8G/12G boundary. 50*aa1a8ff2SEmmanuel Vadot * 51*aa1a8ff2SEmmanuel Vadot * This is the suggested mapping in this SoC: 52*aa1a8ff2SEmmanuel Vadot * 53*aa1a8ff2SEmmanuel Vadot * modules dma-address-region larbs-ports 54*aa1a8ff2SEmmanuel Vadot * disp 0 ~ 4G larb0/1/2/3 55*aa1a8ff2SEmmanuel Vadot * vcodec 4G ~ 8G larb19(21)[1]/21(22)/23 56*aa1a8ff2SEmmanuel Vadot * cam/mdp 8G ~ 12G the other larbs. 57*aa1a8ff2SEmmanuel Vadot * N/A 12G ~ 16G 58*aa1a8ff2SEmmanuel Vadot * CCU0 0x24000_0000 ~ 0x243ff_ffff larb27(24): port 0/1 59*aa1a8ff2SEmmanuel Vadot * CCU1 0x24400_0000 ~ 0x247ff_ffff larb27(24): port 2/3 60*aa1a8ff2SEmmanuel Vadot * 61*aa1a8ff2SEmmanuel Vadot * This SoC have two MM IOMMU HWs, this is the connected information: 62*aa1a8ff2SEmmanuel Vadot * iommu-vdo: larb0/2/5/9/10/11A/11C/13/16B/17B/19/21 63*aa1a8ff2SEmmanuel Vadot * iommu-vpp: larb1/3/4/6/7/11B/12/14/15/16A/17A/23/27 64*aa1a8ff2SEmmanuel Vadot * 65*aa1a8ff2SEmmanuel Vadot * [1]: This is larb19, but the index is 21 from the SW view. 66*aa1a8ff2SEmmanuel Vadot */ 67*aa1a8ff2SEmmanuel Vadot 68*aa1a8ff2SEmmanuel Vadot /* MM IOMMU ports */ 69*aa1a8ff2SEmmanuel Vadot /* LARB 0 -- VDO-0 */ 70*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L0_DISP_RDMA1 MTK_M4U_ID(SMI_L0_ID, 0) 71*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L0_DISP_WDMA0 MTK_M4U_ID(SMI_L0_ID, 1) 72*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L0_DISP_OVL0_RDMA0 MTK_M4U_ID(SMI_L0_ID, 2) 73*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L0_DISP_OVL0_RDMA1 MTK_M4U_ID(SMI_L0_ID, 3) 74*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L0_DISP_OVL0_HDR MTK_M4U_ID(SMI_L0_ID, 4) 75*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L0_DISP_POSTMASK0 MTK_M4U_ID(SMI_L0_ID, 5) 76*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L0_DISP_FAKE_ENG0 MTK_M4U_ID(SMI_L0_ID, 6) 77*aa1a8ff2SEmmanuel Vadot 78*aa1a8ff2SEmmanuel Vadot /* LARB 1 -- VD0-0 */ 79*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L1_DISP_RDMA0 MTK_M4U_ID(SMI_L1_ID, 0) 80*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L1_DISP_WDMA1 MTK_M4U_ID(SMI_L1_ID, 1) 81*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L1_DISP_OVL1_RDMA0 MTK_M4U_ID(SMI_L1_ID, 2) 82*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L1_DISP_OVL1_RDMA1 MTK_M4U_ID(SMI_L1_ID, 3) 83*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L1_DISP_OVL1_HDR MTK_M4U_ID(SMI_L1_ID, 4) 84*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L1_DISP_WROT0 MTK_M4U_ID(SMI_L1_ID, 5) 85*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L1_DISP_FAKE_ENG1 MTK_M4U_ID(SMI_L1_ID, 6) 86*aa1a8ff2SEmmanuel Vadot 87*aa1a8ff2SEmmanuel Vadot /* LARB 2 -- VDO-1 */ 88*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L2_MDP_RDMA0 MTK_M4U_ID(SMI_L2_ID, 0) 89*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L2_MDP_RDMA2 MTK_M4U_ID(SMI_L2_ID, 1) 90*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L2_MDP_RDMA4 MTK_M4U_ID(SMI_L2_ID, 2) 91*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L2_MDP_RDMA6 MTK_M4U_ID(SMI_L2_ID, 3) 92*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L2_DISP_FAKE1 MTK_M4U_ID(SMI_L2_ID, 4) 93*aa1a8ff2SEmmanuel Vadot 94*aa1a8ff2SEmmanuel Vadot /* LARB 3 -- VDO-1 */ 95*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L3_MDP_RDMA1 MTK_M4U_ID(SMI_L3_ID, 0) 96*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L3_MDP_RDMA3 MTK_M4U_ID(SMI_L3_ID, 1) 97*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L3_MDP_RDMA5 MTK_M4U_ID(SMI_L3_ID, 2) 98*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L3_MDP_RDMA7 MTK_M4U_ID(SMI_L3_ID, 3) 99*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L3_HDR_DS_SMI MTK_M4U_ID(SMI_L3_ID, 4) 100*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L3_HDR_ADL_SMI MTK_M4U_ID(SMI_L3_ID, 5) 101*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L3_DISP_FAKE1 MTK_M4U_ID(SMI_L3_ID, 6) 102*aa1a8ff2SEmmanuel Vadot 103*aa1a8ff2SEmmanuel Vadot /* LARB 4 -- VPP-0 */ 104*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L4_MDP_RDMA MTK_M4U_ID(SMI_L4_ID, 0) 105*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L4_MDP_FG MTK_M4U_ID(SMI_L4_ID, 1) 106*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L4_MDP_OVL MTK_M4U_ID(SMI_L4_ID, 2) 107*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L4_MDP_WROT MTK_M4U_ID(SMI_L4_ID, 3) 108*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L4_FAKE_ENG MTK_M4U_ID(SMI_L4_ID, 4) 109*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L4_DISP_RDMA MTK_M4U_ID(SMI_L4_ID, 5) 110*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L4_DISP_WDMA MTK_M4U_ID(SMI_L4_ID, 6) 111*aa1a8ff2SEmmanuel Vadot 112*aa1a8ff2SEmmanuel Vadot /* LARB 5 -- VPP-1 */ 113*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L5_SVPP1_MDP_RDMA MTK_M4U_ID(SMI_L5_ID, 0) 114*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L5_SVPP1_MDP_FG MTK_M4U_ID(SMI_L5_ID, 1) 115*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L5_SVPP1_MDP_OVL MTK_M4U_ID(SMI_L5_ID, 2) 116*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L5_SVPP1_MDP_WROT MTK_M4U_ID(SMI_L5_ID, 3) 117*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L5_SVPP2_MDP_RDMA MTK_M4U_ID(SMI_L5_ID, 4) 118*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L5_SVPP2_MDP_FG MTK_M4U_ID(SMI_L5_ID, 5) 119*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L5_SVPP2_MDP_WROT MTK_M4U_ID(SMI_L5_ID, 6) 120*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L5_LARB5_FAKE_ENG MTK_M4U_ID(SMI_L5_ID, 7) 121*aa1a8ff2SEmmanuel Vadot 122*aa1a8ff2SEmmanuel Vadot /* LARB 6 -- VPP-1 */ 123*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L6_SVPP3_MDP_RDMA MTK_M4U_ID(SMI_L6_ID, 0) 124*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L6_SVPP3_MDP_FG MTK_M4U_ID(SMI_L6_ID, 1) 125*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L6_SVPP3_MDP_WROT MTK_M4U_ID(SMI_L6_ID, 2) 126*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L6_LARB6_FAKE_ENG MTK_M4U_ID(SMI_L6_ID, 3) 127*aa1a8ff2SEmmanuel Vadot 128*aa1a8ff2SEmmanuel Vadot /* LARB 7 -- WPE */ 129*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L7_WPE_RDMA_0 MTK_M4U_ID(SMI_L7_ID, 0) 130*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L7_WPE_RDMA_1 MTK_M4U_ID(SMI_L7_ID, 1) 131*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L7_WPE_WDMA_0 MTK_M4U_ID(SMI_L7_ID, 2) 132*aa1a8ff2SEmmanuel Vadot 133*aa1a8ff2SEmmanuel Vadot /* LARB 9 -- IMG-M */ 134*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_IMGI_T1_A MTK_M4U_ID(SMI_L9_ID, 0) 135*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_UFDI_T1_A MTK_M4U_ID(SMI_L9_ID, 1) 136*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_IMGBI_T1_A MTK_M4U_ID(SMI_L9_ID, 2) 137*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_IMGCI_T1_A MTK_M4U_ID(SMI_L9_ID, 3) 138*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_SMTI_T1_A MTK_M4U_ID(SMI_L9_ID, 4) 139*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_SMTI_T4_A MTK_M4U_ID(SMI_L9_ID, 5) 140*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_TNCSTI_T1_A MTK_M4U_ID(SMI_L9_ID, 6) 141*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_TNCSTI_T4_A MTK_M4U_ID(SMI_L9_ID, 7) 142*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_YUVO_T1_A MTK_M4U_ID(SMI_L9_ID, 8) 143*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_YUVBO_T1_A MTK_M4U_ID(SMI_L9_ID, 9) 144*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_YUVCO_T1_A MTK_M4U_ID(SMI_L9_ID, 10) 145*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_TIMGO_T1_A MTK_M4U_ID(SMI_L9_ID, 11) 146*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_YUVO_T2_A MTK_M4U_ID(SMI_L9_ID, 12) 147*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_YUVO_T5_A MTK_M4U_ID(SMI_L9_ID, 13) 148*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_IMGI_T1_B MTK_M4U_ID(SMI_L9_ID, 14) 149*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_IMGBI_T1_B MTK_M4U_ID(SMI_L9_ID, 15) 150*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_IMGCI_T1_B MTK_M4U_ID(SMI_L9_ID, 16) 151*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_SMTI_T4_B MTK_M4U_ID(SMI_L9_ID, 17) 152*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_TNCSO_T1_A MTK_M4U_ID(SMI_L9_ID, 18) 153*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_SMTO_T1_A MTK_M4U_ID(SMI_L9_ID, 19) 154*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_SMTO_T4_A MTK_M4U_ID(SMI_L9_ID, 20) 155*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_TNCSTO_T1_A MTK_M4U_ID(SMI_L9_ID, 21) 156*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_YUVO_T2_B MTK_M4U_ID(SMI_L9_ID, 22) 157*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_YUVO_T5_B MTK_M4U_ID(SMI_L9_ID, 23) 158*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L9_SMTO_T4_B MTK_M4U_ID(SMI_L9_ID, 24) 159*aa1a8ff2SEmmanuel Vadot 160*aa1a8ff2SEmmanuel Vadot /* LARB 10 -- IMG-D */ 161*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_IMGI_D1 MTK_M4U_ID(SMI_L10_ID, 0) 162*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_IMGBI_D1 MTK_M4U_ID(SMI_L10_ID, 1) 163*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_IMGCI_D1 MTK_M4U_ID(SMI_L10_ID, 2) 164*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_IMGDI_D1 MTK_M4U_ID(SMI_L10_ID, 3) 165*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_DEPI_D1 MTK_M4U_ID(SMI_L10_ID, 4) 166*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_DMGI_D1 MTK_M4U_ID(SMI_L10_ID, 5) 167*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_SMTI_D1 MTK_M4U_ID(SMI_L10_ID, 6) 168*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_RECI_D1 MTK_M4U_ID(SMI_L10_ID, 7) 169*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_RECI_D1_N MTK_M4U_ID(SMI_L10_ID, 8) 170*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_TNRWI_D1 MTK_M4U_ID(SMI_L10_ID, 9) 171*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_TNRCI_D1 MTK_M4U_ID(SMI_L10_ID, 10) 172*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_TNRCI_D1_N MTK_M4U_ID(SMI_L10_ID, 11) 173*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_IMG4O_D1 MTK_M4U_ID(SMI_L10_ID, 12) 174*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_IMG4BO_D1 MTK_M4U_ID(SMI_L10_ID, 13) 175*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_SMTI_D8 MTK_M4U_ID(SMI_L10_ID, 14) 176*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_SMTO_D1 MTK_M4U_ID(SMI_L10_ID, 15) 177*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_TNRMO_D1 MTK_M4U_ID(SMI_L10_ID, 16) 178*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_TNRMO_D1_N MTK_M4U_ID(SMI_L10_ID, 17) 179*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_SMTO_D8 MTK_M4U_ID(SMI_L10_ID, 18) 180*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L10_DBGO_D1 MTK_M4U_ID(SMI_L10_ID, 19) 181*aa1a8ff2SEmmanuel Vadot 182*aa1a8ff2SEmmanuel Vadot /* LARB 11A -- IMG-D */ 183*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WPE_RDMA_0 MTK_M4U_ID(SMI_L11A_ID, 0) 184*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WPE_RDMA_1 MTK_M4U_ID(SMI_L11A_ID, 1) 185*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WPE_RDMA_4P_0 MTK_M4U_ID(SMI_L11A_ID, 2) 186*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WPE_RDMA_4P_1 MTK_M4U_ID(SMI_L11A_ID, 3) 187*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WPE_CQ0 MTK_M4U_ID(SMI_L11A_ID, 4) 188*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WPE_CQ1 MTK_M4U_ID(SMI_L11A_ID, 5) 189*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_PIMGI_P1 MTK_M4U_ID(SMI_L11A_ID, 6) 190*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_PIMGBI_P1 MTK_M4U_ID(SMI_L11A_ID, 7) 191*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_PIMGCI_P1 MTK_M4U_ID(SMI_L11A_ID, 8) 192*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_IMGI_T1_C MTK_M4U_ID(SMI_L11A_ID, 9) 193*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_IMGBI_T1_C MTK_M4U_ID(SMI_L11A_ID, 10) 194*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_IMGCI_T1_C MTK_M4U_ID(SMI_L11A_ID, 11) 195*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_SMTI_T1_C MTK_M4U_ID(SMI_L11A_ID, 12) 196*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_SMTI_T4_C MTK_M4U_ID(SMI_L11A_ID, 13) 197*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_SMTI_T6_C MTK_M4U_ID(SMI_L11A_ID, 14) 198*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_YUVO_T1_C MTK_M4U_ID(SMI_L11A_ID, 15) 199*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_YUVBO_T1_C MTK_M4U_ID(SMI_L11A_ID, 16) 200*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_YUVCO_T1_C MTK_M4U_ID(SMI_L11A_ID, 17) 201*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WPE_WDMA_0 MTK_M4U_ID(SMI_L11A_ID, 18) 202*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WPE_WDMA_4P_0 MTK_M4U_ID(SMI_L11A_ID, 19) 203*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_WROT_P1 MTK_M4U_ID(SMI_L11A_ID, 20) 204*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_TCCSO_P1 MTK_M4U_ID(SMI_L11A_ID, 21) 205*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_TCCSI_P1 MTK_M4U_ID(SMI_L11A_ID, 22) 206*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_TIMGO_T1_C MTK_M4U_ID(SMI_L11A_ID, 23) 207*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_YUVO_T2_C MTK_M4U_ID(SMI_L11A_ID, 24) 208*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_YUVO_T5_C MTK_M4U_ID(SMI_L11A_ID, 25) 209*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_SMTO_T1_C MTK_M4U_ID(SMI_L11A_ID, 26) 210*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_SMTO_T4_C MTK_M4U_ID(SMI_L11A_ID, 27) 211*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_SMTO_T6_C MTK_M4U_ID(SMI_L11A_ID, 28) 212*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11A_DBGO_T1_C MTK_M4U_ID(SMI_L11A_ID, 29) 213*aa1a8ff2SEmmanuel Vadot 214*aa1a8ff2SEmmanuel Vadot /* LARB 11B -- IMG-D */ 215*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WPE_RDMA_0 MTK_M4U_ID(SMI_L11B_ID, 0) 216*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WPE_RDMA_1 MTK_M4U_ID(SMI_L11B_ID, 1) 217*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WPE_RDMA_4P_0 MTK_M4U_ID(SMI_L11B_ID, 2) 218*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WPE_RDMA_4P_1 MTK_M4U_ID(SMI_L11B_ID, 3) 219*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WPE_CQ0 MTK_M4U_ID(SMI_L11B_ID, 4) 220*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WPE_CQ1 MTK_M4U_ID(SMI_L11B_ID, 5) 221*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_PIMGI_P1 MTK_M4U_ID(SMI_L11B_ID, 6) 222*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_PIMGBI_P1 MTK_M4U_ID(SMI_L11B_ID, 7) 223*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_PIMGCI_P1 MTK_M4U_ID(SMI_L11B_ID, 8) 224*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_IMGI_T1_C MTK_M4U_ID(SMI_L11B_ID, 9) 225*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_IMGBI_T1_C MTK_M4U_ID(SMI_L11B_ID, 10) 226*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_IMGCI_T1_C MTK_M4U_ID(SMI_L11B_ID, 11) 227*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_SMTI_T1_C MTK_M4U_ID(SMI_L11B_ID, 12) 228*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_SMTI_T4_C MTK_M4U_ID(SMI_L11B_ID, 13) 229*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_SMTI_T6_C MTK_M4U_ID(SMI_L11B_ID, 14) 230*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_YUVO_T1_C MTK_M4U_ID(SMI_L11B_ID, 15) 231*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_YUVBO_T1_C MTK_M4U_ID(SMI_L11B_ID, 16) 232*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_YUVCO_T1_C MTK_M4U_ID(SMI_L11B_ID, 17) 233*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WPE_WDMA_0 MTK_M4U_ID(SMI_L11B_ID, 18) 234*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WPE_WDMA_4P_0 MTK_M4U_ID(SMI_L11B_ID, 19) 235*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_WROT_P1 MTK_M4U_ID(SMI_L11B_ID, 20) 236*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_TCCSO_P1 MTK_M4U_ID(SMI_L11B_ID, 21) 237*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_TCCSI_P1 MTK_M4U_ID(SMI_L11B_ID, 22) 238*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_TIMGO_T1_C MTK_M4U_ID(SMI_L11B_ID, 23) 239*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_YUVO_T2_C MTK_M4U_ID(SMI_L11B_ID, 24) 240*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_YUVO_T5_C MTK_M4U_ID(SMI_L11B_ID, 25) 241*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_SMTO_T1_C MTK_M4U_ID(SMI_L11B_ID, 26) 242*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_SMTO_T4_C MTK_M4U_ID(SMI_L11B_ID, 27) 243*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_SMTO_T6_C MTK_M4U_ID(SMI_L11B_ID, 28) 244*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11B_DBGO_T1_C MTK_M4U_ID(SMI_L11B_ID, 29) 245*aa1a8ff2SEmmanuel Vadot 246*aa1a8ff2SEmmanuel Vadot /* LARB 11C -- IMG-D */ 247*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WPE_RDMA_0 MTK_M4U_ID(SMI_L11C_ID, 0) 248*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WPE_RDMA_1 MTK_M4U_ID(SMI_L11C_ID, 1) 249*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WPE_RDMA_4P_0 MTK_M4U_ID(SMI_L11C_ID, 2) 250*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WPE_RDMA_4P_1 MTK_M4U_ID(SMI_L11C_ID, 3) 251*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WPE_CQ0 MTK_M4U_ID(SMI_L11C_ID, 4) 252*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WPE_CQ1 MTK_M4U_ID(SMI_L11C_ID, 5) 253*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_PIMGI_P1 MTK_M4U_ID(SMI_L11C_ID, 6) 254*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_PIMGBI_P1 MTK_M4U_ID(SMI_L11C_ID, 7) 255*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_PIMGCI_P1 MTK_M4U_ID(SMI_L11C_ID, 8) 256*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_IMGI_T1_C MTK_M4U_ID(SMI_L11C_ID, 9) 257*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_IMGBI_T1_C MTK_M4U_ID(SMI_L11C_ID, 10) 258*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_IMGCI_T1_C MTK_M4U_ID(SMI_L11C_ID, 11) 259*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_SMTI_T1_C MTK_M4U_ID(SMI_L11C_ID, 12) 260*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_SMTI_T4_C MTK_M4U_ID(SMI_L11C_ID, 13) 261*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_SMTI_T6_C MTK_M4U_ID(SMI_L11C_ID, 14) 262*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_YUVO_T1_C MTK_M4U_ID(SMI_L11C_ID, 15) 263*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_YUVBO_T1_C MTK_M4U_ID(SMI_L11C_ID, 16) 264*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_YUVCO_T1_C MTK_M4U_ID(SMI_L11C_ID, 17) 265*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WPE_WDMA_0 MTK_M4U_ID(SMI_L11C_ID, 18) 266*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WPE_WDMA_4P_0 MTK_M4U_ID(SMI_L11C_ID, 19) 267*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_WROT_P1 MTK_M4U_ID(SMI_L11C_ID, 20) 268*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_TCCSO_P1 MTK_M4U_ID(SMI_L11C_ID, 21) 269*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_TCCSI_P1 MTK_M4U_ID(SMI_L11C_ID, 22) 270*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_TIMGO_T1_C MTK_M4U_ID(SMI_L11C_ID, 23) 271*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_YUVO_T2_C MTK_M4U_ID(SMI_L11C_ID, 24) 272*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_YUVO_T5_C MTK_M4U_ID(SMI_L11C_ID, 25) 273*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_SMTO_T1_C MTK_M4U_ID(SMI_L11C_ID, 26) 274*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_SMTO_T4_C MTK_M4U_ID(SMI_L11C_ID, 27) 275*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_SMTO_T6_C MTK_M4U_ID(SMI_L11C_ID, 28) 276*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L11C_DBGO_T1_C MTK_M4U_ID(SMI_L11C_ID, 29) 277*aa1a8ff2SEmmanuel Vadot 278*aa1a8ff2SEmmanuel Vadot /* LARB 12 -- IPE */ 279*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_FDVT_RDA_0 MTK_M4U_ID(SMI_L12_ID, 0) 280*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_FDVT_RDB_0 MTK_M4U_ID(SMI_L12_ID, 1) 281*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_FDVT_WRA_0 MTK_M4U_ID(SMI_L12_ID, 2) 282*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_FDVT_WRB_0 MTK_M4U_ID(SMI_L12_ID, 3) 283*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_ME_RDMA MTK_M4U_ID(SMI_L12_ID, 4) 284*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_ME_WDMA MTK_M4U_ID(SMI_L12_ID, 5) 285*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_DVS_RDMA MTK_M4U_ID(SMI_L12_ID, 6) 286*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_DVS_WDMA MTK_M4U_ID(SMI_L12_ID, 7) 287*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_DVP_RDMA MTK_M4U_ID(SMI_L12_ID, 8) 288*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_DVP_WDMA MTK_M4U_ID(SMI_L12_ID, 9) 289*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_FDVT_2ND_RDA_0 MTK_M4U_ID(SMI_L12_ID, 10) 290*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_FDVT_2ND_RDB_0 MTK_M4U_ID(SMI_L12_ID, 11) 291*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_FDVT_2ND_WRA_0 MTK_M4U_ID(SMI_L12_ID, 12) 292*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_FDVT_2ND_WRB_0 MTK_M4U_ID(SMI_L12_ID, 13) 293*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_DHZEI_E1 MTK_M4U_ID(SMI_L12_ID, 14) 294*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L12_DHZEO_E1 MTK_M4U_ID(SMI_L12_ID, 15) 295*aa1a8ff2SEmmanuel Vadot 296*aa1a8ff2SEmmanuel Vadot /* LARB 13 -- CAM-1 */ 297*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_CAMSV_CQI_E1 MTK_M4U_ID(SMI_L13_ID, 0) 298*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_CAMSV_CQI_E2 MTK_M4U_ID(SMI_L13_ID, 1) 299*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_A_IMGO_1 MTK_M4U_ID(SMI_L13_ID, 2) 300*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_C_IMGO_1 MTK_M4U_ID(SMI_L13_ID, 3) 301*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_A_IMGO_2 MTK_M4U_ID(SMI_L13_ID, 4) 302*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_C_IMGO_2 MTK_M4U_ID(SMI_L13_ID, 5) 303*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_PDAI_A_0 MTK_M4U_ID(SMI_L13_ID, 6) 304*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_PDAI_A_1 MTK_M4U_ID(SMI_L13_ID, 7) 305*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_CAMSV_CQI_B_E1 MTK_M4U_ID(SMI_L13_ID, 8) 306*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_CAMSV_CQI_B_E2 MTK_M4U_ID(SMI_L13_ID, 9) 307*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_CAMSV_CQI_C_E1 MTK_M4U_ID(SMI_L13_ID, 10) 308*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_CAMSV_CQI_C_E2 MTK_M4U_ID(SMI_L13_ID, 11) 309*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_E_IMGO_1 MTK_M4U_ID(SMI_L13_ID, 12) 310*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_E_IMGO_2 MTK_M4U_ID(SMI_L13_ID, 13) 311*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_A_UFEO_1 MTK_M4U_ID(SMI_L13_ID, 14) 312*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_C_UFEO_1 MTK_M4U_ID(SMI_L13_ID, 15) 313*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_A_UFEO_2 MTK_M4U_ID(SMI_L13_ID, 16) 314*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_C_UFEO_2 MTK_M4U_ID(SMI_L13_ID, 17) 315*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_E_UFEO_1 MTK_M4U_ID(SMI_L13_ID, 18) 316*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_E_UFEO_2 MTK_M4U_ID(SMI_L13_ID, 19) 317*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_G_IMGO_1 MTK_M4U_ID(SMI_L13_ID, 20) 318*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_GCAMSV_G_IMGO_2 MTK_M4U_ID(SMI_L13_ID, 21) 319*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_PDAO_A MTK_M4U_ID(SMI_L13_ID, 22) 320*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L13_PDAO_C MTK_M4U_ID(SMI_L13_ID, 23) 321*aa1a8ff2SEmmanuel Vadot 322*aa1a8ff2SEmmanuel Vadot /* LARB 14 -- CAM-1 */ 323*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_B_IMGO_1 MTK_M4U_ID(SMI_L14_ID, 0) 324*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_B_IMGO_2 MTK_M4U_ID(SMI_L14_ID, 1) 325*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_SCAMSV_A_IMGO_1 MTK_M4U_ID(SMI_L14_ID, 2) 326*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_SCAMSV_A_IMGO_2 MTK_M4U_ID(SMI_L14_ID, 3) 327*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_SCAMSV_B_IMGO_1 MTK_M4U_ID(SMI_L14_ID, 4) 328*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_SCAMSV_B_IMGO_2 MTK_M4U_ID(SMI_L14_ID, 5) 329*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_PDAI_B_0 MTK_M4U_ID(SMI_L14_ID, 6) 330*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_PDAI_B_1 MTK_M4U_ID(SMI_L14_ID, 7) 331*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_D_IMGO_1 MTK_M4U_ID(SMI_L14_ID, 8) 332*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_D_IMGO_2 MTK_M4U_ID(SMI_L14_ID, 9) 333*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_F_IMGO_1 MTK_M4U_ID(SMI_L14_ID, 10) 334*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_F_IMGO_2 MTK_M4U_ID(SMI_L14_ID, 11) 335*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_H_IMGO_1 MTK_M4U_ID(SMI_L14_ID, 12) 336*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_H_IMGO_2 MTK_M4U_ID(SMI_L14_ID, 13) 337*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_B_UFEO_1 MTK_M4U_ID(SMI_L14_ID, 14) 338*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_B_UFEO_2 MTK_M4U_ID(SMI_L14_ID, 15) 339*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_D_UFEO_1 MTK_M4U_ID(SMI_L14_ID, 16) 340*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_GCAMSV_D_UFEO_2 MTK_M4U_ID(SMI_L14_ID, 17) 341*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_PDAO_B MTK_M4U_ID(SMI_L14_ID, 18) 342*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_IPUI MTK_M4U_ID(SMI_L14_ID, 19) 343*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_IPUO MTK_M4U_ID(SMI_L14_ID, 20) 344*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_IPU3O MTK_M4U_ID(SMI_L14_ID, 21) 345*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L14_FAKE MTK_M4U_ID(SMI_L14_ID, 22) 346*aa1a8ff2SEmmanuel Vadot 347*aa1a8ff2SEmmanuel Vadot /* LARB 15 -- IMG-D */ 348*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_VIPI_D1 MTK_M4U_ID(SMI_L15_ID, 0) 349*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_VIPBI_D1 MTK_M4U_ID(SMI_L15_ID, 1) 350*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_SMTI_D6 MTK_M4U_ID(SMI_L15_ID, 2) 351*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_TNCSTI_D1 MTK_M4U_ID(SMI_L15_ID, 3) 352*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_TNCSTI_D4 MTK_M4U_ID(SMI_L15_ID, 4) 353*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_SMTI_D4 MTK_M4U_ID(SMI_L15_ID, 5) 354*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_IMG3O_D1 MTK_M4U_ID(SMI_L15_ID, 6) 355*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_IMG3BO_D1 MTK_M4U_ID(SMI_L15_ID, 7) 356*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_IMG3CO_D1 MTK_M4U_ID(SMI_L15_ID, 8) 357*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_IMG2O_D1 MTK_M4U_ID(SMI_L15_ID, 9) 358*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_SMTI_D9 MTK_M4U_ID(SMI_L15_ID, 10) 359*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_SMTO_D4 MTK_M4U_ID(SMI_L15_ID, 11) 360*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_FEO_D1 MTK_M4U_ID(SMI_L15_ID, 12) 361*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_TNCSO_D1 MTK_M4U_ID(SMI_L15_ID, 13) 362*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_TNCSTO_D1 MTK_M4U_ID(SMI_L15_ID, 14) 363*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_SMTO_D6 MTK_M4U_ID(SMI_L15_ID, 15) 364*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_SMTO_D9 MTK_M4U_ID(SMI_L15_ID, 16) 365*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_TNCO_D1 MTK_M4U_ID(SMI_L15_ID, 17) 366*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L15_TNCO_D1_N MTK_M4U_ID(SMI_L15_ID, 18) 367*aa1a8ff2SEmmanuel Vadot 368*aa1a8ff2SEmmanuel Vadot /* LARB 16A -- CAM */ 369*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_IMGO_R1 MTK_M4U_ID(SMI_L16A_ID, 0) 370*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_CQI_R1 MTK_M4U_ID(SMI_L16A_ID, 1) 371*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_CQI_R2 MTK_M4U_ID(SMI_L16A_ID, 2) 372*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_BPCI_R1 MTK_M4U_ID(SMI_L16A_ID, 3) 373*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_LSCI_R1 MTK_M4U_ID(SMI_L16A_ID, 4) 374*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_RAWI_R2 MTK_M4U_ID(SMI_L16A_ID, 5) 375*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_RAWI_R3 MTK_M4U_ID(SMI_L16A_ID, 6) 376*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_UFDI_R2 MTK_M4U_ID(SMI_L16A_ID, 7) 377*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_UFDI_R3 MTK_M4U_ID(SMI_L16A_ID, 8) 378*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_RAWI_R4 MTK_M4U_ID(SMI_L16A_ID, 9) 379*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_RAWI_R5 MTK_M4U_ID(SMI_L16A_ID, 10) 380*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_AAI_R1 MTK_M4U_ID(SMI_L16A_ID, 11) 381*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_UFDI_R5 MTK_M4U_ID(SMI_L16A_ID, 12) 382*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_FHO_R1 MTK_M4U_ID(SMI_L16A_ID, 13) 383*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_AAO_R1 MTK_M4U_ID(SMI_L16A_ID, 14) 384*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_TSFSO_R1 MTK_M4U_ID(SMI_L16A_ID, 15) 385*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16A_FLKO_R1 MTK_M4U_ID(SMI_L16A_ID, 16) 386*aa1a8ff2SEmmanuel Vadot 387*aa1a8ff2SEmmanuel Vadot /* LARB 16B -- CAM */ 388*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_IMGO_R1 MTK_M4U_ID(SMI_L16B_ID, 0) 389*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_CQI_R1 MTK_M4U_ID(SMI_L16B_ID, 1) 390*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_CQI_R2 MTK_M4U_ID(SMI_L16B_ID, 2) 391*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_BPCI_R1 MTK_M4U_ID(SMI_L16B_ID, 3) 392*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_LSCI_R1 MTK_M4U_ID(SMI_L16B_ID, 4) 393*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_RAWI_R2 MTK_M4U_ID(SMI_L16B_ID, 5) 394*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_RAWI_R3 MTK_M4U_ID(SMI_L16B_ID, 6) 395*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_UFDI_R2 MTK_M4U_ID(SMI_L16B_ID, 7) 396*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_UFDI_R3 MTK_M4U_ID(SMI_L16B_ID, 8) 397*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_RAWI_R4 MTK_M4U_ID(SMI_L16B_ID, 9) 398*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_RAWI_R5 MTK_M4U_ID(SMI_L16B_ID, 10) 399*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_AAI_R1 MTK_M4U_ID(SMI_L16B_ID, 11) 400*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_UFDI_R5 MTK_M4U_ID(SMI_L16B_ID, 12) 401*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_FHO_R1 MTK_M4U_ID(SMI_L16B_ID, 13) 402*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_AAO_R1 MTK_M4U_ID(SMI_L16B_ID, 14) 403*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_TSFSO_R1 MTK_M4U_ID(SMI_L16B_ID, 15) 404*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L16B_FLKO_R1 MTK_M4U_ID(SMI_L16B_ID, 16) 405*aa1a8ff2SEmmanuel Vadot 406*aa1a8ff2SEmmanuel Vadot /* LARB 17A -- CAM */ 407*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17A_YUVO_R1 MTK_M4U_ID(SMI_L17A_ID, 0) 408*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17A_YUVO_R3 MTK_M4U_ID(SMI_L17A_ID, 1) 409*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17A_YUVCO_R1 MTK_M4U_ID(SMI_L17A_ID, 2) 410*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17A_YUVO_R2 MTK_M4U_ID(SMI_L17A_ID, 3) 411*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17A_RZH1N2TO_R1 MTK_M4U_ID(SMI_L17A_ID, 4) 412*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17A_DRZS4NO_R1 MTK_M4U_ID(SMI_L17A_ID, 5) 413*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17A_TNCSO_R1 MTK_M4U_ID(SMI_L17A_ID, 6) 414*aa1a8ff2SEmmanuel Vadot 415*aa1a8ff2SEmmanuel Vadot /* LARB 17B -- CAM */ 416*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17B_YUVO_R1 MTK_M4U_ID(SMI_L17B_ID, 0) 417*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17B_YUVO_R3 MTK_M4U_ID(SMI_L17B_ID, 1) 418*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17B_YUVCO_R1 MTK_M4U_ID(SMI_L17B_ID, 2) 419*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17B_YUVO_R2 MTK_M4U_ID(SMI_L17B_ID, 3) 420*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17B_RZH1N2TO_R1 MTK_M4U_ID(SMI_L17B_ID, 4) 421*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17B_DRZS4NO_R1 MTK_M4U_ID(SMI_L17B_ID, 5) 422*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L17B_TNCSO_R1 MTK_M4U_ID(SMI_L17B_ID, 6) 423*aa1a8ff2SEmmanuel Vadot 424*aa1a8ff2SEmmanuel Vadot /* LARB 19 -- VENC */ 425*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_RCPU MTK_M4U_ID(SMI_L19_ID, 0) 426*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_REC MTK_M4U_ID(SMI_L19_ID, 1) 427*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_BSDMA MTK_M4U_ID(SMI_L19_ID, 2) 428*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_SV_COMV MTK_M4U_ID(SMI_L19_ID, 3) 429*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_RD_COMV MTK_M4U_ID(SMI_L19_ID, 4) 430*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_NBM_RDMA MTK_M4U_ID(SMI_L19_ID, 5) 431*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_NBM_RDMA_LITE MTK_M4U_ID(SMI_L19_ID, 6) 432*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGENC_Y_RDMA MTK_M4U_ID(SMI_L19_ID, 7) 433*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGENC_C_RDMA MTK_M4U_ID(SMI_L19_ID, 8) 434*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGENC_Q_TABLE MTK_M4U_ID(SMI_L19_ID, 9) 435*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_SUB_W_LUMA MTK_M4U_ID(SMI_L19_ID, 10) 436*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_FCS_NBM_RDMA MTK_M4U_ID(SMI_L19_ID, 11) 437*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGENC_BSDMA MTK_M4U_ID(SMI_L19_ID, 12) 438*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGDEC_WDMA_0 MTK_M4U_ID(SMI_L19_ID, 13) 439*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGDEC_BSDMA_0 MTK_M4U_ID(SMI_L19_ID, 14) 440*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_NBM_WDMA MTK_M4U_ID(SMI_L19_ID, 15) 441*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_NBM_WDMA_LITE MTK_M4U_ID(SMI_L19_ID, 16) 442*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_FCS_NBM_WDMA MTK_M4U_ID(SMI_L19_ID, 17) 443*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGDEC_WDMA_1 MTK_M4U_ID(SMI_L19_ID, 18) 444*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGDEC_BSDMA_1 MTK_M4U_ID(SMI_L19_ID, 19) 445*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGDEC_HUFF_OFFSET_1 MTK_M4U_ID(SMI_L19_ID, 20) 446*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_JPGDEC_HUFF_OFFSET_0 MTK_M4U_ID(SMI_L19_ID, 21) 447*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_CUR_LUMA MTK_M4U_ID(SMI_L19_ID, 22) 448*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_CUR_CHROMA MTK_M4U_ID(SMI_L19_ID, 23) 449*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_REF_LUMA MTK_M4U_ID(SMI_L19_ID, 24) 450*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_REF_CHROMA MTK_M4U_ID(SMI_L19_ID, 25) 451*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L19_VENC_SUB_R_LUMA MTK_M4U_ID(SMI_L19_ID, 26) 452*aa1a8ff2SEmmanuel Vadot 453*aa1a8ff2SEmmanuel Vadot /* LARB 21 -- VDEC-CORE0 */ 454*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_MC_EXT MTK_M4U_ID(SMI_L21_ID, 0) 455*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_UFO_EXT MTK_M4U_ID(SMI_L21_ID, 1) 456*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_PP_EXT MTK_M4U_ID(SMI_L21_ID, 2) 457*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_PRED_RD_EXT MTK_M4U_ID(SMI_L21_ID, 3) 458*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_PRED_WR_EXT MTK_M4U_ID(SMI_L21_ID, 4) 459*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_PPWRAP_EXT MTK_M4U_ID(SMI_L21_ID, 5) 460*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_TILE_EXT MTK_M4U_ID(SMI_L21_ID, 6) 461*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_VLD_EXT MTK_M4U_ID(SMI_L21_ID, 7) 462*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_VLD2_EXT MTK_M4U_ID(SMI_L21_ID, 8) 463*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_AVC_MV_EXT MTK_M4U_ID(SMI_L21_ID, 9) 464*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L21_HW_VDEC_UFO_EXT_C MTK_M4U_ID(SMI_L21_ID, 10) 465*aa1a8ff2SEmmanuel Vadot 466*aa1a8ff2SEmmanuel Vadot /* LARB 23 -- VDEC-SOC */ 467*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_LAT0_VLD_EXT MTK_M4U_ID(SMI_L23_ID, 0) 468*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_LAT0_VLD2_EXT MTK_M4U_ID(SMI_L23_ID, 1) 469*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_LAT0_AVC_MV_EXT MTK_M4U_ID(SMI_L23_ID, 2) 470*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_LAT0_PRED_RD_EXT MTK_M4U_ID(SMI_L23_ID, 3) 471*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_LAT0_TILE_EXT MTK_M4U_ID(SMI_L23_ID, 4) 472*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_LAT0_WDMA_EXT MTK_M4U_ID(SMI_L23_ID, 5) 473*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_UFO_ENC_EXT MTK_M4U_ID(SMI_L23_ID, 6) 474*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_UFO_ENC_EXT_C MTK_M4U_ID(SMI_L23_ID, 7) 475*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L23_HW_VDEC_MC_EXT_C MTK_M4U_ID(SMI_L23_ID, 8) 476*aa1a8ff2SEmmanuel Vadot 477*aa1a8ff2SEmmanuel Vadot /* LARB 27 -- CCU */ 478*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L27_CCUI MTK_M4U_ID(SMI_L27_ID, 0) 479*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L27_CCUO MTK_M4U_ID(SMI_L27_ID, 1) 480*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L27_CCUI2 MTK_M4U_ID(SMI_L27_ID, 2) 481*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L27_CCUO2 MTK_M4U_ID(SMI_L27_ID, 3) 482*aa1a8ff2SEmmanuel Vadot 483*aa1a8ff2SEmmanuel Vadot /* LARB 28 -- AXI-CCU */ 484*aa1a8ff2SEmmanuel Vadot #define M4U_PORT_L28_CCU_AXI_0 MTK_M4U_ID(SMI_L28_ID, 0) 485*aa1a8ff2SEmmanuel Vadot 486*aa1a8ff2SEmmanuel Vadot /* infra/peri */ 487*aa1a8ff2SEmmanuel Vadot #define IFR_IOMMU_PORT_PCIE_0 MTK_IFAIOMMU_PERI_ID(0) 488*aa1a8ff2SEmmanuel Vadot 489*aa1a8ff2SEmmanuel Vadot #endif 490