1 /* SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause) */
2 /*
3  * Wave5 series multi-standard codec IP - wave5 register definitions
4  *
5  * Copyright (C) 2021-2023 CHIPS&MEDIA INC
6  */
7 
8 #ifndef __WAVE5_REGISTER_DEFINE_H__
9 #define __WAVE5_REGISTER_DEFINE_H__
10 
11 enum W5_VPU_COMMAND {
12 	W5_INIT_VPU		= 0x0001,
13 	W5_WAKEUP_VPU		= 0x0002,
14 	W5_SLEEP_VPU		= 0x0004,
15 	W5_CREATE_INSTANCE	= 0x0008,       /* queuing command */
16 	W5_FLUSH_INSTANCE	= 0x0010,
17 	W5_DESTROY_INSTANCE	= 0x0020,       /* queuing command */
18 	W5_INIT_SEQ		= 0x0040,       /* queuing command */
19 	W5_SET_FB		= 0x0080,
20 	W5_DEC_ENC_PIC		= 0x0100,       /* queuing command */
21 	W5_ENC_SET_PARAM	= 0x0200,	/* queuing command */
22 	W5_QUERY		= 0x4000,
23 	W5_UPDATE_BS		= 0x8000,
24 	W5_MAX_VPU_COMD		= 0x10000,
25 };
26 
27 enum query_opt {
28 	GET_VPU_INFO		= 0,
29 	SET_WRITE_PROT		= 1,
30 	GET_RESULT		= 2,
31 	UPDATE_DISP_FLAG	= 3,
32 	GET_BW_REPORT		= 4,
33 	GET_BS_RD_PTR		= 5,		/* for decoder */
34 	GET_BS_WR_PTR		= 6,		/* for encoder */
35 	GET_SRC_BUF_FLAG	= 7,		/* for encoder */
36 	SET_BS_RD_PTR		= 8,		/* for decoder */
37 	GET_DEBUG_INFO		= 0x61,
38 };
39 
40 #define W5_REG_BASE                     0x00000000
41 #define W5_CMD_REG_BASE                 0x00000100
42 #define W5_CMD_REG_END                  0x00000200
43 
44 /*
45  * COMMON
46  *
47  * ----
48  *
49  * Power on configuration
50  * PO_DEBUG_MODE    [0]     1 - power on with debug mode
51  * USE_PO_CONF      [3]     1 - use power-on-configuration
52  */
53 #define W5_PO_CONF                     (W5_REG_BASE + 0x0000)
54 #define W5_VCPU_CUR_PC                 (W5_REG_BASE + 0x0004)
55 #define W5_VCPU_CUR_LR                 (W5_REG_BASE + 0x0008)
56 #define W5_VPU_PDBG_STEP_MASK_V        (W5_REG_BASE + 0x000C)
57 #define W5_VPU_PDBG_CTRL               (W5_REG_BASE + 0x0010) /* v_cpu debugger ctrl register */
58 #define W5_VPU_PDBG_IDX_REG            (W5_REG_BASE + 0x0014) /* v_cpu debugger index register */
59 #define W5_VPU_PDBG_WDATA_REG          (W5_REG_BASE + 0x0018) /* v_cpu debugger write data reg */
60 #define W5_VPU_PDBG_RDATA_REG          (W5_REG_BASE + 0x001C) /* v_cpu debugger read data reg */
61 
62 #define W5_VPU_FIO_CTRL_ADDR           (W5_REG_BASE + 0x0020)
63 #define W5_VPU_FIO_DATA                (W5_REG_BASE + 0x0024)
64 #define W5_VPU_VINT_REASON_USR         (W5_REG_BASE + 0x0030)
65 #define W5_VPU_VINT_REASON_CLR         (W5_REG_BASE + 0x0034)
66 #define W5_VPU_HOST_INT_REQ            (W5_REG_BASE + 0x0038)
67 #define W5_VPU_VINT_CLEAR              (W5_REG_BASE + 0x003C)
68 #define W5_VPU_HINT_CLEAR              (W5_REG_BASE + 0x0040)
69 #define W5_VPU_VPU_INT_STS             (W5_REG_BASE + 0x0044)
70 #define W5_VPU_VINT_ENABLE             (W5_REG_BASE + 0x0048)
71 #define W5_VPU_VINT_REASON             (W5_REG_BASE + 0x004C)
72 #define W5_VPU_RESET_REQ               (W5_REG_BASE + 0x0050)
73 #define W5_RST_BLOCK_CCLK(_core)       BIT((_core))
74 #define W5_RST_BLOCK_CCLK_ALL          (0xff)
75 #define W5_RST_BLOCK_BCLK(_core)       (0x100 << (_core))
76 #define W5_RST_BLOCK_BCLK_ALL          (0xff00)
77 #define W5_RST_BLOCK_ACLK(_core)       (0x10000 << (_core))
78 #define W5_RST_BLOCK_ACLK_ALL          (0xff0000)
79 #define W5_RST_BLOCK_VCPU_ALL          (0x3f000000)
80 #define W5_RST_BLOCK_ALL               (0x3fffffff)
81 #define W5_VPU_RESET_STATUS            (W5_REG_BASE + 0x0054)
82 
83 #define W5_VCPU_RESTART                (W5_REG_BASE + 0x0058)
84 #define W5_VPU_CLK_MASK                (W5_REG_BASE + 0x005C)
85 
86 /* REMAP_CTRL
87  * PAGE SIZE:   [8:0]   0x001 - 4K
88  *                      0x002 - 8K
89  *                      0x004 - 16K
90  *                      ...
91  *                      0x100 - 1M
92  * REGION ATTR1 [10]    0     - normal
93  *                      1     - make bus error for the region
94  * REGION ATTR2 [11]    0     - normal
95  *                      1     - bypass region
96  * REMAP INDEX  [15:12]       - 0 ~ 3
97  * ENDIAN       [19:16]       - NOTE: Currently not supported in this driver
98  * AXI-ID       [23:20]       - upper AXI-ID
99  * BUS_ERROR    [29]    0     - bypass
100  *                      1     - make BUS_ERROR for unmapped region
101  * BYPASS_ALL   [30]    1     - bypass all
102  * ENABLE       [31]    1     - update control register[30:16]
103  */
104 #define W5_VPU_REMAP_CTRL                       (W5_REG_BASE + 0x0060)
105 #define W5_VPU_REMAP_VADDR                      (W5_REG_BASE + 0x0064)
106 #define W5_VPU_REMAP_PADDR                      (W5_REG_BASE + 0x0068)
107 #define W5_VPU_REMAP_CORE_START                 (W5_REG_BASE + 0x006C)
108 #define W5_VPU_BUSY_STATUS                      (W5_REG_BASE + 0x0070)
109 #define W5_VPU_HALT_STATUS                      (W5_REG_BASE + 0x0074)
110 #define W5_VPU_VCPU_STATUS                      (W5_REG_BASE + 0x0078)
111 #define W5_VPU_RET_PRODUCT_VERSION              (W5_REG_BASE + 0x0094)
112 /*
113  * assign vpu_config0          = {conf_map_converter_reg,      // [31]
114  * conf_map_converter_sig,         // [30]
115  * 8'd0,                        // [29:22]
116  * conf_std_switch_en,          // [21]
117  * conf_bg_detect,              // [20]
118  * conf_3dnr_en,                // [19]
119  * conf_one_axi_en,             // [18]
120  * conf_sec_axi_en,             // [17]
121  * conf_bus_info,               // [16]
122  * conf_afbc_en,                // [15]
123  * conf_afbc_version_id,        // [14:12]
124  * conf_fbc_en,                 // [11]
125  * conf_fbc_version_id,         // [10:08]
126  * conf_scaler_en,              // [07]
127  * conf_scaler_version_id,      // [06:04]
128  * conf_bwb_en,                 // [03]
129  * 3'd0};                       // [02:00]
130  */
131 #define W5_VPU_RET_VPU_CONFIG0                  (W5_REG_BASE + 0x0098)
132 /*
133  * assign vpu_config1          = {4'd0,                        // [31:28]
134  * conf_perf_timer_en,          // [27]
135  * conf_multi_core_en,          // [26]
136  * conf_gcu_en,                 // [25]
137  * conf_cu_report,              // [24]
138  * 4'd0,                        // [23:20]
139  * conf_vcore_id_3,             // [19]
140  * conf_vcore_id_2,             // [18]
141  * conf_vcore_id_1,             // [17]
142  * conf_vcore_id_0,             // [16]
143  * conf_bwb_opt,                // [15]
144  * 7'd0,                        // [14:08]
145  * conf_cod_std_en_reserved_7,  // [7]
146  * conf_cod_std_en_reserved_6,  // [6]
147  * conf_cod_std_en_reserved_5,  // [5]
148  * conf_cod_std_en_reserved_4,  // [4]
149  * conf_cod_std_en_reserved_3,  // [3]
150  * conf_cod_std_en_reserved_2,  // [2]
151  * conf_cod_std_en_vp9,         // [1]
152  * conf_cod_std_en_hevc};       // [0]
153  * }
154  */
155 #define W5_VPU_RET_VPU_CONFIG1                  (W5_REG_BASE + 0x009C)
156 
157 #define W5_VPU_DBG_REG0							(W5_REG_BASE + 0x00f0)
158 #define W5_VPU_DBG_REG1							(W5_REG_BASE + 0x00f4)
159 #define W5_VPU_DBG_REG2							(W5_REG_BASE + 0x00f8)
160 #define W5_VPU_DBG_REG3							(W5_REG_BASE + 0x00fc)
161 
162 /************************************************************************/
163 /* PRODUCT INFORMATION                                                  */
164 /************************************************************************/
165 #define W5_PRODUCT_NAME                        (W5_REG_BASE + 0x1040)
166 #define W5_PRODUCT_NUMBER                      (W5_REG_BASE + 0x1044)
167 
168 /************************************************************************/
169 /* DECODER/ENCODER COMMON                                               */
170 /************************************************************************/
171 #define W5_COMMAND                              (W5_REG_BASE + 0x0100)
172 #define W5_COMMAND_OPTION                       (W5_REG_BASE + 0x0104)
173 #define W5_QUERY_OPTION                         (W5_REG_BASE + 0x0104)
174 #define W5_RET_SUCCESS                          (W5_REG_BASE + 0x0108)
175 #define W5_RET_FAIL_REASON                      (W5_REG_BASE + 0x010C)
176 #define W5_RET_QUEUE_FAIL_REASON                (W5_REG_BASE + 0x0110)
177 #define W5_CMD_INSTANCE_INFO                    (W5_REG_BASE + 0x0110)
178 
179 #define W5_RET_QUEUE_STATUS                     (W5_REG_BASE + 0x01E0)
180 #define W5_RET_BS_EMPTY_INST                    (W5_REG_BASE + 0x01E4)
181 #define W5_RET_QUEUE_CMD_DONE_INST              (W5_REG_BASE + 0x01E8)
182 #define W5_RET_STAGE0_INSTANCE_INFO             (W5_REG_BASE + 0x01EC)
183 #define W5_RET_STAGE1_INSTANCE_INFO             (W5_REG_BASE + 0x01F0)
184 #define W5_RET_STAGE2_INSTANCE_INFO             (W5_REG_BASE + 0x01F4)
185 
186 #define W5_RET_SEQ_DONE_INSTANCE_INFO           (W5_REG_BASE + 0x01FC)
187 
188 #define W5_BS_OPTION                            (W5_REG_BASE + 0x0120)
189 
190 /* return info when QUERY (GET_RESULT) for en/decoder */
191 #define W5_RET_VLC_BUF_SIZE                     (W5_REG_BASE + 0x01B0)
192 /* return info when QUERY (GET_RESULT) for en/decoder */
193 #define W5_RET_PARAM_BUF_SIZE                   (W5_REG_BASE + 0x01B4)
194 
195 /* set when SET_FB for en/decoder */
196 #define W5_CMD_SET_FB_ADDR_TASK_BUF             (W5_REG_BASE + 0x01D4)
197 #define W5_CMD_SET_FB_TASK_BUF_SIZE             (W5_REG_BASE + 0x01D8)
198 /************************************************************************/
199 /* INIT_VPU - COMMON                                                    */
200 /************************************************************************/
201 /* note: W5_ADDR_CODE_BASE should be aligned to 4KB */
202 #define W5_ADDR_CODE_BASE                       (W5_REG_BASE + 0x0110)
203 #define W5_CODE_SIZE                            (W5_REG_BASE + 0x0114)
204 #define W5_CODE_PARAM                           (W5_REG_BASE + 0x0118)
205 #define W5_ADDR_TEMP_BASE                       (W5_REG_BASE + 0x011C)
206 #define W5_TEMP_SIZE                            (W5_REG_BASE + 0x0120)
207 #define W5_HW_OPTION                            (W5_REG_BASE + 0x012C)
208 #define W5_CMD_INIT_NUM_TASK_BUF		(W5_REG_BASE + 0x0134)
209 #define W5_CMD_INIT_ADDR_TASK_BUF0		(W5_REG_BASE + 0x0138)
210 #define W5_CMD_INIT_TASK_BUF_SIZE		(W5_REG_BASE + 0x0178)
211 #define W5_SEC_AXI_PARAM                        (W5_REG_BASE + 0x0180)
212 
213 /************************************************************************/
214 /* CREATE_INSTANCE - COMMON                                             */
215 /************************************************************************/
216 #define W5_ADDR_WORK_BASE                       (W5_REG_BASE + 0x0114)
217 #define W5_WORK_SIZE                            (W5_REG_BASE + 0x0118)
218 #define W5_CMD_DEC_BS_START_ADDR                (W5_REG_BASE + 0x011C)
219 #define W5_CMD_DEC_BS_SIZE                      (W5_REG_BASE + 0x0120)
220 #define W5_CMD_BS_PARAM                         (W5_REG_BASE + 0x0124)
221 #define W5_CMD_ADDR_SEC_AXI                     (W5_REG_BASE + 0x0130)
222 #define W515_CMD_ADDR_SEC_AXI			(W5_REG_BASE + 0x0124)
223 #define W5_CMD_SEC_AXI_SIZE                     (W5_REG_BASE + 0x0134)
224 #define W515_CMD_SEC_AXI_SIZE			(W5_REG_BASE + 0x0128)
225 #define W5_CMD_EXT_ADDR                         (W5_REG_BASE + 0x0138)
226 #define W5_CMD_NUM_CQ_DEPTH_M1                  (W5_REG_BASE + 0x013C)
227 #define W5_CMD_ERR_CONCEAL                      (W5_REG_BASE + 0x0140)
228 
229 /************************************************************************/
230 /* DECODER - INIT_SEQ                                                   */
231 /************************************************************************/
232 #define W5_BS_RD_PTR                            (W5_REG_BASE + 0x0118)
233 #define W5_BS_WR_PTR                            (W5_REG_BASE + 0x011C)
234 /************************************************************************/
235 /* SET_FRAME_BUF                                                        */
236 /************************************************************************/
237 /* SET_FB_OPTION 0x00       REGISTER FRAMEBUFFERS
238  * 0x01       UPDATE FRAMEBUFFER, just one framebuffer(linear, fbc and mvcol)
239  */
240 #define W5_SFB_OPTION                           (W5_REG_BASE + 0x0104)
241 #define W5_COMMON_PIC_INFO                      (W5_REG_BASE + 0x0118)
242 #define W5_PIC_SIZE                             (W5_REG_BASE + 0x011C)
243 #define W5_SET_FB_NUM                           (W5_REG_BASE + 0x0120)
244 #define W5_EXTRA_PIC_INFO                       (W5_REG_BASE + 0x0124)
245 
246 #define W5_ADDR_LUMA_BASE0                      (W5_REG_BASE + 0x0134)
247 #define W5_ADDR_CB_BASE0                        (W5_REG_BASE + 0x0138)
248 #define W5_ADDR_CR_BASE0                        (W5_REG_BASE + 0x013C)
249 /* compression offset table for luma */
250 #define W5_ADDR_FBC_Y_OFFSET0                   (W5_REG_BASE + 0x013C)
251 /* compression offset table for chroma */
252 #define W5_ADDR_FBC_C_OFFSET0                   (W5_REG_BASE + 0x0140)
253 #define W5_ADDR_LUMA_BASE1                      (W5_REG_BASE + 0x0144)
254 #define W5_ADDR_CB_ADDR1                        (W5_REG_BASE + 0x0148)
255 #define W5_ADDR_CR_ADDR1                        (W5_REG_BASE + 0x014C)
256 /* compression offset table for luma */
257 #define W5_ADDR_FBC_Y_OFFSET1                   (W5_REG_BASE + 0x014C)
258 /* compression offset table for chroma */
259 #define W5_ADDR_FBC_C_OFFSET1                   (W5_REG_BASE + 0x0150)
260 #define W5_ADDR_LUMA_BASE2                      (W5_REG_BASE + 0x0154)
261 #define W5_ADDR_CB_ADDR2                        (W5_REG_BASE + 0x0158)
262 #define W5_ADDR_CR_ADDR2                        (W5_REG_BASE + 0x015C)
263 /* compression offset table for luma */
264 #define W5_ADDR_FBC_Y_OFFSET2                   (W5_REG_BASE + 0x015C)
265 /* compression offset table for chroma */
266 #define W5_ADDR_FBC_C_OFFSET2                   (W5_REG_BASE + 0x0160)
267 #define W5_ADDR_LUMA_BASE3                      (W5_REG_BASE + 0x0164)
268 #define W5_ADDR_CB_ADDR3                        (W5_REG_BASE + 0x0168)
269 #define W5_ADDR_CR_ADDR3                        (W5_REG_BASE + 0x016C)
270 /* compression offset table for luma */
271 #define W5_ADDR_FBC_Y_OFFSET3                   (W5_REG_BASE + 0x016C)
272 /* compression offset table for chroma */
273 #define W5_ADDR_FBC_C_OFFSET3                   (W5_REG_BASE + 0x0170)
274 #define W5_ADDR_LUMA_BASE4                      (W5_REG_BASE + 0x0174)
275 #define W5_ADDR_CB_ADDR4                        (W5_REG_BASE + 0x0178)
276 #define W5_ADDR_CR_ADDR4                        (W5_REG_BASE + 0x017C)
277 /* compression offset table for luma */
278 #define W5_ADDR_FBC_Y_OFFSET4                   (W5_REG_BASE + 0x017C)
279 /* compression offset table for chroma */
280 #define W5_ADDR_FBC_C_OFFSET4                   (W5_REG_BASE + 0x0180)
281 #define W5_ADDR_LUMA_BASE5                      (W5_REG_BASE + 0x0184)
282 #define W5_ADDR_CB_ADDR5                        (W5_REG_BASE + 0x0188)
283 #define W5_ADDR_CR_ADDR5                        (W5_REG_BASE + 0x018C)
284 /* compression offset table for luma */
285 #define W5_ADDR_FBC_Y_OFFSET5                   (W5_REG_BASE + 0x018C)
286 /* compression offset table for chroma */
287 #define W5_ADDR_FBC_C_OFFSET5                   (W5_REG_BASE + 0x0190)
288 #define W5_ADDR_LUMA_BASE6                      (W5_REG_BASE + 0x0194)
289 #define W5_ADDR_CB_ADDR6                        (W5_REG_BASE + 0x0198)
290 #define W5_ADDR_CR_ADDR6                        (W5_REG_BASE + 0x019C)
291 /* compression offset table for luma */
292 #define W5_ADDR_FBC_Y_OFFSET6                   (W5_REG_BASE + 0x019C)
293 /* compression offset table for chroma */
294 #define W5_ADDR_FBC_C_OFFSET6                   (W5_REG_BASE + 0x01A0)
295 #define W5_ADDR_LUMA_BASE7                      (W5_REG_BASE + 0x01A4)
296 #define W5_ADDR_CB_ADDR7                        (W5_REG_BASE + 0x01A8)
297 #define W5_ADDR_CR_ADDR7                        (W5_REG_BASE + 0x01AC)
298 /* compression offset table for luma */
299 #define W5_ADDR_FBC_Y_OFFSET7                   (W5_REG_BASE + 0x01AC)
300 /* compression offset table for chroma */
301 #define W5_ADDR_FBC_C_OFFSET7                   (W5_REG_BASE + 0x01B0)
302 #define W5_ADDR_MV_COL0                         (W5_REG_BASE + 0x01B4)
303 #define W5_ADDR_MV_COL1                         (W5_REG_BASE + 0x01B8)
304 #define W5_ADDR_MV_COL2                         (W5_REG_BASE + 0x01BC)
305 #define W5_ADDR_MV_COL3                         (W5_REG_BASE + 0x01C0)
306 #define W5_ADDR_MV_COL4                         (W5_REG_BASE + 0x01C4)
307 #define W5_ADDR_MV_COL5                         (W5_REG_BASE + 0x01C8)
308 #define W5_ADDR_MV_COL6                         (W5_REG_BASE + 0x01CC)
309 #define W5_ADDR_MV_COL7                         (W5_REG_BASE + 0x01D0)
310 
311 /* UPDATE_FB */
312 /* CMD_SET_FB_STRIDE [15:0]     - FBC framebuffer stride
313  * [31:15]    - linear framebuffer stride
314  */
315 #define W5_CMD_SET_FB_STRIDE                    (W5_REG_BASE + 0x0118)
316 #define W5_CMD_SET_FB_INDEX                     (W5_REG_BASE + 0x0120)
317 #define W5_ADDR_LUMA_BASE                       (W5_REG_BASE + 0x0134)
318 #define W5_ADDR_CB_BASE                         (W5_REG_BASE + 0x0138)
319 #define W5_ADDR_CR_BASE                         (W5_REG_BASE + 0x013C)
320 #define W5_ADDR_MV_COL                          (W5_REG_BASE + 0x0140)
321 #define W5_ADDR_FBC_Y_BASE                      (W5_REG_BASE + 0x0144)
322 #define W5_ADDR_FBC_C_BASE                      (W5_REG_BASE + 0x0148)
323 #define W5_ADDR_FBC_Y_OFFSET                    (W5_REG_BASE + 0x014C)
324 #define W5_ADDR_FBC_C_OFFSET                    (W5_REG_BASE + 0x0150)
325 
326 /************************************************************************/
327 /* DECODER - DEC_PIC                                                    */
328 /************************************************************************/
329 #define W5_CMD_DEC_VCORE_INFO                   (W5_REG_BASE + 0x0194)
330 /* sequence change enable mask register
331  * CMD_SEQ_CHANGE_ENABLE_FLAG [5]   profile_idc
332  *                            [16]  pic_width/height_in_luma_sample
333  *                            [19]  sps_max_dec_pic_buffering, max_num_reorder, max_latency_increase
334  */
335 #define W5_CMD_SEQ_CHANGE_ENABLE_FLAG           (W5_REG_BASE + 0x0128)
336 #define W5_CMD_DEC_USER_MASK                    (W5_REG_BASE + 0x012C)
337 #define W5_CMD_DEC_TEMPORAL_ID_PLUS1            (W5_REG_BASE + 0x0130)
338 #define W5_CMD_DEC_FORCE_FB_LATENCY_PLUS1       (W5_REG_BASE + 0x0134)
339 #define W5_USE_SEC_AXI                          (W5_REG_BASE + 0x0150)
340 
341 /************************************************************************/
342 /* DECODER - QUERY : GET_VPU_INFO                                       */
343 /************************************************************************/
344 #define W5_RET_FW_VERSION                       (W5_REG_BASE + 0x0118)
345 #define W5_RET_PRODUCT_NAME                     (W5_REG_BASE + 0x011C)
346 #define W5_RET_PRODUCT_VERSION                  (W5_REG_BASE + 0x0120)
347 #define W5_RET_STD_DEF0                         (W5_REG_BASE + 0x0124)
348 #define W5_RET_STD_DEF1                         (W5_REG_BASE + 0x0128)
349 #define W5_RET_CONF_FEATURE                     (W5_REG_BASE + 0x012C)
350 #define W5_RET_CONF_DATE                        (W5_REG_BASE + 0x0130)
351 #define W5_RET_CONF_REVISION                    (W5_REG_BASE + 0x0134)
352 #define W5_RET_CONF_TYPE                        (W5_REG_BASE + 0x0138)
353 #define W5_RET_PRODUCT_ID                       (W5_REG_BASE + 0x013C)
354 #define W5_RET_CUSTOMER_ID                      (W5_REG_BASE + 0x0140)
355 
356 /************************************************************************/
357 /* DECODER - QUERY : GET_RESULT                                         */
358 /************************************************************************/
359 #define W5_CMD_DEC_ADDR_REPORT_BASE         (W5_REG_BASE + 0x0114)
360 #define W5_CMD_DEC_REPORT_SIZE              (W5_REG_BASE + 0x0118)
361 #define W5_CMD_DEC_REPORT_PARAM             (W5_REG_BASE + 0x011C)
362 
363 #define W5_RET_DEC_BS_RD_PTR                (W5_REG_BASE + 0x011C)
364 #define W5_RET_DEC_SEQ_PARAM                (W5_REG_BASE + 0x0120)
365 #define W5_RET_DEC_COLOR_SAMPLE_INFO        (W5_REG_BASE + 0x0124)
366 #define W5_RET_DEC_ASPECT_RATIO             (W5_REG_BASE + 0x0128)
367 #define W5_RET_DEC_BIT_RATE                 (W5_REG_BASE + 0x012C)
368 #define W5_RET_DEC_FRAME_RATE_NR            (W5_REG_BASE + 0x0130)
369 #define W5_RET_DEC_FRAME_RATE_DR            (W5_REG_BASE + 0x0134)
370 #define W5_RET_DEC_NUM_REQUIRED_FB          (W5_REG_BASE + 0x0138)
371 #define W5_RET_DEC_NUM_REORDER_DELAY        (W5_REG_BASE + 0x013C)
372 #define W5_RET_DEC_SUB_LAYER_INFO           (W5_REG_BASE + 0x0140)
373 #define W5_RET_DEC_NOTIFICATION             (W5_REG_BASE + 0x0144)
374 /*
375  * USER_DATA_FLAGS for HEVC/H264 only.
376  * Bits:
377  * [1] - User data buffer full boolean
378  * [2] - VUI parameter flag
379  * [4] - Pic_timing SEI flag
380  * [5] - 1st user_data_registed_itu_t_t35 prefix SEI flag
381  * [6] - user_data_unregistered prefix SEI flag
382  * [7] - 1st user_data_registed_itu_t_t35 suffix SEI flag
383  * [8] - user_data_unregistered suffix SEI flag
384  * [10]- mastering_display_color_volume prefix SEI flag
385  * [11]- chroma_resampling_display_color_volume prefix SEI flag
386  * [12]- knee_function_info SEI flag
387  * [13]- tone_mapping_info prefix SEI flag
388  * [14]- film_grain_characteristics_info prefix SEI flag
389  * [15]- content_light_level_info prefix SEI flag
390  * [16]- color_remapping_info prefix SEI flag
391  * [28]- 2nd user_data_registed_itu_t_t35 prefix SEI flag
392  * [29]- 3rd user_data_registed_itu_t_t35 prefix SEI flag
393  * [30]- 2nd user_data_registed_itu_t_t35 suffix SEI flag
394  * [31]- 3rd user_data_registed_itu_t_t35 suffix SEI flag
395  */
396 #define W5_RET_DEC_USERDATA_IDC             (W5_REG_BASE + 0x0148)
397 #define W5_RET_DEC_PIC_SIZE                 (W5_REG_BASE + 0x014C)
398 #define W5_RET_DEC_CROP_TOP_BOTTOM          (W5_REG_BASE + 0x0150)
399 #define W5_RET_DEC_CROP_LEFT_RIGHT          (W5_REG_BASE + 0x0154)
400 /*
401  * #define W5_RET_DEC_AU_START_POS             (W5_REG_BASE + 0x0158)
402  * => Access unit (AU) Bitstream start position
403  * #define W5_RET_DEC_AU_END_POS               (W5_REG_BASE + 0x015C)
404  * => Access unit (AU) Bitstream end position
405  */
406 
407 /*
408  * Decoded picture type:
409  * reg_val & 0x7			=> picture type
410  * (reg_val >> 4) & 0x3f		=> VCL NAL unit type
411  * (reg_val >> 31) & 0x1		=> output_flag
412  * 16 << ((reg_val >> 10) & 0x3)	=> ctu_size
413  */
414 #define W5_RET_DEC_PIC_TYPE                 (W5_REG_BASE + 0x0160)
415 #define W5_RET_DEC_PIC_POC                  (W5_REG_BASE + 0x0164)
416 /*
417  * #define W5_RET_DEC_RECOVERY_POINT           (W5_REG_BASE + 0x0168)
418  * => HEVC recovery point
419  * reg_val & 0xff => number of signed recovery picture order counts
420  * (reg_val >> 16) & 0x1 => exact match flag
421  * (reg_val >> 17) & 0x1 => broken link flag
422  * (reg_val >> 18) & 0x1 => exist flag
423  */
424 #define W5_RET_DEC_DEBUG_INDEX              (W5_REG_BASE + 0x016C)
425 #define W5_RET_DEC_DECODED_INDEX            (W5_REG_BASE + 0x0170)
426 #define W5_RET_DEC_DISPLAY_INDEX            (W5_REG_BASE + 0x0174)
427 /*
428  * #define W5_RET_DEC_REALLOC_INDEX            (W5_REG_BASE + 0x0178)
429  * => display picture index in decoded picture buffer
430  * reg_val & 0xf => display picture index for FBC buffer (by reordering)
431  */
432 #define W5_RET_DEC_DISP_IDC                 (W5_REG_BASE + 0x017C)
433 /*
434  * #define W5_RET_DEC_ERR_CTB_NUM              (W5_REG_BASE + 0x0180)
435  * => Number of error CTUs
436  * reg_val >> 16	=> erroneous CTUs in bitstream
437  * reg_val & 0xffff	=> total CTUs in bitstream
438  *
439  * #define W5_RET_DEC_PIC_PARAM                (W5_REG_BASE + 0x01A0)
440  * => Bitstream sequence/picture parameter information (AV1 only)
441  * reg_val & 0x1 => intrabc tool enable
442  * (reg_val >> 1) & 0x1 => screen content tools enable
443  */
444 #define W5_RET_DEC_HOST_CMD_TICK            (W5_REG_BASE + 0x01B8)
445 /*
446  * #define W5_RET_DEC_SEEK_START_TICK          (W5_REG_BASE + 0x01BC)
447  * #define W5_RET_DEC_SEEK_END_TICK            (W5_REG_BASE + 0x01C0)
448  * => Start and end ticks for seeking slices of the picture
449  * #define W5_RET_DEC_PARSING_START_TICK       (W5_REG_BASE + 0x01C4)
450  * #define W5_RET_DEC_PARSING_END_TICK         (W5_REG_BASE + 0x01C8)
451  * => Start and end ticks for parsing slices of the picture
452  * #define W5_RET_DEC_DECODING_START_TICK      (W5_REG_BASE + 0x01CC)
453  * => Start tick for decoding slices of the picture
454  */
455 #define W5_RET_DEC_DECODING_ENC_TICK        (W5_REG_BASE + 0x01D0)
456 #define W5_RET_DEC_WARN_INFO                (W5_REG_BASE + 0x01D4)
457 #define W5_RET_DEC_ERR_INFO                 (W5_REG_BASE + 0x01D8)
458 #define W5_RET_DEC_DECODING_SUCCESS         (W5_REG_BASE + 0x01DC)
459 
460 /************************************************************************/
461 /* DECODER - FLUSH_INSTANCE                                             */
462 /************************************************************************/
463 #define W5_CMD_FLUSH_INST_OPT               (W5_REG_BASE + 0x104)
464 
465 /************************************************************************/
466 /* DECODER - QUERY : UPDATE_DISP_FLAG                                   */
467 /************************************************************************/
468 #define W5_CMD_DEC_SET_DISP_IDC             (W5_REG_BASE + 0x0118)
469 #define W5_CMD_DEC_CLR_DISP_IDC             (W5_REG_BASE + 0x011C)
470 
471 /************************************************************************/
472 /* DECODER - QUERY : SET_BS_RD_PTR                                      */
473 /************************************************************************/
474 #define W5_RET_QUERY_DEC_SET_BS_RD_PTR      (W5_REG_BASE + 0x011C)
475 
476 /************************************************************************/
477 /* DECODER - QUERY : GET_BS_RD_PTR                                      */
478 /************************************************************************/
479 #define W5_RET_QUERY_DEC_BS_RD_PTR          (W5_REG_BASE + 0x011C)
480 
481 /************************************************************************/
482 /* QUERY : GET_DEBUG_INFO                                               */
483 /************************************************************************/
484 #define W5_RET_QUERY_DEBUG_PRI_REASON       (W5_REG_BASE + 0x114)
485 
486 /************************************************************************/
487 /* GDI register for debugging                                           */
488 /************************************************************************/
489 #define W5_GDI_BASE                         0x8800
490 #define W5_GDI_BUS_CTRL                     (W5_GDI_BASE + 0x0F0)
491 #define W5_GDI_BUS_STATUS                   (W5_GDI_BASE + 0x0F4)
492 
493 #define W5_BACKBONE_BASE_VCPU               0xFE00
494 #define W5_BACKBONE_BUS_CTRL_VCPU           (W5_BACKBONE_BASE_VCPU + 0x010)
495 #define W5_BACKBONE_BUS_STATUS_VCPU         (W5_BACKBONE_BASE_VCPU + 0x014)
496 #define W5_BACKBONE_PROG_AXI_ID             (W5_BACKBONE_BASE_VCPU + 0x00C)
497 
498 #define W5_BACKBONE_PROC_EXT_ADDR           (W5_BACKBONE_BASE_VCPU + 0x0C0)
499 #define W5_BACKBONE_AXI_PARAM               (W5_BACKBONE_BASE_VCPU + 0x0E0)
500 
501 #define W5_BACKBONE_BASE_VCORE0             0x8E00
502 #define W5_BACKBONE_BUS_CTRL_VCORE0         (W5_BACKBONE_BASE_VCORE0 + 0x010)
503 #define W5_BACKBONE_BUS_STATUS_VCORE0       (W5_BACKBONE_BASE_VCORE0 + 0x014)
504 
505 #define W5_BACKBONE_BASE_VCORE1             0x9E00  /* for dual-core product */
506 #define W5_BACKBONE_BUS_CTRL_VCORE1         (W5_BACKBONE_BASE_VCORE1 + 0x010)
507 #define W5_BACKBONE_BUS_STATUS_VCORE1       (W5_BACKBONE_BASE_VCORE1 + 0x014)
508 
509 #define W5_COMBINED_BACKBONE_BASE           0xFE00
510 #define W5_COMBINED_BACKBONE_BUS_CTRL       (W5_COMBINED_BACKBONE_BASE + 0x010)
511 #define W5_COMBINED_BACKBONE_BUS_STATUS     (W5_COMBINED_BACKBONE_BASE + 0x014)
512 
513 /************************************************************************/
514 /*                                                                      */
515 /*               for  ENCODER                                           */
516 /*                                                                      */
517 /************************************************************************/
518 #define W5_RET_STAGE3_INSTANCE_INFO             (W5_REG_BASE + 0x1F8)
519 /************************************************************************/
520 /* ENCODER - CREATE_INSTANCE                                            */
521 /************************************************************************/
522 /* 0x114 ~ 0x124 : defined above (CREATE_INSTANCE COMMON) */
523 #define W5_CMD_ENC_VCORE_INFO                   (W5_REG_BASE + 0x0194)
524 #define W5_CMD_ENC_SRC_OPTIONS                  (W5_REG_BASE + 0x0128)
525 
526 /************************************************************************/
527 /* ENCODER - SET_FB                                                     */
528 /************************************************************************/
529 #define W5_FBC_STRIDE                           (W5_REG_BASE + 0x128)
530 #define W5_ADDR_SUB_SAMPLED_FB_BASE             (W5_REG_BASE + 0x12C)
531 #define W5_SUB_SAMPLED_ONE_FB_SIZE              (W5_REG_BASE + 0x130)
532 
533 /************************************************************************/
534 /* ENCODER - ENC_SET_PARAM (COMMON & CHANGE_PARAM)                      */
535 /************************************************************************/
536 #define W5_CMD_ENC_SEQ_SET_PARAM_OPTION         (W5_REG_BASE + 0x104)
537 #define W5_CMD_ENC_SEQ_SET_PARAM_ENABLE         (W5_REG_BASE + 0x118)
538 #define W5_CMD_ENC_SEQ_SRC_SIZE                 (W5_REG_BASE + 0x11C)
539 #define W5_CMD_ENC_SEQ_CUSTOM_MAP_ENDIAN        (W5_REG_BASE + 0x120)
540 #define W5_CMD_ENC_SEQ_SPS_PARAM                (W5_REG_BASE + 0x124)
541 #define W5_CMD_ENC_SEQ_PPS_PARAM                (W5_REG_BASE + 0x128)
542 #define W5_CMD_ENC_SEQ_GOP_PARAM                (W5_REG_BASE + 0x12C)
543 #define W5_CMD_ENC_SEQ_INTRA_PARAM              (W5_REG_BASE + 0x130)
544 #define W5_CMD_ENC_SEQ_CONF_WIN_TOP_BOT         (W5_REG_BASE + 0x134)
545 #define W5_CMD_ENC_SEQ_CONF_WIN_LEFT_RIGHT      (W5_REG_BASE + 0x138)
546 #define W5_CMD_ENC_SEQ_RDO_PARAM                (W5_REG_BASE + 0x13C)
547 #define W5_CMD_ENC_SEQ_INDEPENDENT_SLICE        (W5_REG_BASE + 0x140)
548 #define W5_CMD_ENC_SEQ_DEPENDENT_SLICE          (W5_REG_BASE + 0x144)
549 #define W5_CMD_ENC_SEQ_INTRA_REFRESH            (W5_REG_BASE + 0x148)
550 #define W5_CMD_ENC_SEQ_INPUT_SRC_PARAM          (W5_REG_BASE + 0x14C)
551 
552 #define W5_CMD_ENC_SEQ_RC_FRAME_RATE            (W5_REG_BASE + 0x150)
553 #define W5_CMD_ENC_SEQ_RC_TARGET_RATE           (W5_REG_BASE + 0x154)
554 #define W5_CMD_ENC_SEQ_RC_PARAM                 (W5_REG_BASE + 0x158)
555 #define W5_CMD_ENC_SEQ_RC_MIN_MAX_QP            (W5_REG_BASE + 0x15C)
556 #define W5_CMD_ENC_SEQ_RC_BIT_RATIO_LAYER_0_3   (W5_REG_BASE + 0x160)
557 #define W5_CMD_ENC_SEQ_RC_BIT_RATIO_LAYER_4_7   (W5_REG_BASE + 0x164)
558 #define W5_CMD_ENC_SEQ_RC_INTER_MIN_MAX_QP      (W5_REG_BASE + 0x168)
559 #define W5_CMD_ENC_SEQ_RC_WEIGHT_PARAM          (W5_REG_BASE + 0x16C)
560 
561 #define W5_CMD_ENC_SEQ_ROT_PARAM                (W5_REG_BASE + 0x170)
562 #define W5_CMD_ENC_SEQ_NUM_UNITS_IN_TICK        (W5_REG_BASE + 0x174)
563 #define W5_CMD_ENC_SEQ_TIME_SCALE               (W5_REG_BASE + 0x178)
564 #define W5_CMD_ENC_SEQ_NUM_TICKS_POC_DIFF_ONE   (W5_REG_BASE + 0x17C)
565 
566 #define W5_CMD_ENC_SEQ_CUSTOM_MD_PU04           (W5_REG_BASE + 0x184)
567 #define W5_CMD_ENC_SEQ_CUSTOM_MD_PU08           (W5_REG_BASE + 0x188)
568 #define W5_CMD_ENC_SEQ_CUSTOM_MD_PU16           (W5_REG_BASE + 0x18C)
569 #define W5_CMD_ENC_SEQ_CUSTOM_MD_PU32           (W5_REG_BASE + 0x190)
570 #define W5_CMD_ENC_SEQ_CUSTOM_MD_CU08           (W5_REG_BASE + 0x194)
571 #define W5_CMD_ENC_SEQ_CUSTOM_MD_CU16           (W5_REG_BASE + 0x198)
572 #define W5_CMD_ENC_SEQ_CUSTOM_MD_CU32           (W5_REG_BASE + 0x19C)
573 #define W5_CMD_ENC_SEQ_NR_PARAM                 (W5_REG_BASE + 0x1A0)
574 #define W5_CMD_ENC_SEQ_NR_WEIGHT                (W5_REG_BASE + 0x1A4)
575 #define W5_CMD_ENC_SEQ_BG_PARAM                 (W5_REG_BASE + 0x1A8)
576 #define W5_CMD_ENC_SEQ_CUSTOM_LAMBDA_ADDR       (W5_REG_BASE + 0x1AC)
577 #define W5_CMD_ENC_SEQ_USER_SCALING_LIST_ADDR   (W5_REG_BASE + 0x1B0)
578 #define W5_CMD_ENC_SEQ_VUI_HRD_PARAM            (W5_REG_BASE + 0x180)
579 #define W5_CMD_ENC_SEQ_VUI_RBSP_ADDR            (W5_REG_BASE + 0x1B8)
580 #define W5_CMD_ENC_SEQ_HRD_RBSP_ADDR            (W5_REG_BASE + 0x1BC)
581 
582 /************************************************************************/
583 /* ENCODER - ENC_SET_PARAM (CUSTOM_GOP)                                 */
584 /************************************************************************/
585 #define W5_CMD_ENC_CUSTOM_GOP_PARAM             (W5_REG_BASE + 0x11C)
586 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_0       (W5_REG_BASE + 0x120)
587 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_1       (W5_REG_BASE + 0x124)
588 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_2       (W5_REG_BASE + 0x128)
589 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_3       (W5_REG_BASE + 0x12C)
590 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_4       (W5_REG_BASE + 0x130)
591 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_5       (W5_REG_BASE + 0x134)
592 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_6       (W5_REG_BASE + 0x138)
593 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_7       (W5_REG_BASE + 0x13C)
594 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_8       (W5_REG_BASE + 0x140)
595 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_9       (W5_REG_BASE + 0x144)
596 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_10      (W5_REG_BASE + 0x148)
597 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_11      (W5_REG_BASE + 0x14C)
598 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_12      (W5_REG_BASE + 0x150)
599 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_13      (W5_REG_BASE + 0x154)
600 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_14      (W5_REG_BASE + 0x158)
601 #define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_15      (W5_REG_BASE + 0x15C)
602 
603 /************************************************************************/
604 /* ENCODER - ENC_PIC                                                    */
605 /************************************************************************/
606 #define W5_CMD_ENC_BS_START_ADDR                (W5_REG_BASE + 0x118)
607 #define W5_CMD_ENC_BS_SIZE                      (W5_REG_BASE + 0x11C)
608 #define W5_CMD_ENC_PIC_USE_SEC_AXI              (W5_REG_BASE + 0x124)
609 #define W5_CMD_ENC_PIC_REPORT_PARAM             (W5_REG_BASE + 0x128)
610 
611 #define W5_CMD_ENC_PIC_CUSTOM_MAP_OPTION_PARAM  (W5_REG_BASE + 0x138)
612 #define W5_CMD_ENC_PIC_CUSTOM_MAP_OPTION_ADDR   (W5_REG_BASE + 0x13C)
613 #define W5_CMD_ENC_PIC_SRC_PIC_IDX              (W5_REG_BASE + 0x144)
614 #define W5_CMD_ENC_PIC_SRC_ADDR_Y               (W5_REG_BASE + 0x148)
615 #define W5_CMD_ENC_PIC_SRC_ADDR_U               (W5_REG_BASE + 0x14C)
616 #define W5_CMD_ENC_PIC_SRC_ADDR_V               (W5_REG_BASE + 0x150)
617 #define W5_CMD_ENC_PIC_SRC_STRIDE               (W5_REG_BASE + 0x154)
618 #define W5_CMD_ENC_PIC_SRC_FORMAT               (W5_REG_BASE + 0x158)
619 #define W5_CMD_ENC_PIC_SRC_AXI_SEL              (W5_REG_BASE + 0x160)
620 #define W5_CMD_ENC_PIC_CODE_OPTION              (W5_REG_BASE + 0x164)
621 #define W5_CMD_ENC_PIC_PIC_PARAM                (W5_REG_BASE + 0x168)
622 #define W5_CMD_ENC_PIC_LONGTERM_PIC             (W5_REG_BASE + 0x16C)
623 #define W5_CMD_ENC_PIC_WP_PIXEL_SIGMA_Y         (W5_REG_BASE + 0x170)
624 #define W5_CMD_ENC_PIC_WP_PIXEL_SIGMA_C         (W5_REG_BASE + 0x174)
625 #define W5_CMD_ENC_PIC_WP_PIXEL_MEAN_Y          (W5_REG_BASE + 0x178)
626 #define W5_CMD_ENC_PIC_WP_PIXEL_MEAN_C          (W5_REG_BASE + 0x17C)
627 #define W5_CMD_ENC_PIC_CF50_Y_OFFSET_TABLE_ADDR  (W5_REG_BASE + 0x190)
628 #define W5_CMD_ENC_PIC_CF50_CB_OFFSET_TABLE_ADDR (W5_REG_BASE + 0x194)
629 #define W5_CMD_ENC_PIC_CF50_CR_OFFSET_TABLE_ADDR (W5_REG_BASE + 0x198)
630 #define W5_CMD_ENC_PIC_PREFIX_SEI_NAL_ADDR       (W5_REG_BASE + 0x180)
631 #define W5_CMD_ENC_PIC_PREFIX_SEI_INFO           (W5_REG_BASE + 0x184)
632 #define W5_CMD_ENC_PIC_SUFFIX_SEI_NAL_ADDR       (W5_REG_BASE + 0x188)
633 #define W5_CMD_ENC_PIC_SUFFIX_SEI_INFO           (W5_REG_BASE + 0x18c)
634 
635 /************************************************************************/
636 /* ENCODER - QUERY (GET_RESULT)                                         */
637 /************************************************************************/
638 #define W5_RET_ENC_NUM_REQUIRED_FB              (W5_REG_BASE + 0x11C)
639 #define W5_RET_ENC_MIN_SRC_BUF_NUM              (W5_REG_BASE + 0x120)
640 #define W5_RET_ENC_PIC_TYPE                     (W5_REG_BASE + 0x124)
641 /*
642  * #define W5_RET_ENC_PIC_POC                      (W5_REG_BASE + 0x128)
643  * => picture order count value of current encoded picture
644  */
645 #define W5_RET_ENC_PIC_IDX                      (W5_REG_BASE + 0x12C)
646 /*
647  * #define W5_RET_ENC_PIC_SLICE_NUM                (W5_REG_BASE + 0x130)
648  * reg_val & 0xffff = total independent slice segment number (16 bits)
649  * (reg_val >> 16) & 0xffff = total dependent slice segment number (16 bits)
650  *
651  * #define W5_RET_ENC_PIC_SKIP                     (W5_REG_BASE + 0x134)
652  * reg_val & 0xfe = picture skip flag (7 bits)
653  *
654  * #define W5_RET_ENC_PIC_NUM_INTRA                (W5_REG_BASE + 0x138)
655  * => number of intra blocks in 8x8 (32 bits)
656  *
657  * #define W5_RET_ENC_PIC_NUM_MERGE                (W5_REG_BASE + 0x13C)
658  * => number of merge blocks in 8x8 (32 bits)
659  *
660  * #define W5_RET_ENC_PIC_NUM_SKIP                 (W5_REG_BASE + 0x144)
661  * => number of skip blocks in 8x8 (32 bits)
662  *
663  * #define W5_RET_ENC_PIC_AVG_CTU_QP               (W5_REG_BASE + 0x148)
664  * => Average CTU QP value (32 bits)
665  */
666 #define W5_RET_ENC_PIC_BYTE                     (W5_REG_BASE + 0x14C)
667 /*
668  * #define W5_RET_ENC_GOP_PIC_IDX                  (W5_REG_BASE + 0x150)
669  * => picture index in group of pictures
670  */
671 #define W5_RET_ENC_USED_SRC_IDX                 (W5_REG_BASE + 0x154)
672 /*
673  * #define W5_RET_ENC_PIC_NUM                      (W5_REG_BASE + 0x158)
674  * => encoded picture number
675  */
676 #define W5_RET_ENC_VCL_NUT                      (W5_REG_BASE + 0x15C)
677 /*
678  * Only for H264:
679  * #define W5_RET_ENC_PIC_DIST_LOW                 (W5_REG_BASE + 0x164)
680  * => lower 32 bits of the sum of squared difference between source Y picture
681  *    and reconstructed Y picture
682  * #define W5_RET_ENC_PIC_DIST_HIGH                (W5_REG_BASE + 0x168)
683  * => upper 32 bits of the sum of squared difference between source Y picture
684  *    and reconstructed Y picture
685  */
686 #define W5_RET_ENC_PIC_MAX_LATENCY_PICS     (W5_REG_BASE + 0x16C)
687 
688 #define W5_RET_ENC_HOST_CMD_TICK                (W5_REG_BASE + 0x1B8)
689 /*
690  * #define W5_RET_ENC_PREPARE_START_TICK           (W5_REG_BASE + 0x1BC)
691  * #define W5_RET_ENC_PREPARE_END_TICK             (W5_REG_BASE + 0x1C0)
692  * => Start and end ticks for preparing slices of the picture
693  * #define W5_RET_ENC_PROCESSING_START_TICK        (W5_REG_BASE + 0x1C4)
694  * #define W5_RET_ENC_PROCESSING_END_TICK          (W5_REG_BASE + 0x1C8)
695  * => Start and end ticks for processing slices of the picture
696  * #define W5_RET_ENC_ENCODING_START_TICK          (W5_REG_BASE + 0x1CC)
697  * => Start tick for encoding slices of the picture
698  */
699 #define W5_RET_ENC_ENCODING_END_TICK            (W5_REG_BASE + 0x1D0)
700 
701 #define W5_RET_ENC_WARN_INFO                    (W5_REG_BASE + 0x1D4)
702 #define W5_RET_ENC_ERR_INFO                     (W5_REG_BASE + 0x1D8)
703 #define W5_RET_ENC_ENCODING_SUCCESS             (W5_REG_BASE + 0x1DC)
704 
705 /************************************************************************/
706 /* ENCODER - QUERY (GET_BS_WR_PTR)                                      */
707 /************************************************************************/
708 #define W5_RET_ENC_RD_PTR                       (W5_REG_BASE + 0x114)
709 #define W5_RET_ENC_WR_PTR                       (W5_REG_BASE + 0x118)
710 #define W5_CMD_ENC_REASON_SEL                   (W5_REG_BASE + 0x11C)
711 
712 /************************************************************************/
713 /* ENCODER - QUERY (GET_BW_REPORT)                                      */
714 /************************************************************************/
715 #define RET_QUERY_BW_PRP_AXI_READ               (W5_REG_BASE + 0x118)
716 #define RET_QUERY_BW_PRP_AXI_WRITE              (W5_REG_BASE + 0x11C)
717 #define RET_QUERY_BW_FBD_Y_AXI_READ             (W5_REG_BASE + 0x120)
718 #define RET_QUERY_BW_FBC_Y_AXI_WRITE            (W5_REG_BASE + 0x124)
719 #define RET_QUERY_BW_FBD_C_AXI_READ             (W5_REG_BASE + 0x128)
720 #define RET_QUERY_BW_FBC_C_AXI_WRITE            (W5_REG_BASE + 0x12C)
721 #define RET_QUERY_BW_PRI_AXI_READ               (W5_REG_BASE + 0x130)
722 #define RET_QUERY_BW_PRI_AXI_WRITE              (W5_REG_BASE + 0x134)
723 #define RET_QUERY_BW_SEC_AXI_READ               (W5_REG_BASE + 0x138)
724 #define RET_QUERY_BW_SEC_AXI_WRITE              (W5_REG_BASE + 0x13C)
725 #define RET_QUERY_BW_PROC_AXI_READ              (W5_REG_BASE + 0x140)
726 #define RET_QUERY_BW_PROC_AXI_WRITE             (W5_REG_BASE + 0x144)
727 #define RET_QUERY_BW_BWB_AXI_WRITE              (W5_REG_BASE + 0x148)
728 #define W5_CMD_BW_OPTION                        (W5_REG_BASE + 0x14C)
729 
730 /************************************************************************/
731 /* ENCODER - QUERY (GET_SRC_FLAG)                                       */
732 /************************************************************************/
733 #define W5_RET_RELEASED_SRC_INSTANCE            (W5_REG_BASE + 0x1EC)
734 
735 #define W5_ENC_PIC_SUB_FRAME_SYNC_IF            (W5_REG_BASE + 0x0300)
736 
737 #endif /* __WAVE5_REGISTER_DEFINE_H__ */
738