xref: /freebsd-src/sys/contrib/device-tree/include/dt-bindings/memory/mediatek,mt8188-memory-port.h (revision aa1a8ff2d6dbc51ef058f46f3db5a8bb77967145)
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