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

source code of linux/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_dwb.h