xref: /netbsd-src/sys/external/bsd/drm2/dist/drm/amd/display/dc/dcn20/dcn20_dwb.h (revision 41ec02673d281bbb3d38e6c78504ce6e30c228c1)
1 /*	$NetBSD: dcn20_dwb.h,v 1.2 2021/12/18 23:45:03 riastradh Exp $	*/
2 
3 /* Copyright 2012-17 Advanced Micro Devices, Inc.
4  *
5  * Permission is hereby granted, free of charge, to any person obtaining a
6  * copy of this software and associated documentation files (the "Software"),
7  * to deal in the Software without restriction, including without limitation
8  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9  * and/or sell copies of the Software, and to permit persons to whom the
10  * Software is furnished to do so, subject to the following conditions:
11  *
12  * The above copyright notice and this permission notice shall be included in
13  * all copies or substantial portions of the Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
19  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
20  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
21  * OTHER DEALINGS IN THE SOFTWARE.
22  *
23  * Authors: AMD
24  *
25  */
26 #ifndef __DC_DWBC_DCN20_H__
27 #define __DC_DWBC_DCN20_H__
28 
29 #define TO_DCN20_DWBC(dwbc_base) \
30 	container_of(dwbc_base, struct dcn20_dwbc, base)
31 
32 /* DCN */
33 #define BASE_INNER(seg) \
34 	DCE_BASE__INST0_SEG ## seg
35 
36 #define BASE(seg) \
37 	BASE_INNER(seg)
38 
39 #define SR(reg_name)\
40 		.reg_name = BASE(mm ## reg_name ## _BASE_IDX) +  \
41 					mm ## reg_name
42 
43 #define SRI(reg_name, block, id)\
44 	.reg_name = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \
45 					mm ## block ## id ## _ ## reg_name
46 
47 #define SRI2(reg_name, block, id)\
48 	.reg_name = BASE(mm ## reg_name ## _BASE_IDX) + \
49 					mm ## reg_name
50 
51 #define SRII(reg_name, block, id)\
52 	.reg_name[id] = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \
53 					mm ## block ## id ## _ ## reg_name
54 
55 #define SF(reg_name, field_name, post_fix)\
56 	.field_name = reg_name ## __ ## field_name ## post_fix
57 
58 
59 #define DWBC_COMMON_REG_LIST_DCN2_0(inst) \
60 	SRI2(WB_ENABLE, CNV, inst),\
61 	SRI2(WB_EC_CONFIG, CNV, inst),\
62 	SRI2(CNV_MODE, CNV, inst),\
63 	SRI2(CNV_WINDOW_START, CNV, inst),\
64 	SRI2(CNV_WINDOW_SIZE, CNV, inst),\
65 	SRI2(CNV_UPDATE, CNV, inst),\
66 	SRI2(CNV_SOURCE_SIZE, CNV, inst),\
67 	SRI2(CNV_TEST_CNTL, CNV, inst),\
68 	SRI2(CNV_TEST_CRC_RED, CNV, inst),\
69 	SRI2(CNV_TEST_CRC_GREEN, CNV, inst),\
70 	SRI2(CNV_TEST_CRC_BLUE, CNV, inst),\
71 	SRI2(WBSCL_COEF_RAM_SELECT, WBSCL, inst),\
72 	SRI2(WBSCL_COEF_RAM_TAP_DATA, WBSCL, inst),\
73 	SRI2(WBSCL_MODE, WBSCL, inst),\
74 	SRI2(WBSCL_TAP_CONTROL, WBSCL, inst),\
75 	SRI2(WBSCL_DEST_SIZE, WBSCL, inst),\
76 	SRI2(WBSCL_HORZ_FILTER_SCALE_RATIO, WBSCL, inst),\
77 	SRI2(WBSCL_HORZ_FILTER_INIT_Y_RGB, WBSCL, inst),\
78 	SRI2(WBSCL_HORZ_FILTER_INIT_CBCR, WBSCL, inst),\
79 	SRI2(WBSCL_VERT_FILTER_SCALE_RATIO, WBSCL, inst),\
80 	SRI2(WBSCL_VERT_FILTER_INIT_Y_RGB, WBSCL, inst),\
81 	SRI2(WBSCL_VERT_FILTER_INIT_CBCR, WBSCL, inst),\
82 	SRI2(WBSCL_ROUND_OFFSET, WBSCL, inst),\
83 	SRI2(WBSCL_OVERFLOW_STATUS, WBSCL, inst),\
84 	SRI2(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL, inst),\
85 	SRI2(WBSCL_TEST_CNTL, WBSCL, inst),\
86 	SRI2(WBSCL_TEST_CRC_RED, WBSCL, inst),\
87 	SRI2(WBSCL_TEST_CRC_GREEN, WBSCL, inst),\
88 	SRI2(WBSCL_TEST_CRC_BLUE, WBSCL, inst),\
89 	SRI2(WBSCL_BACKPRESSURE_CNT_EN, WBSCL, inst),\
90 	SRI2(WB_MCIF_BACKPRESSURE_CNT, WBSCL, inst),\
91 	SRI2(WBSCL_CLAMP_Y_RGB, WBSCL, inst),\
92 	SRI2(WBSCL_CLAMP_CBCR, WBSCL, inst),\
93 	SRI2(WBSCL_OUTSIDE_PIX_STRATEGY, WBSCL, inst),\
94 	SRI2(WBSCL_OUTSIDE_PIX_STRATEGY_CBCR, WBSCL, inst),\
95 	SRI2(WBSCL_DEBUG, WBSCL, inst),\
96 	SRI2(WBSCL_TEST_DEBUG_INDEX, WBSCL, inst),\
97 	SRI2(WBSCL_TEST_DEBUG_DATA, WBSCL, inst),\
98 	SRI2(WB_DEBUG_CTRL, CNV, inst),\
99 	SRI2(WB_DBG_MODE, CNV, inst),\
100 	SRI2(WB_HW_DEBUG, CNV, inst),\
101 	SRI2(CNV_TEST_DEBUG_INDEX, CNV, inst),\
102 	SRI2(CNV_TEST_DEBUG_DATA, CNV, inst),\
103 	SRI2(WB_SOFT_RESET, CNV, inst),\
104 	SRI2(WB_WARM_UP_MODE_CTL1, CNV, inst),\
105 	SRI2(WB_WARM_UP_MODE_CTL2, CNV, inst)
106 
107 #define DWBC_COMMON_MASK_SH_LIST_DCN2_0(mask_sh) \
108 	SF(WB_ENABLE, WB_ENABLE, mask_sh),\
109 	SF(WB_EC_CONFIG, DISPCLK_R_WB_GATE_DIS, mask_sh),\
110 	SF(WB_EC_CONFIG, DISPCLK_G_WB_GATE_DIS, mask_sh),\
111 	SF(WB_EC_CONFIG, DISPCLK_G_WBSCL_GATE_DIS, mask_sh),\
112 	SF(WB_EC_CONFIG, WB_TEST_CLK_SEL, mask_sh),\
113 	SF(WB_EC_CONFIG, WB_LB_LS_DIS, mask_sh),\
114 	SF(WB_EC_CONFIG, WB_LB_SD_DIS, mask_sh),\
115 	SF(WB_EC_CONFIG, WB_LUT_LS_DIS, mask_sh),\
116 	SF(WB_EC_CONFIG, WBSCL_LB_MEM_PWR_MODE_SEL, mask_sh),\
117 	SF(WB_EC_CONFIG, WBSCL_LB_MEM_PWR_DIS, mask_sh),\
118 	SF(WB_EC_CONFIG, WBSCL_LB_MEM_PWR_FORCE, mask_sh),\
119 	SF(WB_EC_CONFIG, WBSCL_LB_MEM_PWR_STATE, mask_sh),\
120 	SF(WB_EC_CONFIG, WB_RAM_PW_SAVE_MODE, mask_sh),\
121 	SF(WB_EC_CONFIG, WBSCL_LUT_MEM_PWR_STATE, mask_sh),\
122 	SF(CNV_MODE, CNV_OUT_BPC, mask_sh),\
123 	SF(CNV_MODE, CNV_FRAME_CAPTURE_RATE, mask_sh),\
124 	SF(CNV_MODE, CNV_WINDOW_CROP_EN, mask_sh),\
125 	SF(CNV_MODE, CNV_STEREO_TYPE, mask_sh),\
126 	SF(CNV_MODE, CNV_INTERLACED_MODE, mask_sh),\
127 	SF(CNV_MODE, CNV_EYE_SELECTION, mask_sh),\
128 	SF(CNV_MODE, CNV_STEREO_POLARITY, mask_sh),\
129 	SF(CNV_MODE, CNV_INTERLACED_FIELD_ORDER, mask_sh),\
130 	SF(CNV_MODE, CNV_STEREO_SPLIT, mask_sh),\
131 	SF(CNV_MODE, CNV_NEW_CONTENT, mask_sh),\
132 	SF(CNV_MODE, CNV_FRAME_CAPTURE_EN_CURRENT, mask_sh),\
133 	SF(CNV_MODE, CNV_FRAME_CAPTURE_EN, mask_sh),\
134 	SF(CNV_WINDOW_START, CNV_WINDOW_START_X, mask_sh),\
135 	SF(CNV_WINDOW_START, CNV_WINDOW_START_Y, mask_sh),\
136 	SF(CNV_WINDOW_SIZE, CNV_WINDOW_WIDTH, mask_sh),\
137 	SF(CNV_WINDOW_SIZE, CNV_WINDOW_HEIGHT, mask_sh),\
138 	SF(CNV_UPDATE, CNV_UPDATE_PENDING, mask_sh),\
139 	SF(CNV_UPDATE, CNV_UPDATE_TAKEN, mask_sh),\
140 	SF(CNV_UPDATE, CNV_UPDATE_LOCK, mask_sh),\
141 	SF(CNV_SOURCE_SIZE, CNV_SOURCE_WIDTH, mask_sh),\
142 	SF(CNV_SOURCE_SIZE, CNV_SOURCE_HEIGHT, mask_sh),\
143 	SF(CNV_TEST_CNTL, CNV_TEST_CRC_EN, mask_sh),\
144 	SF(CNV_TEST_CNTL, CNV_TEST_CRC_CONT_EN, mask_sh),\
145 	SF(CNV_TEST_CRC_RED, CNV_TEST_CRC_RED_MASK, mask_sh),\
146 	SF(CNV_TEST_CRC_RED, CNV_TEST_CRC_SIG_RED, mask_sh),\
147 	SF(CNV_TEST_CRC_GREEN, CNV_TEST_CRC_GREEN_MASK, mask_sh),\
148 	SF(CNV_TEST_CRC_GREEN, CNV_TEST_CRC_SIG_GREEN, mask_sh),\
149 	SF(CNV_TEST_CRC_BLUE, CNV_TEST_CRC_BLUE_MASK, mask_sh),\
150 	SF(CNV_TEST_CRC_BLUE, CNV_TEST_CRC_SIG_BLUE, mask_sh),\
151 	SF(WB_DEBUG_CTRL, WB_DEBUG_EN, mask_sh),\
152 	SF(WB_DEBUG_CTRL, WB_DEBUG_SEL, mask_sh),\
153 	SF(WB_DBG_MODE, WB_DBG_MODE_EN, mask_sh),\
154 	SF(WB_DBG_MODE, WB_DBG_DIN_FMT, mask_sh),\
155 	SF(WB_DBG_MODE, WB_DBG_36MODE, mask_sh),\
156 	SF(WB_DBG_MODE, WB_DBG_CMAP, mask_sh),\
157 	SF(WB_DBG_MODE, WB_DBG_PXLRATE_ERROR, mask_sh),\
158 	SF(WB_DBG_MODE, WB_DBG_SOURCE_WIDTH, mask_sh),\
159 	SF(WB_HW_DEBUG, WB_HW_DEBUG, mask_sh),\
160 	SF(WB_SOFT_RESET, WB_SOFT_RESET, mask_sh),\
161 	SF(CNV_TEST_DEBUG_INDEX, CNV_TEST_DEBUG_INDEX, mask_sh),\
162 	SF(CNV_TEST_DEBUG_INDEX, CNV_TEST_DEBUG_WRITE_EN, mask_sh),\
163 	SF(CNV_TEST_DEBUG_DATA, CNV_TEST_DEBUG_DATA, mask_sh),\
164 	SF(WBSCL_COEF_RAM_SELECT, WBSCL_COEF_RAM_TAP_PAIR_IDX, mask_sh),\
165 	SF(WBSCL_COEF_RAM_SELECT, WBSCL_COEF_RAM_PHASE, mask_sh),\
166 	SF(WBSCL_COEF_RAM_SELECT, WBSCL_COEF_RAM_FILTER_TYPE, mask_sh),\
167 	SF(WBSCL_COEF_RAM_TAP_DATA, WBSCL_COEF_RAM_EVEN_TAP_COEF, mask_sh),\
168 	SF(WBSCL_COEF_RAM_TAP_DATA, WBSCL_COEF_RAM_EVEN_TAP_COEF_EN, mask_sh),\
169 	SF(WBSCL_COEF_RAM_TAP_DATA, WBSCL_COEF_RAM_ODD_TAP_COEF, mask_sh),\
170 	SF(WBSCL_COEF_RAM_TAP_DATA, WBSCL_COEF_RAM_ODD_TAP_COEF_EN, mask_sh),\
171 	SF(WBSCL_MODE, WBSCL_MODE, mask_sh),\
172 	SF(WBSCL_MODE, WBSCL_OUT_BIT_DEPTH, mask_sh),\
173 	SF(WBSCL_TAP_CONTROL, WBSCL_V_NUM_OF_TAPS_Y_RGB, mask_sh),\
174 	SF(WBSCL_TAP_CONTROL, WBSCL_V_NUM_OF_TAPS_CBCR, mask_sh),\
175 	SF(WBSCL_TAP_CONTROL, WBSCL_H_NUM_OF_TAPS_Y_RGB, mask_sh),\
176 	SF(WBSCL_TAP_CONTROL, WBSCL_H_NUM_OF_TAPS_CBCR, mask_sh),\
177 	SF(WBSCL_DEST_SIZE, WBSCL_DEST_HEIGHT, mask_sh),\
178 	SF(WBSCL_DEST_SIZE, WBSCL_DEST_WIDTH, mask_sh),\
179 	SF(WBSCL_HORZ_FILTER_SCALE_RATIO, WBSCL_H_SCALE_RATIO, mask_sh),\
180 	SF(WBSCL_HORZ_FILTER_INIT_Y_RGB, WBSCL_H_INIT_FRAC_Y_RGB, mask_sh),\
181 	SF(WBSCL_HORZ_FILTER_INIT_Y_RGB, WBSCL_H_INIT_INT_Y_RGB, mask_sh),\
182 	SF(WBSCL_HORZ_FILTER_INIT_CBCR, WBSCL_H_INIT_FRAC_CBCR, mask_sh),\
183 	SF(WBSCL_HORZ_FILTER_INIT_CBCR, WBSCL_H_INIT_INT_CBCR, mask_sh),\
184 	SF(WBSCL_VERT_FILTER_SCALE_RATIO, WBSCL_V_SCALE_RATIO, mask_sh),\
185 	SF(WBSCL_VERT_FILTER_INIT_Y_RGB, WBSCL_V_INIT_FRAC_Y_RGB, mask_sh),\
186 	SF(WBSCL_VERT_FILTER_INIT_Y_RGB, WBSCL_V_INIT_INT_Y_RGB, mask_sh),\
187 	SF(WBSCL_VERT_FILTER_INIT_CBCR, WBSCL_V_INIT_FRAC_CBCR, mask_sh),\
188 	SF(WBSCL_VERT_FILTER_INIT_CBCR, WBSCL_V_INIT_INT_CBCR, mask_sh),\
189 	SF(WBSCL_ROUND_OFFSET, WBSCL_ROUND_OFFSET_Y_RGB, mask_sh),\
190 	SF(WBSCL_ROUND_OFFSET, WBSCL_ROUND_OFFSET_CBCR, mask_sh),\
191 	SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_FLAG, mask_sh),\
192 	SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_ACK, mask_sh),\
193 	SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_MASK, mask_sh),\
194 	SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_INT_STATUS, mask_sh),\
195 	SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_INT_TYPE, mask_sh),\
196 	SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_FLAG, mask_sh),\
197 	SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_ACK, mask_sh),\
198 	SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_MASK, mask_sh),\
199 	SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_INT_STATUS, mask_sh),\
200 	SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_INT_TYPE, mask_sh),\
201 	SF(WBSCL_TEST_CNTL, WBSCL_TEST_CRC_EN, mask_sh),\
202 	SF(WBSCL_TEST_CNTL, WBSCL_TEST_CRC_CONT_EN, mask_sh),\
203 	SF(WBSCL_TEST_CRC_RED, WBSCL_TEST_CRC_RED_MASK, mask_sh),\
204 	SF(WBSCL_TEST_CRC_RED, WBSCL_TEST_CRC_SIG_RED, mask_sh),\
205 	SF(WBSCL_TEST_CRC_GREEN, WBSCL_TEST_CRC_GREEN_MASK, mask_sh),\
206 	SF(WBSCL_TEST_CRC_GREEN, WBSCL_TEST_CRC_SIG_GREEN, mask_sh),\
207 	SF(WBSCL_TEST_CRC_BLUE, WBSCL_TEST_CRC_BLUE_MASK, mask_sh),\
208 	SF(WBSCL_TEST_CRC_BLUE, WBSCL_TEST_CRC_SIG_BLUE, mask_sh),\
209 	SF(WBSCL_BACKPRESSURE_CNT_EN, WBSCL_BACKPRESSURE_CNT_EN, mask_sh),\
210 	SF(WB_MCIF_BACKPRESSURE_CNT, WB_MCIF_Y_MAX_BACKPRESSURE, mask_sh),\
211 	SF(WB_MCIF_BACKPRESSURE_CNT, WB_MCIF_C_MAX_BACKPRESSURE, mask_sh),\
212 	SF(WBSCL_CLAMP_Y_RGB, WBSCL_CLAMP_UPPER_Y_RGB, mask_sh),\
213 	SF(WBSCL_CLAMP_Y_RGB, WBSCL_CLAMP_LOWER_Y_RGB, mask_sh),\
214 	SF(WBSCL_CLAMP_CBCR, WBSCL_CLAMP_UPPER_CBCR, mask_sh),\
215 	SF(WBSCL_CLAMP_CBCR, WBSCL_CLAMP_LOWER_CBCR, mask_sh),\
216 	SF(WBSCL_OUTSIDE_PIX_STRATEGY, WBSCL_OUTSIDE_PIX_STRATEGY, mask_sh),\
217 	SF(WBSCL_OUTSIDE_PIX_STRATEGY, WBSCL_BLACK_COLOR_G_Y, mask_sh),\
218 	SF(WBSCL_OUTSIDE_PIX_STRATEGY_CBCR, WBSCL_BLACK_COLOR_B_CB, mask_sh),\
219 	SF(WBSCL_OUTSIDE_PIX_STRATEGY_CBCR, WBSCL_BLACK_COLOR_R_CR, mask_sh),\
220 	SF(WBSCL_DEBUG, WBSCL_DEBUG, mask_sh),\
221 	SF(WBSCL_TEST_DEBUG_INDEX, WBSCL_TEST_DEBUG_INDEX, mask_sh),\
222 	SF(WBSCL_TEST_DEBUG_INDEX, WBSCL_TEST_DEBUG_WRITE_EN, mask_sh),\
223 	SF(WBSCL_TEST_DEBUG_DATA, WBSCL_TEST_DEBUG_DATA, mask_sh),\
224 	SF(WB_WARM_UP_MODE_CTL1, WIDTH_WARMUP, mask_sh),\
225 	SF(WB_WARM_UP_MODE_CTL1, HEIGHT_WARMUP, mask_sh),\
226 	SF(WB_WARM_UP_MODE_CTL1, GMC_WARM_UP_ENABLE, mask_sh),\
227 	SF(WB_WARM_UP_MODE_CTL2, DATA_VALUE_WARMUP, mask_sh),\
228 	SF(WB_WARM_UP_MODE_CTL2, MODE_WARMUP, mask_sh),\
229 	SF(WB_WARM_UP_MODE_CTL2, DATA_DEPTH_WARMUP, mask_sh)
230 
231 #define DWBC_REG_FIELD_LIST_DCN2_0(type) \
232 	type WB_ENABLE;\
233 	type DISPCLK_R_WB_GATE_DIS;\
234 	type DISPCLK_G_WB_GATE_DIS;\
235 	type DISPCLK_G_WBSCL_GATE_DIS;\
236 	type WB_TEST_CLK_SEL;\
237 	type WB_LB_LS_DIS;\
238 	type WB_LB_SD_DIS;\
239 	type WB_LUT_LS_DIS;\
240 	type WBSCL_LB_MEM_PWR_MODE_SEL;\
241 	type WBSCL_LB_MEM_PWR_DIS;\
242 	type WBSCL_LB_MEM_PWR_FORCE;\
243 	type WBSCL_LB_MEM_PWR_STATE;\
244 	type WB_RAM_PW_SAVE_MODE;\
245 	type WBSCL_LUT_MEM_PWR_STATE;\
246 	type CNV_OUT_BPC;\
247 	type CNV_FRAME_CAPTURE_RATE;\
248 	type CNV_WINDOW_CROP_EN;\
249 	type CNV_STEREO_TYPE;\
250 	type CNV_INTERLACED_MODE;\
251 	type CNV_EYE_SELECTION;\
252 	type CNV_STEREO_POLARITY;\
253 	type CNV_INTERLACED_FIELD_ORDER;\
254 	type CNV_STEREO_SPLIT;\
255 	type CNV_NEW_CONTENT;\
256 	type CNV_FRAME_CAPTURE_EN_CURRENT;\
257 	type CNV_FRAME_CAPTURE_EN;\
258 	type CNV_WINDOW_START_X;\
259 	type CNV_WINDOW_START_Y;\
260 	type CNV_WINDOW_WIDTH;\
261 	type CNV_WINDOW_HEIGHT;\
262 	type CNV_UPDATE_PENDING;\
263 	type CNV_UPDATE_TAKEN;\
264 	type CNV_UPDATE_LOCK;\
265 	type CNV_SOURCE_WIDTH;\
266 	type CNV_SOURCE_HEIGHT;\
267 	type CNV_TEST_CRC_EN;\
268 	type CNV_TEST_CRC_CONT_EN;\
269 	type CNV_TEST_CRC_RED_MASK;\
270 	type CNV_TEST_CRC_SIG_RED;\
271 	type CNV_TEST_CRC_GREEN_MASK;\
272 	type CNV_TEST_CRC_SIG_GREEN;\
273 	type CNV_TEST_CRC_BLUE_MASK;\
274 	type CNV_TEST_CRC_SIG_BLUE;\
275 	type WB_DEBUG_EN;\
276 	type WB_DEBUG_SEL;\
277 	type WB_DBG_MODE_EN;\
278 	type WB_DBG_DIN_FMT;\
279 	type WB_DBG_36MODE;\
280 	type WB_DBG_CMAP;\
281 	type WB_DBG_PXLRATE_ERROR;\
282 	type WB_DBG_SOURCE_WIDTH;\
283 	type WB_HW_DEBUG;\
284 	type CNV_TEST_DEBUG_INDEX;\
285 	type CNV_TEST_DEBUG_WRITE_EN;\
286 	type CNV_TEST_DEBUG_DATA;\
287 	type WB_SOFT_RESET;\
288 	type WBSCL_COEF_RAM_TAP_PAIR_IDX;\
289 	type WBSCL_COEF_RAM_PHASE;\
290 	type WBSCL_COEF_RAM_FILTER_TYPE;\
291 	type WBSCL_COEF_RAM_SEL;\
292 	type WBSCL_COEF_RAM_SEL_CURRENT;\
293 	type WBSCL_COEF_RAM_RD_SEL;\
294 	type WBSCL_COEF_RAM_EVEN_TAP_COEF;\
295 	type WBSCL_COEF_RAM_EVEN_TAP_COEF_EN;\
296 	type WBSCL_COEF_RAM_ODD_TAP_COEF;\
297 	type WBSCL_COEF_RAM_ODD_TAP_COEF_EN;\
298 	type WBSCL_MODE;\
299 	type WBSCL_OUT_BIT_DEPTH;\
300 	type WBSCL_V_NUM_OF_TAPS_Y_RGB;\
301 	type WBSCL_V_NUM_OF_TAPS_CBCR;\
302 	type WBSCL_H_NUM_OF_TAPS_Y_RGB;\
303 	type WBSCL_H_NUM_OF_TAPS_CBCR;\
304 	type WBSCL_DEST_HEIGHT;\
305 	type WBSCL_DEST_WIDTH;\
306 	type WBSCL_H_SCALE_RATIO;\
307 	type WBSCL_H_INIT_FRAC_Y_RGB;\
308 	type WBSCL_H_INIT_INT_Y_RGB;\
309 	type WBSCL_H_INIT_FRAC_CBCR;\
310 	type WBSCL_H_INIT_INT_CBCR;\
311 	type WBSCL_V_SCALE_RATIO;\
312 	type WBSCL_V_INIT_FRAC_Y_RGB;\
313 	type WBSCL_V_INIT_INT_Y_RGB;\
314 	type WBSCL_V_INIT_FRAC_CBCR;\
315 	type WBSCL_V_INIT_INT_CBCR;\
316 	type WBSCL_ROUND_OFFSET_Y_RGB;\
317 	type WBSCL_ROUND_OFFSET_CBCR;\
318 	type WBSCL_DATA_OVERFLOW_FLAG;\
319 	type WBSCL_DATA_OVERFLOW_ACK;\
320 	type WBSCL_DATA_OVERFLOW_MASK;\
321 	type WBSCL_DATA_OVERFLOW_INT_STATUS;\
322 	type WBSCL_DATA_OVERFLOW_INT_TYPE;\
323 	type WBSCL_HOST_CONFLICT_FLAG;\
324 	type WBSCL_HOST_CONFLICT_ACK;\
325 	type WBSCL_HOST_CONFLICT_MASK;\
326 	type WBSCL_HOST_CONFLICT_INT_STATUS;\
327 	type WBSCL_HOST_CONFLICT_INT_TYPE;\
328 	type WBSCL_TEST_CRC_EN;\
329 	type WBSCL_TEST_CRC_CONT_EN;\
330 	type WBSCL_TEST_CRC_RED_MASK;\
331 	type WBSCL_TEST_CRC_SIG_RED;\
332 	type WBSCL_TEST_CRC_GREEN_MASK;\
333 	type WBSCL_TEST_CRC_SIG_GREEN;\
334 	type WBSCL_TEST_CRC_BLUE_MASK;\
335 	type WBSCL_TEST_CRC_SIG_BLUE;\
336 	type WBSCL_BACKPRESSURE_CNT_EN;\
337 	type WB_MCIF_Y_MAX_BACKPRESSURE;\
338 	type WB_MCIF_C_MAX_BACKPRESSURE;\
339 	type WBSCL_CLAMP_UPPER_Y_RGB;\
340 	type WBSCL_CLAMP_LOWER_Y_RGB;\
341 	type WBSCL_CLAMP_UPPER_CBCR;\
342 	type WBSCL_CLAMP_LOWER_CBCR;\
343 	type WBSCL_OUTSIDE_PIX_STRATEGY;\
344 	type WBSCL_BLACK_COLOR_G_Y;\
345 	type WBSCL_BLACK_COLOR_B_CB;\
346 	type WBSCL_BLACK_COLOR_R_CR;\
347 	type WBSCL_DEBUG;\
348 	type WBSCL_TEST_DEBUG_INDEX;\
349 	type WBSCL_TEST_DEBUG_WRITE_EN;\
350 	type WBSCL_TEST_DEBUG_DATA;\
351 	type WIDTH_WARMUP;\
352 	type HEIGHT_WARMUP;\
353 	type GMC_WARM_UP_ENABLE;\
354 	type DATA_VALUE_WARMUP;\
355 	type MODE_WARMUP;\
356 	type DATA_DEPTH_WARMUP; \
357 
358 struct dcn20_dwbc_registers {
359 	/* DCN2.0 */
360 	uint32_t WB_ENABLE;
361 	uint32_t WB_EC_CONFIG;
362 	uint32_t CNV_MODE;
363 	uint32_t CNV_WINDOW_START;
364 	uint32_t CNV_WINDOW_SIZE;
365 	uint32_t CNV_UPDATE;
366 	uint32_t CNV_SOURCE_SIZE;
367 	uint32_t CNV_TEST_CNTL;
368 	uint32_t CNV_TEST_CRC_RED;
369 	uint32_t CNV_TEST_CRC_GREEN;
370 	uint32_t CNV_TEST_CRC_BLUE;
371 	uint32_t WB_DEBUG_CTRL;
372 	uint32_t WB_DBG_MODE;
373 	uint32_t WB_HW_DEBUG;
374 	uint32_t CNV_TEST_DEBUG_INDEX;
375 	uint32_t CNV_TEST_DEBUG_DATA;
376 	uint32_t WB_SOFT_RESET;
377 	uint32_t WBSCL_COEF_RAM_SELECT;
378 	uint32_t WBSCL_COEF_RAM_TAP_DATA;
379 	uint32_t WBSCL_MODE;
380 	uint32_t WBSCL_TAP_CONTROL;
381 	uint32_t WBSCL_DEST_SIZE;
382 	uint32_t WBSCL_HORZ_FILTER_SCALE_RATIO;
383 	uint32_t WBSCL_HORZ_FILTER_INIT_Y_RGB;
384 	uint32_t WBSCL_HORZ_FILTER_INIT_CBCR;
385 	uint32_t WBSCL_VERT_FILTER_SCALE_RATIO;
386 	uint32_t WBSCL_VERT_FILTER_INIT_Y_RGB;
387 	uint32_t WBSCL_VERT_FILTER_INIT_CBCR;
388 	uint32_t WBSCL_ROUND_OFFSET;
389 	uint32_t WBSCL_OVERFLOW_STATUS;
390 	uint32_t WBSCL_COEF_RAM_CONFLICT_STATUS;
391 	uint32_t WBSCL_TEST_CNTL;
392 	uint32_t WBSCL_TEST_CRC_RED;
393 	uint32_t WBSCL_TEST_CRC_GREEN;
394 	uint32_t WBSCL_TEST_CRC_BLUE;
395 	uint32_t WBSCL_BACKPRESSURE_CNT_EN;
396 	uint32_t WB_MCIF_BACKPRESSURE_CNT;
397 	uint32_t WBSCL_CLAMP_Y_RGB;
398 	uint32_t WBSCL_CLAMP_CBCR;
399 	uint32_t WBSCL_OUTSIDE_PIX_STRATEGY;
400 	uint32_t WBSCL_OUTSIDE_PIX_STRATEGY_CBCR;
401 	uint32_t WBSCL_DEBUG;
402 	uint32_t WBSCL_TEST_DEBUG_INDEX;
403 	uint32_t WBSCL_TEST_DEBUG_DATA;
404 	uint32_t WB_WARM_UP_MODE_CTL1;
405 	uint32_t WB_WARM_UP_MODE_CTL2;
406 };
407 
408 
409 struct dcn20_dwbc_mask {
410 	DWBC_REG_FIELD_LIST_DCN2_0(uint32_t)
411 };
412 
413 struct dcn20_dwbc_shift {
414 	DWBC_REG_FIELD_LIST_DCN2_0(uint8_t)
415 };
416 
417 struct dcn20_dwbc {
418 	struct dwbc base;
419 	const struct dcn20_dwbc_registers *dwbc_regs;
420 	const struct dcn20_dwbc_shift *dwbc_shift;
421 	const struct dcn20_dwbc_mask *dwbc_mask;
422 };
423 
424 void dcn20_dwbc_construct(struct dcn20_dwbc *dwbc20,
425 	struct dc_context *ctx,
426 	const struct dcn20_dwbc_registers *dwbc_regs,
427 	const struct dcn20_dwbc_shift *dwbc_shift,
428 	const struct dcn20_dwbc_mask *dwbc_mask,
429 	int inst);
430 
431 bool dwb2_disable(struct dwbc *dwbc);
432 
433 bool dwb2_is_enabled(struct dwbc *dwbc);
434 
435 void dwb2_set_stereo(struct dwbc *dwbc,
436 	struct dwb_stereo_params *stereo_params);
437 
438 void dwb2_set_new_content(struct dwbc *dwbc,
439 	bool is_new_content);
440 
441 void dwb2_config_dwb_cnv(struct dwbc *dwbc,
442 	struct dc_dwb_params *params);
443 
444 void dwb2_set_scaler(struct dwbc *dwbc, struct dc_dwb_params *params);
445 
446 bool dwb_program_vert_scalar(struct dcn20_dwbc *dwbc20,
447 	uint32_t src_height,
448 	uint32_t dest_height,
449 	struct scaling_taps num_taps,
450 	enum dwb_subsample_position subsample_position);
451 
452 bool dwb_program_horz_scalar(struct dcn20_dwbc *dwbc20,
453 	uint32_t src_width,
454 	uint32_t dest_width,
455 	struct scaling_taps num_taps);
456 
457 
458 #endif
459 
460 
461