Commit | Line | Data |
---|---|---|
26e0ca22 LP |
1 | /* |
2 | * vsp1_regs.h -- R-Car VSP1 Registers Definitions | |
3 | * | |
4 | * Copyright (C) 2013 Renesas Electronics Corporation | |
5 | * | |
6 | * Contact: Laurent Pinchart (laurent.pinchart@ideasonboard.com) | |
7 | * | |
8 | * This program is free software; you can redistribute it and/or modify | |
9 | * it under the terms of the GNU General Public License version 2 | |
10 | * as published by the Free Software Foundation. | |
11 | */ | |
12 | ||
13 | #ifndef __VSP1_REGS_H__ | |
14 | #define __VSP1_REGS_H__ | |
15 | ||
16 | /* ----------------------------------------------------------------------------- | |
17 | * General Control Registers | |
18 | */ | |
19 | ||
20 | #define VI6_CMD(n) (0x0000 + (n) * 4) | |
21 | #define VI6_CMD_STRCMD (1 << 0) | |
22 | ||
23 | #define VI6_CLK_DCSWT 0x0018 | |
24 | #define VI6_CLK_DCSWT_CSTPW_MASK (0xff << 8) | |
25 | #define VI6_CLK_DCSWT_CSTPW_SHIFT 8 | |
26 | #define VI6_CLK_DCSWT_CSTRW_MASK (0xff << 0) | |
27 | #define VI6_CLK_DCSWT_CSTRW_SHIFT 0 | |
28 | ||
29 | #define VI6_SRESET 0x0028 | |
30 | #define VI6_SRESET_SRTS(n) (1 << (n)) | |
31 | ||
32 | #define VI6_STATUS 0x0038 | |
33 | #define VI6_STATUS_SYS_ACT(n) (1 << ((n) + 8)) | |
34 | ||
35 | #define VI6_WPF_IRQ_ENB(n) (0x0048 + (n) * 12) | |
36 | #define VI6_WFP_IRQ_ENB_DFEE (1 << 1) | |
37 | #define VI6_WFP_IRQ_ENB_FREE (1 << 0) | |
38 | ||
39 | #define VI6_WPF_IRQ_STA(n) (0x004c + (n) * 12) | |
40 | #define VI6_WFP_IRQ_STA_DFE (1 << 1) | |
41 | #define VI6_WFP_IRQ_STA_FRE (1 << 0) | |
42 | ||
43 | #define VI6_DISP_IRQ_ENB 0x0078 | |
44 | #define VI6_DISP_IRQ_ENB_DSTE (1 << 8) | |
45 | #define VI6_DISP_IRQ_ENB_MAEE (1 << 5) | |
59a7954c | 46 | #define VI6_DISP_IRQ_ENB_LNEE(n) (1 << (n)) |
26e0ca22 LP |
47 | |
48 | #define VI6_DISP_IRQ_STA 0x007c | |
49 | #define VI6_DISP_IRQ_STA_DSE (1 << 8) | |
50 | #define VI6_DISP_IRQ_STA_MAE (1 << 5) | |
533ab223 | 51 | #define VI6_DISP_IRQ_STA_LNE(n) (1 << (n)) |
26e0ca22 LP |
52 | |
53 | #define VI6_WPF_LINE_COUNT(n) (0x0084 + (n) * 4) | |
54 | #define VI6_WPF_LINE_COUNT_MASK (0x1fffff << 0) | |
55 | ||
56 | /* ----------------------------------------------------------------------------- | |
57 | * Display List Control Registers | |
58 | */ | |
59 | ||
60 | #define VI6_DL_CTRL 0x0100 | |
61 | #define VI6_DL_CTRL_AR_WAIT_MASK (0xffff << 16) | |
62 | #define VI6_DL_CTRL_AR_WAIT_SHIFT 16 | |
63 | #define VI6_DL_CTRL_DC2 (1 << 12) | |
64 | #define VI6_DL_CTRL_DC1 (1 << 8) | |
65 | #define VI6_DL_CTRL_DC0 (1 << 4) | |
66 | #define VI6_DL_CTRL_CFM0 (1 << 2) | |
67 | #define VI6_DL_CTRL_NH0 (1 << 1) | |
68 | #define VI6_DL_CTRL_DLE (1 << 0) | |
69 | ||
70 | #define VI6_DL_HDR_ADDR(n) (0x0104 + (n) * 4) | |
71 | ||
72 | #define VI6_DL_SWAP 0x0114 | |
73 | #define VI6_DL_SWAP_LWS (1 << 2) | |
74 | #define VI6_DL_SWAP_WDS (1 << 1) | |
75 | #define VI6_DL_SWAP_BTS (1 << 0) | |
76 | ||
77 | #define VI6_DL_EXT_CTRL 0x011c | |
78 | #define VI6_DL_EXT_CTRL_NWE (1 << 16) | |
79 | #define VI6_DL_EXT_CTRL_POLINT_MASK (0x3f << 8) | |
80 | #define VI6_DL_EXT_CTRL_POLINT_SHIFT 8 | |
81 | #define VI6_DL_EXT_CTRL_DLPRI (1 << 5) | |
82 | #define VI6_DL_EXT_CTRL_EXPRI (1 << 4) | |
83 | #define VI6_DL_EXT_CTRL_EXT (1 << 0) | |
84 | ||
85 | #define VI6_DL_BODY_SIZE 0x0120 | |
86 | #define VI6_DL_BODY_SIZE_UPD (1 << 24) | |
87 | #define VI6_DL_BODY_SIZE_BS_MASK (0x1ffff << 0) | |
88 | #define VI6_DL_BODY_SIZE_BS_SHIFT 0 | |
89 | ||
90 | /* ----------------------------------------------------------------------------- | |
91 | * RPF Control Registers | |
92 | */ | |
93 | ||
94 | #define VI6_RPF_OFFSET 0x100 | |
95 | ||
96 | #define VI6_RPF_SRC_BSIZE 0x0300 | |
97 | #define VI6_RPF_SRC_BSIZE_BHSIZE_MASK (0x1fff << 16) | |
98 | #define VI6_RPF_SRC_BSIZE_BHSIZE_SHIFT 16 | |
99 | #define VI6_RPF_SRC_BSIZE_BVSIZE_MASK (0x1fff << 0) | |
100 | #define VI6_RPF_SRC_BSIZE_BVSIZE_SHIFT 0 | |
101 | ||
102 | #define VI6_RPF_SRC_ESIZE 0x0304 | |
103 | #define VI6_RPF_SRC_ESIZE_EHSIZE_MASK (0x1fff << 16) | |
104 | #define VI6_RPF_SRC_ESIZE_EHSIZE_SHIFT 16 | |
105 | #define VI6_RPF_SRC_ESIZE_EVSIZE_MASK (0x1fff << 0) | |
106 | #define VI6_RPF_SRC_ESIZE_EVSIZE_SHIFT 0 | |
107 | ||
108 | #define VI6_RPF_INFMT 0x0308 | |
109 | #define VI6_RPF_INFMT_VIR (1 << 28) | |
110 | #define VI6_RPF_INFMT_CIPM (1 << 16) | |
111 | #define VI6_RPF_INFMT_SPYCS (1 << 15) | |
112 | #define VI6_RPF_INFMT_SPUVS (1 << 14) | |
113 | #define VI6_RPF_INFMT_CEXT_ZERO (0 << 12) | |
114 | #define VI6_RPF_INFMT_CEXT_EXT (1 << 12) | |
115 | #define VI6_RPF_INFMT_CEXT_ONE (2 << 12) | |
116 | #define VI6_RPF_INFMT_CEXT_MASK (3 << 12) | |
117 | #define VI6_RPF_INFMT_RDTM_BT601 (0 << 9) | |
118 | #define VI6_RPF_INFMT_RDTM_BT601_EXT (1 << 9) | |
119 | #define VI6_RPF_INFMT_RDTM_BT709 (2 << 9) | |
120 | #define VI6_RPF_INFMT_RDTM_BT709_EXT (3 << 9) | |
121 | #define VI6_RPF_INFMT_RDTM_MASK (7 << 9) | |
122 | #define VI6_RPF_INFMT_CSC (1 << 8) | |
123 | #define VI6_RPF_INFMT_RDFMT_MASK (0x7f << 0) | |
124 | #define VI6_RPF_INFMT_RDFMT_SHIFT 0 | |
125 | ||
126 | #define VI6_RPF_DSWAP 0x030c | |
127 | #define VI6_RPF_DSWAP_A_LLS (1 << 11) | |
128 | #define VI6_RPF_DSWAP_A_LWS (1 << 10) | |
129 | #define VI6_RPF_DSWAP_A_WDS (1 << 9) | |
130 | #define VI6_RPF_DSWAP_A_BTS (1 << 8) | |
131 | #define VI6_RPF_DSWAP_P_LLS (1 << 3) | |
132 | #define VI6_RPF_DSWAP_P_LWS (1 << 2) | |
133 | #define VI6_RPF_DSWAP_P_WDS (1 << 1) | |
134 | #define VI6_RPF_DSWAP_P_BTS (1 << 0) | |
135 | ||
136 | #define VI6_RPF_LOC 0x0310 | |
137 | #define VI6_RPF_LOC_HCOORD_MASK (0x1fff << 16) | |
138 | #define VI6_RPF_LOC_HCOORD_SHIFT 16 | |
139 | #define VI6_RPF_LOC_VCOORD_MASK (0x1fff << 0) | |
140 | #define VI6_RPF_LOC_VCOORD_SHIFT 0 | |
141 | ||
142 | #define VI6_RPF_ALPH_SEL 0x0314 | |
143 | #define VI6_RPF_ALPH_SEL_ASEL_PACKED (0 << 28) | |
144 | #define VI6_RPF_ALPH_SEL_ASEL_8B_PLANE (1 << 28) | |
145 | #define VI6_RPF_ALPH_SEL_ASEL_SELECT (2 << 28) | |
146 | #define VI6_RPF_ALPH_SEL_ASEL_1B_PLANE (3 << 28) | |
147 | #define VI6_RPF_ALPH_SEL_ASEL_FIXED (4 << 28) | |
148 | #define VI6_RPF_ALPH_SEL_ASEL_MASK (7 << 28) | |
149 | #define VI6_RPF_ALPH_SEL_ASEL_SHIFT 28 | |
150 | #define VI6_RPF_ALPH_SEL_IROP_MASK (0xf << 24) | |
151 | #define VI6_RPF_ALPH_SEL_IROP_SHIFT 24 | |
152 | #define VI6_RPF_ALPH_SEL_BSEL (1 << 23) | |
153 | #define VI6_RPF_ALPH_SEL_AEXT_ZERO (0 << 18) | |
154 | #define VI6_RPF_ALPH_SEL_AEXT_EXT (1 << 18) | |
155 | #define VI6_RPF_ALPH_SEL_AEXT_ONE (2 << 18) | |
156 | #define VI6_RPF_ALPH_SEL_AEXT_MASK (3 << 18) | |
157 | #define VI6_RPF_ALPH_SEL_ALPHA0_MASK (0xff << 8) | |
158 | #define VI6_RPF_ALPH_SEL_ALPHA0_SHIFT 8 | |
159 | #define VI6_RPF_ALPH_SEL_ALPHA1_MASK (0xff << 0) | |
160 | #define VI6_RPF_ALPH_SEL_ALPHA1_SHIFT 0 | |
161 | ||
162 | #define VI6_RPF_VRTCOL_SET 0x0318 | |
163 | #define VI6_RPF_VRTCOL_SET_LAYA_MASK (0xff << 24) | |
164 | #define VI6_RPF_VRTCOL_SET_LAYA_SHIFT 24 | |
165 | #define VI6_RPF_VRTCOL_SET_LAYR_MASK (0xff << 16) | |
166 | #define VI6_RPF_VRTCOL_SET_LAYR_SHIFT 16 | |
167 | #define VI6_RPF_VRTCOL_SET_LAYG_MASK (0xff << 8) | |
168 | #define VI6_RPF_VRTCOL_SET_LAYG_SHIFT 8 | |
169 | #define VI6_RPF_VRTCOL_SET_LAYB_MASK (0xff << 0) | |
170 | #define VI6_RPF_VRTCOL_SET_LAYB_SHIFT 0 | |
171 | ||
172 | #define VI6_RPF_MSK_CTRL 0x031c | |
173 | #define VI6_RPF_MSK_CTRL_MSK_EN (1 << 24) | |
174 | #define VI6_RPF_MSK_CTRL_MGR_MASK (0xff << 16) | |
175 | #define VI6_RPF_MSK_CTRL_MGR_SHIFT 16 | |
176 | #define VI6_RPF_MSK_CTRL_MGG_MASK (0xff << 8) | |
177 | #define VI6_RPF_MSK_CTRL_MGG_SHIFT 8 | |
178 | #define VI6_RPF_MSK_CTRL_MGB_MASK (0xff << 0) | |
179 | #define VI6_RPF_MSK_CTRL_MGB_SHIFT 0 | |
180 | ||
181 | #define VI6_RPF_MSK_SET0 0x0320 | |
182 | #define VI6_RPF_MSK_SET1 0x0324 | |
183 | #define VI6_RPF_MSK_SET_MSA_MASK (0xff << 24) | |
184 | #define VI6_RPF_MSK_SET_MSA_SHIFT 24 | |
185 | #define VI6_RPF_MSK_SET_MSR_MASK (0xff << 16) | |
186 | #define VI6_RPF_MSK_SET_MSR_SHIFT 16 | |
187 | #define VI6_RPF_MSK_SET_MSG_MASK (0xff << 8) | |
188 | #define VI6_RPF_MSK_SET_MSG_SHIFT 8 | |
189 | #define VI6_RPF_MSK_SET_MSB_MASK (0xff << 0) | |
190 | #define VI6_RPF_MSK_SET_MSB_SHIFT 0 | |
191 | ||
192 | #define VI6_RPF_CKEY_CTRL 0x0328 | |
193 | #define VI6_RPF_CKEY_CTRL_CV (1 << 4) | |
194 | #define VI6_RPF_CKEY_CTRL_SAPE1 (1 << 1) | |
195 | #define VI6_RPF_CKEY_CTRL_SAPE0 (1 << 0) | |
196 | ||
197 | #define VI6_RPF_CKEY_SET0 0x032c | |
198 | #define VI6_RPF_CKEY_SET1 0x0330 | |
199 | #define VI6_RPF_CKEY_SET_AP_MASK (0xff << 24) | |
200 | #define VI6_RPF_CKEY_SET_AP_SHIFT 24 | |
201 | #define VI6_RPF_CKEY_SET_R_MASK (0xff << 16) | |
202 | #define VI6_RPF_CKEY_SET_R_SHIFT 16 | |
203 | #define VI6_RPF_CKEY_SET_GY_MASK (0xff << 8) | |
204 | #define VI6_RPF_CKEY_SET_GY_SHIFT 8 | |
205 | #define VI6_RPF_CKEY_SET_B_MASK (0xff << 0) | |
206 | #define VI6_RPF_CKEY_SET_B_SHIFT 0 | |
207 | ||
208 | #define VI6_RPF_SRCM_PSTRIDE 0x0334 | |
209 | #define VI6_RPF_SRCM_PSTRIDE_Y_SHIFT 16 | |
210 | #define VI6_RPF_SRCM_PSTRIDE_C_SHIFT 0 | |
211 | ||
212 | #define VI6_RPF_SRCM_ASTRIDE 0x0338 | |
213 | #define VI6_RPF_SRCM_PSTRIDE_A_SHIFT 0 | |
214 | ||
215 | #define VI6_RPF_SRCM_ADDR_Y 0x033c | |
216 | #define VI6_RPF_SRCM_ADDR_C0 0x0340 | |
217 | #define VI6_RPF_SRCM_ADDR_C1 0x0344 | |
218 | #define VI6_RPF_SRCM_ADDR_AI 0x0348 | |
219 | ||
220 | /* ----------------------------------------------------------------------------- | |
221 | * WPF Control Registers | |
222 | */ | |
223 | ||
224 | #define VI6_WPF_OFFSET 0x100 | |
225 | ||
226 | #define VI6_WPF_SRCRPF 0x1000 | |
227 | #define VI6_WPF_SRCRPF_VIRACT_DIS (0 << 28) | |
228 | #define VI6_WPF_SRCRPF_VIRACT_SUB (1 << 28) | |
229 | #define VI6_WPF_SRCRPF_VIRACT_MST (2 << 28) | |
230 | #define VI6_WPF_SRCRPF_VIRACT_MASK (3 << 28) | |
231 | #define VI6_WPF_SRCRPF_RPF_ACT_DIS(n) (0 << ((n) * 2)) | |
232 | #define VI6_WPF_SRCRPF_RPF_ACT_SUB(n) (1 << ((n) * 2)) | |
233 | #define VI6_WPF_SRCRPF_RPF_ACT_MST(n) (2 << ((n) * 2)) | |
234 | #define VI6_WPF_SRCRPF_RPF_ACT_MASK(n) (3 << ((n) * 2)) | |
235 | ||
236 | #define VI6_WPF_HSZCLIP 0x1004 | |
237 | #define VI6_WPF_VSZCLIP 0x1008 | |
238 | #define VI6_WPF_SZCLIP_EN (1 << 28) | |
239 | #define VI6_WPF_SZCLIP_OFST_MASK (0xff << 16) | |
240 | #define VI6_WPF_SZCLIP_OFST_SHIFT 16 | |
241 | #define VI6_WPF_SZCLIP_SIZE_MASK (0x1fff << 0) | |
242 | #define VI6_WPF_SZCLIP_SIZE_SHIFT 0 | |
243 | ||
244 | #define VI6_WPF_OUTFMT 0x100c | |
245 | #define VI6_WPF_OUTFMT_PDV_MASK (0xff << 24) | |
246 | #define VI6_WPF_OUTFMT_PDV_SHIFT 24 | |
247 | #define VI6_WPF_OUTFMT_PXA (1 << 23) | |
248 | #define VI6_WPF_OUTFMT_FLP (1 << 16) | |
249 | #define VI6_WPF_OUTFMT_SPYCS (1 << 15) | |
250 | #define VI6_WPF_OUTFMT_SPUVS (1 << 14) | |
251 | #define VI6_WPF_OUTFMT_DITH_DIS (0 << 12) | |
252 | #define VI6_WPF_OUTFMT_DITH_EN (3 << 12) | |
253 | #define VI6_WPF_OUTFMT_DITH_MASK (3 << 12) | |
254 | #define VI6_WPF_OUTFMT_WRTM_BT601 (0 << 9) | |
255 | #define VI6_WPF_OUTFMT_WRTM_BT601_EXT (1 << 9) | |
256 | #define VI6_WPF_OUTFMT_WRTM_BT709 (2 << 9) | |
257 | #define VI6_WPF_OUTFMT_WRTM_BT709_EXT (3 << 9) | |
258 | #define VI6_WPF_OUTFMT_WRTM_MASK (7 << 9) | |
259 | #define VI6_WPF_OUTFMT_CSC (1 << 8) | |
260 | #define VI6_WPF_OUTFMT_WRFMT_MASK (0x7f << 0) | |
261 | #define VI6_WPF_OUTFMT_WRFMT_SHIFT 0 | |
262 | ||
263 | #define VI6_WPF_DSWAP 0x1010 | |
264 | #define VI6_WPF_DSWAP_P_LLS (1 << 3) | |
265 | #define VI6_WPF_DSWAP_P_LWS (1 << 2) | |
266 | #define VI6_WPF_DSWAP_P_WDS (1 << 1) | |
267 | #define VI6_WPF_DSWAP_P_BTS (1 << 0) | |
268 | ||
269 | #define VI6_WPF_RNDCTRL 0x1014 | |
270 | #define VI6_WPF_RNDCTRL_CBRM (1 << 28) | |
271 | #define VI6_WPF_RNDCTRL_ABRM_TRUNC (0 << 24) | |
272 | #define VI6_WPF_RNDCTRL_ABRM_ROUND (1 << 24) | |
273 | #define VI6_WPF_RNDCTRL_ABRM_THRESH (2 << 24) | |
274 | #define VI6_WPF_RNDCTRL_ABRM_MASK (3 << 24) | |
275 | #define VI6_WPF_RNDCTRL_ATHRESH_MASK (0xff << 16) | |
276 | #define VI6_WPF_RNDCTRL_ATHRESH_SHIFT 16 | |
277 | #define VI6_WPF_RNDCTRL_CLMD_FULL (0 << 12) | |
278 | #define VI6_WPF_RNDCTRL_CLMD_CLIP (1 << 12) | |
279 | #define VI6_WPF_RNDCTRL_CLMD_EXT (2 << 12) | |
280 | #define VI6_WPF_RNDCTRL_CLMD_MASK (3 << 12) | |
281 | ||
282 | #define VI6_WPF_DSTM_STRIDE_Y 0x101c | |
283 | #define VI6_WPF_DSTM_STRIDE_C 0x1020 | |
284 | #define VI6_WPF_DSTM_ADDR_Y 0x1024 | |
285 | #define VI6_WPF_DSTM_ADDR_C0 0x1028 | |
286 | #define VI6_WPF_DSTM_ADDR_C1 0x102c | |
287 | ||
288 | #define VI6_WPF_WRBCK_CTRL 0x1034 | |
289 | #define VI6_WPF_WRBCK_CTRL_WBMD (1 << 0) | |
290 | ||
291 | /* ----------------------------------------------------------------------------- | |
292 | * DPR Control Registers | |
293 | */ | |
294 | ||
295 | #define VI6_DPR_RPF_ROUTE(n) (0x2000 + (n) * 4) | |
296 | ||
297 | #define VI6_DPR_WPF_FPORCH(n) (0x2014 + (n) * 4) | |
298 | #define VI6_DPR_WPF_FPORCH_FP_WPFN (5 << 8) | |
299 | ||
300 | #define VI6_DPR_SRU_ROUTE 0x2024 | |
301 | #define VI6_DPR_UDS_ROUTE(n) (0x2028 + (n) * 4) | |
302 | #define VI6_DPR_LUT_ROUTE 0x203c | |
303 | #define VI6_DPR_CLU_ROUTE 0x2040 | |
304 | #define VI6_DPR_HST_ROUTE 0x2044 | |
305 | #define VI6_DPR_HSI_ROUTE 0x2048 | |
306 | #define VI6_DPR_BRU_ROUTE 0x204c | |
307 | #define VI6_DPR_ROUTE_FXA_MASK (0xff << 8) | |
308 | #define VI6_DPR_ROUTE_FXA_SHIFT 16 | |
309 | #define VI6_DPR_ROUTE_FP_MASK (0xff << 8) | |
310 | #define VI6_DPR_ROUTE_FP_SHIFT 8 | |
311 | #define VI6_DPR_ROUTE_RT_MASK (0x3f << 0) | |
312 | #define VI6_DPR_ROUTE_RT_SHIFT 0 | |
313 | ||
314 | #define VI6_DPR_HGO_SMPPT 0x2050 | |
315 | #define VI6_DPR_HGT_SMPPT 0x2054 | |
316 | #define VI6_DPR_SMPPT_TGW_MASK (7 << 8) | |
317 | #define VI6_DPR_SMPPT_TGW_SHIFT 8 | |
318 | #define VI6_DPR_SMPPT_PT_MASK (0x3f << 0) | |
319 | #define VI6_DPR_SMPPT_PT_SHIFT 0 | |
320 | ||
321 | #define VI6_DPR_NODE_RPF(n) (n) | |
322 | #define VI6_DPR_NODE_SRU 16 | |
323 | #define VI6_DPR_NODE_UDS(n) (17 + (n)) | |
324 | #define VI6_DPR_NODE_LUT 22 | |
325 | #define VI6_DPR_NODE_BRU_IN(n) (23 + (n)) | |
326 | #define VI6_DPR_NODE_BRU_OUT 27 | |
327 | #define VI6_DPR_NODE_CLU 29 | |
328 | #define VI6_DPR_NODE_HST 30 | |
329 | #define VI6_DPR_NODE_HSI 31 | |
330 | #define VI6_DPR_NODE_LIF 55 | |
331 | #define VI6_DPR_NODE_WPF(n) (56 + (n)) | |
332 | #define VI6_DPR_NODE_UNUSED 63 | |
333 | ||
334 | /* ----------------------------------------------------------------------------- | |
335 | * SRU Control Registers | |
336 | */ | |
337 | ||
338 | #define VI6_SRU_CTRL0 0x2200 | |
58f896d8 | 339 | #define VI6_SRU_CTRL0_PARAM0_MASK (0x1ff << 16) |
a626e64e | 340 | #define VI6_SRU_CTRL0_PARAM0_SHIFT 16 |
58f896d8 | 341 | #define VI6_SRU_CTRL0_PARAM1_MASK (0x1f << 8) |
a626e64e LP |
342 | #define VI6_SRU_CTRL0_PARAM1_SHIFT 8 |
343 | #define VI6_SRU_CTRL0_MODE_UPSCALE (4 << 4) | |
344 | #define VI6_SRU_CTRL0_PARAM2 (1 << 3) | |
345 | #define VI6_SRU_CTRL0_PARAM3 (1 << 2) | |
346 | #define VI6_SRU_CTRL0_PARAM4 (1 << 1) | |
347 | #define VI6_SRU_CTRL0_EN (1 << 0) | |
348 | ||
26e0ca22 | 349 | #define VI6_SRU_CTRL1 0x2204 |
a626e64e LP |
350 | #define VI6_SRU_CTRL1_PARAM5 0x7ff |
351 | ||
26e0ca22 | 352 | #define VI6_SRU_CTRL2 0x2208 |
a626e64e LP |
353 | #define VI6_SRU_CTRL2_PARAM6_SHIFT 16 |
354 | #define VI6_SRU_CTRL2_PARAM7_SHIFT 8 | |
355 | #define VI6_SRU_CTRL2_PARAM8_SHIFT 0 | |
26e0ca22 LP |
356 | |
357 | /* ----------------------------------------------------------------------------- | |
358 | * UDS Control Registers | |
359 | */ | |
360 | ||
361 | #define VI6_UDS_OFFSET 0x100 | |
362 | ||
363 | #define VI6_UDS_CTRL 0x2300 | |
364 | #define VI6_UDS_CTRL_AMD (1 << 30) | |
365 | #define VI6_UDS_CTRL_FMD (1 << 29) | |
366 | #define VI6_UDS_CTRL_BLADV (1 << 28) | |
367 | #define VI6_UDS_CTRL_AON (1 << 25) | |
368 | #define VI6_UDS_CTRL_ATHON (1 << 24) | |
369 | #define VI6_UDS_CTRL_BC (1 << 20) | |
370 | #define VI6_UDS_CTRL_NE_A (1 << 19) | |
371 | #define VI6_UDS_CTRL_NE_RCR (1 << 18) | |
372 | #define VI6_UDS_CTRL_NE_GY (1 << 17) | |
373 | #define VI6_UDS_CTRL_NE_BCB (1 << 16) | |
374 | #define VI6_UDS_CTRL_TDIPC (1 << 1) | |
375 | ||
376 | #define VI6_UDS_SCALE 0x2304 | |
377 | #define VI6_UDS_SCALE_HMANT_MASK (0xf << 28) | |
378 | #define VI6_UDS_SCALE_HMANT_SHIFT 28 | |
379 | #define VI6_UDS_SCALE_HFRAC_MASK (0xfff << 16) | |
380 | #define VI6_UDS_SCALE_HFRAC_SHIFT 16 | |
381 | #define VI6_UDS_SCALE_VMANT_MASK (0xf << 12) | |
382 | #define VI6_UDS_SCALE_VMANT_SHIFT 12 | |
383 | #define VI6_UDS_SCALE_VFRAC_MASK (0xfff << 0) | |
384 | #define VI6_UDS_SCALE_VFRAC_SHIFT 0 | |
385 | ||
386 | #define VI6_UDS_ALPTH 0x2308 | |
387 | #define VI6_UDS_ALPTH_TH1_MASK (0xff << 8) | |
388 | #define VI6_UDS_ALPTH_TH1_SHIFT 8 | |
389 | #define VI6_UDS_ALPTH_TH0_MASK (0xff << 0) | |
390 | #define VI6_UDS_ALPTH_TH0_SHIFT 0 | |
391 | ||
392 | #define VI6_UDS_ALPVAL 0x230c | |
393 | #define VI6_UDS_ALPVAL_VAL2_MASK (0xff << 16) | |
394 | #define VI6_UDS_ALPVAL_VAL2_SHIFT 16 | |
395 | #define VI6_UDS_ALPVAL_VAL1_MASK (0xff << 8) | |
396 | #define VI6_UDS_ALPVAL_VAL1_SHIFT 8 | |
397 | #define VI6_UDS_ALPVAL_VAL0_MASK (0xff << 0) | |
398 | #define VI6_UDS_ALPVAL_VAL0_SHIFT 0 | |
399 | ||
400 | #define VI6_UDS_PASS_BWIDTH 0x2310 | |
401 | #define VI6_UDS_PASS_BWIDTH_H_MASK (0x7f << 16) | |
402 | #define VI6_UDS_PASS_BWIDTH_H_SHIFT 16 | |
403 | #define VI6_UDS_PASS_BWIDTH_V_MASK (0x7f << 0) | |
404 | #define VI6_UDS_PASS_BWIDTH_V_SHIFT 0 | |
405 | ||
406 | #define VI6_UDS_IPC 0x2318 | |
407 | #define VI6_UDS_IPC_FIELD (1 << 27) | |
408 | #define VI6_UDS_IPC_VEDP_MASK (0xfff << 0) | |
409 | #define VI6_UDS_IPC_VEDP_SHIFT 0 | |
410 | ||
411 | #define VI6_UDS_CLIP_SIZE 0x2324 | |
412 | #define VI6_UDS_CLIP_SIZE_HSIZE_MASK (0x1fff << 16) | |
413 | #define VI6_UDS_CLIP_SIZE_HSIZE_SHIFT 16 | |
414 | #define VI6_UDS_CLIP_SIZE_VSIZE_MASK (0x1fff << 0) | |
415 | #define VI6_UDS_CLIP_SIZE_VSIZE_SHIFT 0 | |
416 | ||
417 | #define VI6_UDS_FILL_COLOR 0x2328 | |
418 | #define VI6_UDS_FILL_COLOR_RFILC_MASK (0xff << 16) | |
419 | #define VI6_UDS_FILL_COLOR_RFILC_SHIFT 16 | |
420 | #define VI6_UDS_FILL_COLOR_GFILC_MASK (0xff << 8) | |
421 | #define VI6_UDS_FILL_COLOR_GFILC_SHIFT 8 | |
422 | #define VI6_UDS_FILL_COLOR_BFILC_MASK (0xff << 0) | |
423 | #define VI6_UDS_FILL_COLOR_BFILC_SHIFT 0 | |
424 | ||
425 | /* ----------------------------------------------------------------------------- | |
426 | * LUT Control Registers | |
427 | */ | |
428 | ||
429 | #define VI6_LUT_CTRL 0x2800 | |
989af883 | 430 | #define VI6_LUT_CTRL_EN (1 << 0) |
26e0ca22 LP |
431 | |
432 | /* ----------------------------------------------------------------------------- | |
433 | * CLU Control Registers | |
434 | */ | |
435 | ||
436 | #define VI6_CLU_CTRL 0x2900 | |
437 | ||
438 | /* ----------------------------------------------------------------------------- | |
439 | * HST Control Registers | |
440 | */ | |
441 | ||
442 | #define VI6_HST_CTRL 0x2a00 | |
5cdf5741 | 443 | #define VI6_HST_CTRL_EN (1 << 0) |
26e0ca22 LP |
444 | |
445 | /* ----------------------------------------------------------------------------- | |
446 | * HSI Control Registers | |
447 | */ | |
448 | ||
449 | #define VI6_HSI_CTRL 0x2b00 | |
5cdf5741 | 450 | #define VI6_HSI_CTRL_EN (1 << 0) |
26e0ca22 LP |
451 | |
452 | /* ----------------------------------------------------------------------------- | |
453 | * BRU Control Registers | |
454 | */ | |
455 | ||
629bb6d4 LP |
456 | #define VI6_ROP_NOP 0 |
457 | #define VI6_ROP_AND 1 | |
458 | #define VI6_ROP_AND_REV 2 | |
459 | #define VI6_ROP_COPY 3 | |
460 | #define VI6_ROP_AND_INV 4 | |
461 | #define VI6_ROP_CLEAR 5 | |
462 | #define VI6_ROP_XOR 6 | |
463 | #define VI6_ROP_OR 7 | |
464 | #define VI6_ROP_NOR 8 | |
465 | #define VI6_ROP_EQUIV 9 | |
466 | #define VI6_ROP_INVERT 10 | |
467 | #define VI6_ROP_OR_REV 11 | |
468 | #define VI6_ROP_COPY_INV 12 | |
469 | #define VI6_ROP_OR_INV 13 | |
470 | #define VI6_ROP_NAND 14 | |
471 | #define VI6_ROP_SET 15 | |
472 | ||
26e0ca22 | 473 | #define VI6_BRU_INCTRL 0x2c00 |
629bb6d4 LP |
474 | #define VI6_BRU_INCTRL_NRM (1 << 28) |
475 | #define VI6_BRU_INCTRL_DnON (1 << (16 + (n))) | |
476 | #define VI6_BRU_INCTRL_DITHn_OFF (0 << ((n) * 4)) | |
477 | #define VI6_BRU_INCTRL_DITHn_18BPP (1 << ((n) * 4)) | |
478 | #define VI6_BRU_INCTRL_DITHn_16BPP (2 << ((n) * 4)) | |
479 | #define VI6_BRU_INCTRL_DITHn_15BPP (3 << ((n) * 4)) | |
480 | #define VI6_BRU_INCTRL_DITHn_12BPP (4 << ((n) * 4)) | |
481 | #define VI6_BRU_INCTRL_DITHn_8BPP (5 << ((n) * 4)) | |
482 | #define VI6_BRU_INCTRL_DITHn_MASK (7 << ((n) * 4)) | |
483 | #define VI6_BRU_INCTRL_DITHn_SHIFT ((n) * 4) | |
484 | ||
26e0ca22 | 485 | #define VI6_BRU_VIRRPF_SIZE 0x2c04 |
629bb6d4 LP |
486 | #define VI6_BRU_VIRRPF_SIZE_HSIZE_MASK (0x1fff << 16) |
487 | #define VI6_BRU_VIRRPF_SIZE_HSIZE_SHIFT 16 | |
488 | #define VI6_BRU_VIRRPF_SIZE_VSIZE_MASK (0x1fff << 0) | |
489 | #define VI6_BRU_VIRRPF_SIZE_VSIZE_SHIFT 0 | |
490 | ||
26e0ca22 | 491 | #define VI6_BRU_VIRRPF_LOC 0x2c08 |
629bb6d4 LP |
492 | #define VI6_BRU_VIRRPF_LOC_HCOORD_MASK (0x1fff << 16) |
493 | #define VI6_BRU_VIRRPF_LOC_HCOORD_SHIFT 16 | |
494 | #define VI6_BRU_VIRRPF_LOC_VCOORD_MASK (0x1fff << 0) | |
495 | #define VI6_BRU_VIRRPF_LOC_VCOORD_SHIFT 0 | |
496 | ||
26e0ca22 | 497 | #define VI6_BRU_VIRRPF_COL 0x2c0c |
629bb6d4 LP |
498 | #define VI6_BRU_VIRRPF_COL_A_MASK (0xff << 24) |
499 | #define VI6_BRU_VIRRPF_COL_A_SHIFT 24 | |
500 | #define VI6_BRU_VIRRPF_COL_RCR_MASK (0xff << 16) | |
501 | #define VI6_BRU_VIRRPF_COL_RCR_SHIFT 16 | |
502 | #define VI6_BRU_VIRRPF_COL_GY_MASK (0xff << 8) | |
503 | #define VI6_BRU_VIRRPF_COL_GY_SHIFT 8 | |
504 | #define VI6_BRU_VIRRPF_COL_BCB_MASK (0xff << 0) | |
505 | #define VI6_BRU_VIRRPF_COL_BCB_SHIFT 0 | |
506 | ||
26e0ca22 | 507 | #define VI6_BRU_CTRL(n) (0x2c10 + (n) * 8) |
629bb6d4 LP |
508 | #define VI6_BRU_CTRL_RBC (1 << 31) |
509 | #define VI6_BRU_CTRL_DSTSEL_BRUIN(n) ((n) << 20) | |
510 | #define VI6_BRU_CTRL_DSTSEL_VRPF (4 << 20) | |
511 | #define VI6_BRU_CTRL_DSTSEL_MASK (7 << 20) | |
512 | #define VI6_BRU_CTRL_SRCSEL_BRUIN(n) ((n) << 16) | |
513 | #define VI6_BRU_CTRL_SRCSEL_VRPF (4 << 16) | |
514 | #define VI6_BRU_CTRL_SRCSEL_MASK (7 << 16) | |
515 | #define VI6_BRU_CTRL_CROP(rop) ((rop) << 4) | |
516 | #define VI6_BRU_CTRL_CROP_MASK (0xf << 4) | |
517 | #define VI6_BRU_CTRL_AROP(rop) ((rop) << 0) | |
518 | #define VI6_BRU_CTRL_AROP_MASK (0xf << 0) | |
519 | ||
26e0ca22 | 520 | #define VI6_BRU_BLD(n) (0x2c14 + (n) * 8) |
629bb6d4 LP |
521 | #define VI6_BRU_BLD_CBES (1 << 31) |
522 | #define VI6_BRU_BLD_CCMDX_DST_A (0 << 28) | |
523 | #define VI6_BRU_BLD_CCMDX_255_DST_A (1 << 28) | |
524 | #define VI6_BRU_BLD_CCMDX_SRC_A (2 << 28) | |
525 | #define VI6_BRU_BLD_CCMDX_255_SRC_A (3 << 28) | |
526 | #define VI6_BRU_BLD_CCMDX_COEFX (4 << 28) | |
527 | #define VI6_BRU_BLD_CCMDX_MASK (7 << 28) | |
528 | #define VI6_BRU_BLD_CCMDY_DST_A (0 << 24) | |
529 | #define VI6_BRU_BLD_CCMDY_255_DST_A (1 << 24) | |
530 | #define VI6_BRU_BLD_CCMDY_SRC_A (2 << 24) | |
531 | #define VI6_BRU_BLD_CCMDY_255_SRC_A (3 << 24) | |
532 | #define VI6_BRU_BLD_CCMDY_COEFY (4 << 24) | |
533 | #define VI6_BRU_BLD_CCMDY_MASK (7 << 24) | |
534 | #define VI6_BRU_BLD_CCMDY_SHIFT 24 | |
535 | #define VI6_BRU_BLD_ABES (1 << 23) | |
536 | #define VI6_BRU_BLD_ACMDX_DST_A (0 << 20) | |
537 | #define VI6_BRU_BLD_ACMDX_255_DST_A (1 << 20) | |
538 | #define VI6_BRU_BLD_ACMDX_SRC_A (2 << 20) | |
539 | #define VI6_BRU_BLD_ACMDX_255_SRC_A (3 << 20) | |
540 | #define VI6_BRU_BLD_ACMDX_COEFX (4 << 20) | |
541 | #define VI6_BRU_BLD_ACMDX_MASK (7 << 20) | |
542 | #define VI6_BRU_BLD_ACMDY_DST_A (0 << 16) | |
543 | #define VI6_BRU_BLD_ACMDY_255_DST_A (1 << 16) | |
544 | #define VI6_BRU_BLD_ACMDY_SRC_A (2 << 16) | |
545 | #define VI6_BRU_BLD_ACMDY_255_SRC_A (3 << 16) | |
546 | #define VI6_BRU_BLD_ACMDY_COEFY (4 << 16) | |
547 | #define VI6_BRU_BLD_ACMDY_MASK (7 << 16) | |
548 | #define VI6_BRU_BLD_COEFX_MASK (0xff << 8) | |
549 | #define VI6_BRU_BLD_COEFX_SHIFT 8 | |
550 | #define VI6_BRU_BLD_COEFY_MASK (0xff << 0) | |
551 | #define VI6_BRU_BLD_COEFY_SHIFT 0 | |
552 | ||
26e0ca22 | 553 | #define VI6_BRU_ROP 0x2c30 |
629bb6d4 LP |
554 | #define VI6_BRU_ROP_DSTSEL_BRUIN(n) ((n) << 20) |
555 | #define VI6_BRU_ROP_DSTSEL_VRPF (4 << 20) | |
556 | #define VI6_BRU_ROP_DSTSEL_MASK (7 << 20) | |
557 | #define VI6_BRU_ROP_CROP(rop) ((rop) << 4) | |
558 | #define VI6_BRU_ROP_CROP_MASK (0xf << 4) | |
559 | #define VI6_BRU_ROP_AROP(rop) ((rop) << 0) | |
560 | #define VI6_BRU_ROP_AROP_MASK (0xf << 0) | |
26e0ca22 LP |
561 | |
562 | /* ----------------------------------------------------------------------------- | |
563 | * HGO Control Registers | |
564 | */ | |
565 | ||
566 | #define VI6_HGO_OFFSET 0x3000 | |
567 | #define VI6_HGO_SIZE 0x3004 | |
568 | #define VI6_HGO_MODE 0x3008 | |
569 | #define VI6_HGO_LB_TH 0x300c | |
570 | #define VI6_HGO_LBn_H(n) (0x3010 + (n) * 8) | |
571 | #define VI6_HGO_LBn_V(n) (0x3014 + (n) * 8) | |
572 | #define VI6_HGO_R_HISTO 0x3030 | |
573 | #define VI6_HGO_R_MAXMIN 0x3130 | |
574 | #define VI6_HGO_R_SUM 0x3134 | |
575 | #define VI6_HGO_R_LB_DET 0x3138 | |
576 | #define VI6_HGO_G_HISTO 0x3140 | |
577 | #define VI6_HGO_G_MAXMIN 0x3240 | |
578 | #define VI6_HGO_G_SUM 0x3244 | |
579 | #define VI6_HGO_G_LB_DET 0x3248 | |
580 | #define VI6_HGO_B_HISTO 0x3250 | |
581 | #define VI6_HGO_B_MAXMIN 0x3350 | |
582 | #define VI6_HGO_B_SUM 0x3354 | |
583 | #define VI6_HGO_B_LB_DET 0x3358 | |
584 | #define VI6_HGO_REGRST 0x33fc | |
585 | ||
586 | /* ----------------------------------------------------------------------------- | |
587 | * HGT Control Registers | |
588 | */ | |
589 | ||
590 | #define VI6_HGT_OFFSET 0x3400 | |
591 | #define VI6_HGT_SIZE 0x3404 | |
592 | #define VI6_HGT_MODE 0x3408 | |
593 | #define VI6_HGT_HUE_AREA(n) (0x340c + (n) * 4) | |
594 | #define VI6_HGT_LB_TH 0x3424 | |
595 | #define VI6_HGT_LBn_H(n) (0x3438 + (n) * 8) | |
596 | #define VI6_HGT_LBn_V(n) (0x342c + (n) * 8) | |
597 | #define VI6_HGT_HISTO(m, n) (0x3450 + (m) * 128 + (n) * 4) | |
598 | #define VI6_HGT_MAXMIN 0x3750 | |
599 | #define VI6_HGT_SUM 0x3754 | |
600 | #define VI6_HGT_LB_DET 0x3758 | |
601 | #define VI6_HGT_REGRST 0x37fc | |
602 | ||
603 | /* ----------------------------------------------------------------------------- | |
604 | * LIF Control Registers | |
605 | */ | |
606 | ||
607 | #define VI6_LIF_CTRL 0x3b00 | |
608 | #define VI6_LIF_CTRL_OBTH_MASK (0x7ff << 16) | |
609 | #define VI6_LIF_CTRL_OBTH_SHIFT 16 | |
610 | #define VI6_LIF_CTRL_CFMT (1 << 4) | |
611 | #define VI6_LIF_CTRL_REQSEL (1 << 1) | |
612 | #define VI6_LIF_CTRL_LIF_EN (1 << 0) | |
613 | ||
614 | #define VI6_LIF_CSBTH 0x3b04 | |
615 | #define VI6_LIF_CSBTH_HBTH_MASK (0x7ff << 16) | |
616 | #define VI6_LIF_CSBTH_HBTH_SHIFT 16 | |
617 | #define VI6_LIF_CSBTH_LBTH_MASK (0x7ff << 0) | |
618 | #define VI6_LIF_CSBTH_LBTH_SHIFT 0 | |
619 | ||
620 | /* ----------------------------------------------------------------------------- | |
621 | * Security Control Registers | |
622 | */ | |
623 | ||
624 | #define VI6_SECURITY_CTRL0 0x3d00 | |
625 | #define VI6_SECURITY_CTRL1 0x3d04 | |
626 | ||
627 | /* ----------------------------------------------------------------------------- | |
628 | * RPF CLUT Registers | |
629 | */ | |
630 | ||
631 | #define VI6_CLUT_TABLE 0x4000 | |
632 | ||
633 | /* ----------------------------------------------------------------------------- | |
634 | * 1D LUT Registers | |
635 | */ | |
636 | ||
637 | #define VI6_LUT_TABLE 0x7000 | |
638 | ||
639 | /* ----------------------------------------------------------------------------- | |
640 | * 3D LUT Registers | |
641 | */ | |
642 | ||
643 | #define VI6_CLU_ADDR 0x7400 | |
644 | #define VI6_CLU_DATA 0x7404 | |
645 | ||
646 | /* ----------------------------------------------------------------------------- | |
647 | * Formats | |
648 | */ | |
649 | ||
650 | #define VI6_FMT_RGB_332 0x00 | |
651 | #define VI6_FMT_XRGB_4444 0x01 | |
652 | #define VI6_FMT_RGBX_4444 0x02 | |
653 | #define VI6_FMT_XRGB_1555 0x04 | |
654 | #define VI6_FMT_RGBX_5551 0x05 | |
655 | #define VI6_FMT_RGB_565 0x06 | |
656 | #define VI6_FMT_AXRGB_86666 0x07 | |
657 | #define VI6_FMT_RGBXA_66668 0x08 | |
658 | #define VI6_FMT_XRGBA_66668 0x09 | |
659 | #define VI6_FMT_ARGBX_86666 0x0a | |
660 | #define VI6_FMT_AXRXGXB_8262626 0x0b | |
661 | #define VI6_FMT_XRXGXBA_2626268 0x0c | |
662 | #define VI6_FMT_ARXGXBX_8626262 0x0d | |
663 | #define VI6_FMT_RXGXBXA_6262628 0x0e | |
664 | #define VI6_FMT_XRGB_6666 0x0f | |
665 | #define VI6_FMT_RGBX_6666 0x10 | |
666 | #define VI6_FMT_XRXGXB_262626 0x11 | |
667 | #define VI6_FMT_RXGXBX_626262 0x12 | |
668 | #define VI6_FMT_ARGB_8888 0x13 | |
669 | #define VI6_FMT_RGBA_8888 0x14 | |
670 | #define VI6_FMT_RGB_888 0x15 | |
671 | #define VI6_FMT_XRGXGB_763763 0x16 | |
672 | #define VI6_FMT_XXRGB_86666 0x17 | |
673 | #define VI6_FMT_BGR_888 0x18 | |
674 | #define VI6_FMT_ARGB_4444 0x19 | |
675 | #define VI6_FMT_RGBA_4444 0x1a | |
676 | #define VI6_FMT_ARGB_1555 0x1b | |
677 | #define VI6_FMT_RGBA_5551 0x1c | |
678 | #define VI6_FMT_ABGR_4444 0x1d | |
679 | #define VI6_FMT_BGRA_4444 0x1e | |
680 | #define VI6_FMT_ABGR_1555 0x1f | |
681 | #define VI6_FMT_BGRA_5551 0x20 | |
682 | #define VI6_FMT_XBXGXR_262626 0x21 | |
683 | #define VI6_FMT_ABGR_8888 0x22 | |
684 | #define VI6_FMT_XXRGB_88565 0x23 | |
685 | ||
686 | #define VI6_FMT_Y_UV_444 0x40 | |
687 | #define VI6_FMT_Y_UV_422 0x41 | |
688 | #define VI6_FMT_Y_UV_420 0x42 | |
689 | #define VI6_FMT_YUV_444 0x46 | |
690 | #define VI6_FMT_YUYV_422 0x47 | |
691 | #define VI6_FMT_YYUV_422 0x48 | |
692 | #define VI6_FMT_YUV_420 0x49 | |
693 | #define VI6_FMT_Y_U_V_444 0x4a | |
694 | #define VI6_FMT_Y_U_V_422 0x4b | |
695 | #define VI6_FMT_Y_U_V_420 0x4c | |
696 | ||
697 | #endif /* __VSP1_REGS_H__ */ |