Home | History | Annotate | Line # | Download | only in dcn20
      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