summaryrefslogtreecommitdiffstats
path: root/include/dt-bindings/memory/mt8186-memory-port.h
blob: 2bc6e443304882daaa40d199a6db934c7b934443 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Copyright (c) 2022 MediaTek Inc.
 *
 * Author: Anan Sun <anan.sun@mediatek.com>
 * Author: Yong Wu <yong.wu@mediatek.com>
 */
#ifndef _DT_BINDINGS_MEMORY_MT8186_LARB_PORT_H_
#define _DT_BINDINGS_MEMORY_MT8186_LARB_PORT_H_

#include <dt-bindings/memory/mtk-memory-port.h>

/*
 * MM IOMMU supports 16GB dma address. We separate it to four ranges:
 * 0 ~ 4G; 4G ~ 8G; 8G ~ 12G; 12G ~ 16G, we could adjust these masters
 * locate in anyone region. BUT:
 * a) Make sure all the ports inside a larb are in one range.
 * b) The iova of any master can NOT cross the 4G/8G/12G boundary.
 *
 * This is the suggested mapping in this SoC:
 *
 * modules    dma-address-region	larbs-ports
 * disp         0 ~ 4G                  larb0/1/2
 * vcodec      4G ~ 8G                  larb4/7
 * cam/mdp     8G ~ 12G                 the other larbs.
 * N/A         12G ~ 16G
 * CCU0   0x24000_0000 ~ 0x243ff_ffff   larb13: port 9/10
 * CCU1   0x24400_0000 ~ 0x247ff_ffff   larb14: port 4/5
 */

/* MM IOMMU ports */
/* LARB 0 -- MMSYS */
#define IOMMU_PORT_L0_DISP_POSTMASK0	MTK_M4U_ID(0, 0)
#define IOMMU_PORT_L0_REVERSED		MTK_M4U_ID(0, 1)
#define IOMMU_PORT_L0_OVL_RDMA0		MTK_M4U_ID(0, 2)
#define IOMMU_PORT_L0_DISP_FAKE0	MTK_M4U_ID(0, 3)

/* LARB 1 -- MMSYS */
#define IOMMU_PORT_L1_DISP_RDMA1	MTK_M4U_ID(1, 0)
#define IOMMU_PORT_L1_OVL_2L_RDMA0	MTK_M4U_ID(1, 1)
#define IOMMU_PORT_L1_DISP_RDMA0	MTK_M4U_ID(1, 2)
#define IOMMU_PORT_L1_DISP_WDMA0	MTK_M4U_ID(1, 3)
#define IOMMU_PORT_L1_DISP_FAKE1	MTK_M4U_ID(1, 4)

/* LARB 2 -- MMSYS */
#define IOMMU_PORT_L2_MDP_RDMA0		MTK_M4U_ID(2, 0)
#define IOMMU_PORT_L2_MDP_RDMA1		MTK_M4U_ID(2, 1)
#define IOMMU_PORT_L2_MDP_WROT0		MTK_M4U_ID(2, 2)
#define IOMMU_PORT_L2_MDP_WROT1		MTK_M4U_ID(2, 3)
#define IOMMU_PORT_L2_DISP_FAKE0	MTK_M4U_ID(2, 4)

/* LARB 4 -- VDEC */
#define IOMMU_PORT_L4_HW_VDEC_MC_EXT		MTK_M4U_ID(4, 0)
#define IOMMU_PORT_L4_HW_VDEC_UFO_EXT		MTK_M4U_ID(4, 1)
#define IOMMU_PORT_L4_HW_VDEC_PP_EXT		MTK_M4U_ID(4, 2)
#define IOMMU_PORT_L4_HW_VDEC_PRED_RD_EXT	MTK_M4U_ID(4, 3)
#define IOMMU_PORT_L4_HW_VDEC_PRED_WR_EXT	MTK_M4U_ID(4, 4)
#define IOMMU_PORT_L4_HW_VDEC_PPWRAP_EXT	MTK_M4U_ID(4, 5)
#define IOMMU_PORT_L4_HW_VDEC_TILE_EXT		MTK_M4U_ID(4, 6)
#define IOMMU_PORT_L4_HW_VDEC_VLD_EXT		MTK_M4U_ID(4, 7)
#define IOMMU_PORT_L4_HW_VDEC_VLD2_EXT		MTK_M4U_ID(4, 8)
#define IOMMU_PORT_L4_HW_VDEC_AVC_MV_EXT	MTK_M4U_ID(4, 9)
#define IOMMU_PORT_L4_HW_VDEC_UFO_ENC_EXT	MTK_M4U_ID(4, 10)
#define IOMMU_PORT_L4_HW_VDEC_RG_CTRL_DMA_EXT	MTK_M4U_ID(4, 11)
#define IOMMU_PORT_L4_HW_MINI_MDP_R0_EXT	MTK_M4U_ID(4, 12)
#define IOMMU_PORT_L4_HW_MINI_MDP_W0_EXT	MTK_M4U_ID(4, 13)

/* LARB 7 -- VENC */
#define IOMMU_PORT_L7_VENC_RCPU		MTK_M4U_ID(7, 0)
#define IOMMU_PORT_L7_VENC_REC		MTK_M4U_ID(7, 1)
#define IOMMU_PORT_L7_VENC_BSDMA	MTK_M4U_ID(7, 2)
#define IOMMU_PORT_L7_VENC_SV_COMV	MTK_M4U_ID(7, 3)
#define IOMMU_PORT_L7_VENC_RD_COMV	MTK_M4U_ID(7, 4)
#define IOMMU_PORT_L7_VENC_CUR_LUMA	MTK_M4U_ID(7, 5)
#define IOMMU_PORT_L7_VENC_CUR_CHROMA	MTK_M4U_ID(7, 6)
#define IOMMU_PORT_L7_VENC_REF_LUMA	MTK_M4U_ID(7, 7)
#define IOMMU_PORT_L7_VENC_REF_CHROMA	MTK_M4U_ID(7, 8)
#define IOMMU_PORT_L7_JPGENC_Y_RDMA	MTK_M4U_ID(7, 9)
#define IOMMU_PORT_L7_JPGENC_C_RDMA	MTK_M4U_ID(7, 10)
#define IOMMU_PORT_L7_JPGENC_Q_TABLE	MTK_M4U_ID(7, 11)
#define IOMMU_PORT_L7_JPGENC_BSDMA	MTK_M4U_ID(7, 12)

/* LARB 8 -- WPE */
#define IOMMU_PORT_L8_WPE_RDMA_0	MTK_M4U_ID(8, 0)
#define IOMMU_PORT_L8_WPE_RDMA_1	MTK_M4U_ID(8, 1)
#define IOMMU_PORT_L8_WPE_WDMA_0	MTK_M4U_ID(8, 2)

/* LARB 9 -- IMG-1 */
#define IOMMU_PORT_L9_IMG_IMGI_D1	MTK_M4U_ID(9, 0)
#define IOMMU_PORT_L9_IMG_IMGBI_D1	MTK_M4U_ID(9, 1)
#define IOMMU_PORT_L9_IMG_DMGI_D1	MTK_M4U_ID(9, 2)
#define IOMMU_PORT_L9_IMG_DEPI_D1	MTK_M4U_ID(9, 3)
#define IOMMU_PORT_L9_IMG_LCE_D1	MTK_M4U_ID(9, 4)
#define IOMMU_PORT_L9_IMG_SMTI_D1	MTK_M4U_ID(9, 5)
#define IOMMU_PORT_L9_IMG_SMTO_D2	MTK_M4U_ID(9, 6)
#define IOMMU_PORT_L9_IMG_SMTO_D1	MTK_M4U_ID(9, 7)
#define IOMMU_PORT_L9_IMG_CRZO_D1	MTK_M4U_ID(9, 8)
#define IOMMU_PORT_L9_IMG_IMG3O_D1	MTK_M4U_ID(9, 9)
#define IOMMU_PORT_L9_IMG_VIPI_D1	MTK_M4U_ID(9, 10)
#define IOMMU_PORT_L9_IMG_SMTI_D5	MTK_M4U_ID(9, 11)
#define IOMMU_PORT_L9_IMG_TIMGO_D1	MTK_M4U_ID(9, 12)
#define IOMMU_PORT_L9_IMG_UFBC_W0	MTK_M4U_ID(9, 13)
#define IOMMU_PORT_L9_IMG_UFBC_R0	MTK_M4U_ID(9, 14)
#define IOMMU_PORT_L9_IMG_WPE_RDMA1	MTK_M4U_ID(9, 15)
#define IOMMU_PORT_L9_IMG_WPE_RDMA0	MTK_M4U_ID(9, 16)
#define IOMMU_PORT_L9_IMG_WPE_WDMA	MTK_M4U_ID(9, 17)
#define IOMMU_PORT_L9_IMG_MFB_RDMA0	MTK_M4U_ID(9, 18)
#define IOMMU_PORT_L9_IMG_MFB_RDMA1	MTK_M4U_ID(9, 19)
#define IOMMU_PORT_L9_IMG_MFB_RDMA2	MTK_M4U_ID(9, 20)
#define IOMMU_PORT_L9_IMG_MFB_RDMA3	MTK_M4U_ID(9, 21)
#define IOMMU_PORT_L9_IMG_MFB_RDMA4	MTK_M4U_ID(9, 22)
#define IOMMU_PORT_L9_IMG_MFB_RDMA5	MTK_M4U_ID(9, 23)
#define IOMMU_PORT_L9_IMG_MFB_WDMA0	MTK_M4U_ID(9, 24)
#define IOMMU_PORT_L9_IMG_MFB_WDMA1	MTK_M4U_ID(9, 25)
#define IOMMU_PORT_L9_IMG_RESERVE6	MTK_M4U_ID(9, 26)
#define IOMMU_PORT_L9_IMG_RESERVE7	MTK_M4U_ID(9, 27)
#define IOMMU_PORT_L9_IMG_RESERVE8	MTK_M4U_ID(9, 28)

/* LARB 11 -- IMG-2 */
#define IOMMU_PORT_L11_IMG_IMGI_D1	MTK_M4U_ID(11, 0)
#define IOMMU_PORT_L11_IMG_IMGBI_D1	MTK_M4U_ID(11, 1)
#define IOMMU_PORT_L11_IMG_DMGI_D1	MTK_M4U_ID(11, 2)
#define IOMMU_PORT_L11_IMG_DEPI_D1	MTK_M4U_ID(11, 3)
#define IOMMU_PORT_L11_IMG_LCE_D1	MTK_M4U_ID(11, 4)
#define IOMMU_PORT_L11_IMG_SMTI_D1	MTK_M4U_ID(11, 5)
#define IOMMU_PORT_L11_IMG_SMTO_D2	MTK_M4U_ID(11, 6)
#define IOMMU_PORT_L11_IMG_SMTO_D1	MTK_M4U_ID(11, 7)
#define IOMMU_PORT_L11_IMG_CRZO_D1	MTK_M4U_ID(11, 8)
#define IOMMU_PORT_L11_IMG_IMG3O_D1	MTK_M4U_ID(11, 9)
#define IOMMU_PORT_L11_IMG_VIPI_D1	MTK_M4U_ID(11, 10)
#define IOMMU_PORT_L11_IMG_SMTI_D5	MTK_M4U_ID(11, 11)
#define IOMMU_PORT_L11_IMG_TIMGO_D1	MTK_M4U_ID(11, 12)
#define IOMMU_PORT_L11_IMG_UFBC_W0	MTK_M4U_ID(11, 13)
#define IOMMU_PORT_L11_IMG_UFBC_R0	MTK_M4U_ID(11, 14)
#define IOMMU_PORT_L11_IMG_WPE_RDMA1	MTK_M4U_ID(11, 15)
#define IOMMU_PORT_L11_IMG_WPE_RDMA0	MTK_M4U_ID(11, 16)
#define IOMMU_PORT_L11_IMG_WPE_WDMA	MTK_M4U_ID(11, 17)
#define IOMMU_PORT_L11_IMG_MFB_RDMA0	MTK_M4U_ID(11, 18)
#define IOMMU_PORT_L11_IMG_MFB_RDMA1	MTK_M4U_ID(11, 19)
#define IOMMU_PORT_L11_IMG_MFB_RDMA2	MTK_M4U_ID(11, 20)
#define IOMMU_PORT_L11_IMG_MFB_RDMA3	MTK_M4U_ID(11, 21)
#define IOMMU_PORT_L11_IMG_MFB_RDMA4	MTK_M4U_ID(11, 22)
#define IOMMU_PORT_L11_IMG_MFB_RDMA5	MTK_M4U_ID(11, 23)
#define IOMMU_PORT_L11_IMG_MFB_WDMA0	MTK_M4U_ID(11, 24)
#define IOMMU_PORT_L11_IMG_MFB_WDMA1	MTK_M4U_ID(11, 25)
#define IOMMU_PORT_L11_IMG_RESERVE6	MTK_M4U_ID(11, 26)
#define IOMMU_PORT_L11_IMG_RESERVE7	MTK_M4U_ID(11, 27)
#define IOMMU_PORT_L11_IMG_RESERVE8	MTK_M4U_ID(11, 28)

/* LARB 13 -- CAM */
#define IOMMU_PORT_L13_CAM_MRAWI	MTK_M4U_ID(13, 0)
#define IOMMU_PORT_L13_CAM_MRAWO_0	MTK_M4U_ID(13, 1)
#define IOMMU_PORT_L13_CAM_MRAWO_1	MTK_M4U_ID(13, 2)
#define IOMMU_PORT_L13_CAM_CAMSV_4	MTK_M4U_ID(13, 6)
#define IOMMU_PORT_L13_CAM_CAMSV_5	MTK_M4U_ID(13, 7)
#define IOMMU_PORT_L13_CAM_CAMSV_6	MTK_M4U_ID(13, 8)
#define IOMMU_PORT_L13_CAM_CCUI		MTK_M4U_ID(13, 9)
#define IOMMU_PORT_L13_CAM_CCUO		MTK_M4U_ID(13, 10)
#define IOMMU_PORT_L13_CAM_FAKE		MTK_M4U_ID(13, 11)

/* LARB 14 -- CAM */
#define IOMMU_PORT_L14_CAM_CCUI		MTK_M4U_ID(14, 4)
#define IOMMU_PORT_L14_CAM_CCUO		MTK_M4U_ID(14, 5)

/* LARB 16 -- RAW-A */
#define IOMMU_PORT_L16_CAM_IMGO_R1_A	MTK_M4U_ID(16, 0)
#define IOMMU_PORT_L16_CAM_RRZO_R1_A	MTK_M4U_ID(16, 1)
#define IOMMU_PORT_L16_CAM_CQI_R1_A	MTK_M4U_ID(16, 2)
#define IOMMU_PORT_L16_CAM_BPCI_R1_A	MTK_M4U_ID(16, 3)
#define IOMMU_PORT_L16_CAM_YUVO_R1_A	MTK_M4U_ID(16, 4)
#define IOMMU_PORT_L16_CAM_UFDI_R2_A	MTK_M4U_ID(16, 5)
#define IOMMU_PORT_L16_CAM_RAWI_R2_A	MTK_M4U_ID(16, 6)
#define IOMMU_PORT_L16_CAM_RAWI_R3_A	MTK_M4U_ID(16, 7)
#define IOMMU_PORT_L16_CAM_AAO_R1_A	MTK_M4U_ID(16, 8)
#define IOMMU_PORT_L16_CAM_AFO_R1_A	MTK_M4U_ID(16, 9)
#define IOMMU_PORT_L16_CAM_FLKO_R1_A	MTK_M4U_ID(16, 10)
#define IOMMU_PORT_L16_CAM_LCESO_R1_A	MTK_M4U_ID(16, 11)
#define IOMMU_PORT_L16_CAM_CRZO_R1_A	MTK_M4U_ID(16, 12)
#define IOMMU_PORT_L16_CAM_LTMSO_R1_A	MTK_M4U_ID(16, 13)
#define IOMMU_PORT_L16_CAM_RSSO_R1_A	MTK_M4U_ID(16, 14)
#define IOMMU_PORT_L16_CAM_AAHO_R1_A	MTK_M4U_ID(16, 15)
#define IOMMU_PORT_L16_CAM_LSCI_R1_A	MTK_M4U_ID(16, 16)

/* LARB 17 -- RAW-B */
#define IOMMU_PORT_L17_CAM_IMGO_R1_B	MTK_M4U_ID(17, 0)
#define IOMMU_PORT_L17_CAM_RRZO_R1_B	MTK_M4U_ID(17, 1)
#define IOMMU_PORT_L17_CAM_CQI_R1_B	MTK_M4U_ID(17, 2)
#define IOMMU_PORT_L17_CAM_BPCI_R1_B	MTK_M4U_ID(17, 3)
#define IOMMU_PORT_L17_CAM_YUVO_R1_B	MTK_M4U_ID(17, 4)
#define IOMMU_PORT_L17_CAM_UFDI_R2_B	MTK_M4U_ID(17, 5)
#define IOMMU_PORT_L17_CAM_RAWI_R2_B	MTK_M4U_ID(17, 6)
#define IOMMU_PORT_L17_CAM_RAWI_R3_B	MTK_M4U_ID(17, 7)
#define IOMMU_PORT_L17_CAM_AAO_R1_B	MTK_M4U_ID(17, 8)
#define IOMMU_PORT_L17_CAM_AFO_R1_B	MTK_M4U_ID(17, 9)
#define IOMMU_PORT_L17_CAM_FLKO_R1_B	MTK_M4U_ID(17, 10)
#define IOMMU_PORT_L17_CAM_LCESO_R1_B	MTK_M4U_ID(17, 11)
#define IOMMU_PORT_L17_CAM_CRZO_R1_B	MTK_M4U_ID(17, 12)
#define IOMMU_PORT_L17_CAM_LTMSO_R1_B	MTK_M4U_ID(17, 13)
#define IOMMU_PORT_L17_CAM_RSSO_R1_B	MTK_M4U_ID(17, 14)
#define IOMMU_PORT_L17_CAM_AAHO_R1_B	MTK_M4U_ID(17, 15)
#define IOMMU_PORT_L17_CAM_LSCI_R1_B	MTK_M4U_ID(17, 16)

/* LARB 19 -- IPE */
#define IOMMU_PORT_L19_IPE_DVS_RDMA	MTK_M4U_ID(19, 0)
#define IOMMU_PORT_L19_IPE_DVS_WDMA	MTK_M4U_ID(19, 1)
#define IOMMU_PORT_L19_IPE_DVP_RDMA	MTK_M4U_ID(19, 2)
#define IOMMU_PORT_L19_IPE_DVP_WDMA	MTK_M4U_ID(19, 3)

/* LARB 20 -- IPE */
#define IOMMU_PORT_L20_IPE_FDVT_RDA	MTK_M4U_ID(20, 0)
#define IOMMU_PORT_L20_IPE_FDVT_RDB	MTK_M4U_ID(20, 1)
#define IOMMU_PORT_L20_IPE_FDVT_WRA	MTK_M4U_ID(20, 2)
#define IOMMU_PORT_L20_IPE_FDVT_WRB	MTK_M4U_ID(20, 3)
#define IOMMU_PORT_L20_IPE_RSC_RDMA0	MTK_M4U_ID(20, 4)
#define IOMMU_PORT_L20_IPE_RSC_WDMA	MTK_M4U_ID(20, 5)

#endif