linux/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_dwb.h
<<
>>
Prefs
   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/* DCN */
  31#define BASE_INNER(seg) \
  32        DCE_BASE__INST0_SEG ## seg
  33
  34#define BASE(seg) \
  35        BASE_INNER(seg)
  36
  37#define SR(reg_name)\
  38                .reg_name = BASE(mm ## reg_name ## _BASE_IDX) +  \
  39                                        mm ## reg_name
  40
  41#define SRI(reg_name, block, id)\
  42        .reg_name = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \
  43                                        mm ## block ## id ## _ ## reg_name
  44
  45#define SRI2(reg_name, block, id)\
  46        .reg_name = BASE(mm ## reg_name ## _BASE_IDX) + \
  47                                        mm ## reg_name
  48
  49#define SRII(reg_name, block, id)\
  50        .reg_name[id] = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \
  51                                        mm ## block ## id ## _ ## reg_name
  52
  53#define SF(reg_name, field_name, post_fix)\
  54        .field_name = reg_name ## __ ## field_name ## post_fix
  55
  56
  57#define DWBC_COMMON_REG_LIST_DCN2_0(inst) \
  58        SRI2(WB_ENABLE, CNV, inst),\
  59        SRI2(WB_EC_CONFIG, CNV, inst),\
  60        SRI2(CNV_MODE, CNV, inst),\
  61        SRI2(CNV_WINDOW_START, CNV, inst),\
  62        SRI2(CNV_WINDOW_SIZE, CNV, inst),\
  63        SRI2(CNV_UPDATE, CNV, inst),\
  64        SRI2(CNV_SOURCE_SIZE, CNV, inst),\
  65        SRI2(CNV_TEST_CNTL, CNV, inst),\
  66        SRI2(CNV_TEST_CRC_RED, CNV, inst),\
  67        SRI2(CNV_TEST_CRC_GREEN, CNV, inst),\
  68        SRI2(CNV_TEST_CRC_BLUE, CNV, inst),\
  69        SRI2(WBSCL_COEF_RAM_SELECT, WBSCL, inst),\
  70        SRI2(WBSCL_COEF_RAM_TAP_DATA, WBSCL, inst),\
  71        SRI2(WBSCL_MODE, WBSCL, inst),\
  72        SRI2(WBSCL_TAP_CONTROL, WBSCL, inst),\
  73        SRI2(WBSCL_DEST_SIZE, WBSCL, inst),\
  74        SRI2(WBSCL_HORZ_FILTER_SCALE_RATIO, WBSCL, inst),\
  75        SRI2(WBSCL_HORZ_FILTER_INIT_Y_RGB, WBSCL, inst),\
  76        SRI2(WBSCL_HORZ_FILTER_INIT_CBCR, WBSCL, inst),\
  77        SRI2(WBSCL_VERT_FILTER_SCALE_RATIO, WBSCL, inst),\
  78        SRI2(WBSCL_VERT_FILTER_INIT_Y_RGB, WBSCL, inst),\
  79        SRI2(WBSCL_VERT_FILTER_INIT_CBCR, WBSCL, inst),\
  80        SRI2(WBSCL_ROUND_OFFSET, WBSCL, inst),\
  81        SRI2(WBSCL_OVERFLOW_STATUS, WBSCL, inst),\
  82        SRI2(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL, inst),\
  83        SRI2(WBSCL_TEST_CNTL, WBSCL, inst),\
  84        SRI2(WBSCL_TEST_CRC_RED, WBSCL, inst),\
  85        SRI2(WBSCL_TEST_CRC_GREEN, WBSCL, inst),\
  86        SRI2(WBSCL_TEST_CRC_BLUE, WBSCL, inst),\
  87        SRI2(WBSCL_BACKPRESSURE_CNT_EN, WBSCL, inst),\
  88        SRI2(WB_MCIF_BACKPRESSURE_CNT, WBSCL, inst),\
  89        SRI2(WBSCL_CLAMP_Y_RGB, WBSCL, inst),\
  90        SRI2(WBSCL_CLAMP_CBCR, WBSCL, inst),\
  91        SRI2(WBSCL_OUTSIDE_PIX_STRATEGY, WBSCL, inst),\
  92        SRI2(WBSCL_OUTSIDE_PIX_STRATEGY_CBCR, WBSCL, inst),\
  93        SRI2(WBSCL_DEBUG, WBSCL, inst),\
  94        SRI2(WBSCL_TEST_DEBUG_INDEX, WBSCL, inst),\
  95        SRI2(WBSCL_TEST_DEBUG_DATA, WBSCL, inst),\
  96        SRI2(WB_DEBUG_CTRL, CNV, inst),\
  97        SRI2(WB_DBG_MODE, CNV, inst),\
  98        SRI2(WB_HW_DEBUG, CNV, inst),\
  99        SRI2(CNV_TEST_DEBUG_INDEX, CNV, inst),\
 100        SRI2(CNV_TEST_DEBUG_DATA, CNV, inst),\
 101        SRI2(WB_SOFT_RESET, CNV, inst),\
 102        SRI2(WB_WARM_UP_MODE_CTL1, CNV, inst),\
 103        SRI2(WB_WARM_UP_MODE_CTL2, CNV, inst)
 104
 105#define DWBC_COMMON_MASK_SH_LIST_DCN2_0(mask_sh) \
 106        SF(WB_ENABLE, WB_ENABLE, mask_sh),\
 107        SF(WB_EC_CONFIG, DISPCLK_R_WB_GATE_DIS, mask_sh),\
 108        SF(WB_EC_CONFIG, DISPCLK_G_WB_GATE_DIS, mask_sh),\
 109        SF(WB_EC_CONFIG, DISPCLK_G_WBSCL_GATE_DIS, mask_sh),\
 110        SF(WB_EC_CONFIG, WB_TEST_CLK_SEL, mask_sh),\
 111        SF(WB_EC_CONFIG, WB_LB_LS_DIS, mask_sh),\
 112        SF(WB_EC_CONFIG, WB_LB_SD_DIS, mask_sh),\
 113        SF(WB_EC_CONFIG, WB_LUT_LS_DIS, mask_sh),\
 114        SF(WB_EC_CONFIG, WBSCL_LB_MEM_PWR_MODE_SEL, mask_sh),\
 115        SF(WB_EC_CONFIG, WBSCL_LB_MEM_PWR_DIS, mask_sh),\
 116        SF(WB_EC_CONFIG, WBSCL_LB_MEM_PWR_FORCE, mask_sh),\
 117        SF(WB_EC_CONFIG, WBSCL_LB_MEM_PWR_STATE, mask_sh),\
 118        SF(WB_EC_CONFIG, WB_RAM_PW_SAVE_MODE, mask_sh),\
 119        SF(WB_EC_CONFIG, WBSCL_LUT_MEM_PWR_STATE, mask_sh),\
 120        SF(CNV_MODE, CNV_OUT_BPC, mask_sh),\
 121        SF(CNV_MODE, CNV_FRAME_CAPTURE_RATE, mask_sh),\
 122        SF(CNV_MODE, CNV_WINDOW_CROP_EN, mask_sh),\
 123        SF(CNV_MODE, CNV_STEREO_TYPE, mask_sh),\
 124        SF(CNV_MODE, CNV_INTERLACED_MODE, mask_sh),\
 125        SF(CNV_MODE, CNV_EYE_SELECTION, mask_sh),\
 126        SF(CNV_MODE, CNV_STEREO_POLARITY, mask_sh),\
 127        SF(CNV_MODE, CNV_INTERLACED_FIELD_ORDER, mask_sh),\
 128        SF(CNV_MODE, CNV_STEREO_SPLIT, mask_sh),\
 129        SF(CNV_MODE, CNV_NEW_CONTENT, mask_sh),\
 130        SF(CNV_MODE, CNV_FRAME_CAPTURE_EN_CURRENT, mask_sh),\
 131        SF(CNV_MODE, CNV_FRAME_CAPTURE_EN, mask_sh),\
 132        SF(CNV_WINDOW_START, CNV_WINDOW_START_X, mask_sh),\
 133        SF(CNV_WINDOW_START, CNV_WINDOW_START_Y, mask_sh),\
 134        SF(CNV_WINDOW_SIZE, CNV_WINDOW_WIDTH, mask_sh),\
 135        SF(CNV_WINDOW_SIZE, CNV_WINDOW_HEIGHT, mask_sh),\
 136        SF(CNV_UPDATE, CNV_UPDATE_PENDING, mask_sh),\
 137        SF(CNV_UPDATE, CNV_UPDATE_TAKEN, mask_sh),\
 138        SF(CNV_UPDATE, CNV_UPDATE_LOCK, mask_sh),\
 139        SF(CNV_SOURCE_SIZE, CNV_SOURCE_WIDTH, mask_sh),\
 140        SF(CNV_SOURCE_SIZE, CNV_SOURCE_HEIGHT, mask_sh),\
 141        SF(CNV_TEST_CNTL, CNV_TEST_CRC_EN, mask_sh),\
 142        SF(CNV_TEST_CNTL, CNV_TEST_CRC_CONT_EN, mask_sh),\
 143        SF(CNV_TEST_CRC_RED, CNV_TEST_CRC_RED_MASK, mask_sh),\
 144        SF(CNV_TEST_CRC_RED, CNV_TEST_CRC_SIG_RED, mask_sh),\
 145        SF(CNV_TEST_CRC_GREEN, CNV_TEST_CRC_GREEN_MASK, mask_sh),\
 146        SF(CNV_TEST_CRC_GREEN, CNV_TEST_CRC_SIG_GREEN, mask_sh),\
 147        SF(CNV_TEST_CRC_BLUE, CNV_TEST_CRC_BLUE_MASK, mask_sh),\
 148        SF(CNV_TEST_CRC_BLUE, CNV_TEST_CRC_SIG_BLUE, mask_sh),\
 149        SF(WB_DEBUG_CTRL, WB_DEBUG_EN, mask_sh),\
 150        SF(WB_DEBUG_CTRL, WB_DEBUG_SEL, mask_sh),\
 151        SF(WB_DBG_MODE, WB_DBG_MODE_EN, mask_sh),\
 152        SF(WB_DBG_MODE, WB_DBG_DIN_FMT, mask_sh),\
 153        SF(WB_DBG_MODE, WB_DBG_36MODE, mask_sh),\
 154        SF(WB_DBG_MODE, WB_DBG_CMAP, mask_sh),\
 155        SF(WB_DBG_MODE, WB_DBG_PXLRATE_ERROR, mask_sh),\
 156        SF(WB_DBG_MODE, WB_DBG_SOURCE_WIDTH, mask_sh),\
 157        SF(WB_HW_DEBUG, WB_HW_DEBUG, mask_sh),\
 158        SF(WB_SOFT_RESET, WB_SOFT_RESET, mask_sh),\
 159        SF(CNV_TEST_DEBUG_INDEX, CNV_TEST_DEBUG_INDEX, mask_sh),\
 160        SF(CNV_TEST_DEBUG_INDEX, CNV_TEST_DEBUG_WRITE_EN, mask_sh),\
 161        SF(CNV_TEST_DEBUG_DATA, CNV_TEST_DEBUG_DATA, mask_sh),\
 162        SF(WBSCL_COEF_RAM_SELECT, WBSCL_COEF_RAM_TAP_PAIR_IDX, mask_sh),\
 163        SF(WBSCL_COEF_RAM_SELECT, WBSCL_COEF_RAM_PHASE, mask_sh),\
 164        SF(WBSCL_COEF_RAM_SELECT, WBSCL_COEF_RAM_FILTER_TYPE, mask_sh),\
 165        SF(WBSCL_COEF_RAM_TAP_DATA, WBSCL_COEF_RAM_EVEN_TAP_COEF, mask_sh),\
 166        SF(WBSCL_COEF_RAM_TAP_DATA, WBSCL_COEF_RAM_EVEN_TAP_COEF_EN, mask_sh),\
 167        SF(WBSCL_COEF_RAM_TAP_DATA, WBSCL_COEF_RAM_ODD_TAP_COEF, mask_sh),\
 168        SF(WBSCL_COEF_RAM_TAP_DATA, WBSCL_COEF_RAM_ODD_TAP_COEF_EN, mask_sh),\
 169        SF(WBSCL_MODE, WBSCL_MODE, mask_sh),\
 170        SF(WBSCL_MODE, WBSCL_OUT_BIT_DEPTH, mask_sh),\
 171        SF(WBSCL_TAP_CONTROL, WBSCL_V_NUM_OF_TAPS_Y_RGB, mask_sh),\
 172        SF(WBSCL_TAP_CONTROL, WBSCL_V_NUM_OF_TAPS_CBCR, mask_sh),\
 173        SF(WBSCL_TAP_CONTROL, WBSCL_H_NUM_OF_TAPS_Y_RGB, mask_sh),\
 174        SF(WBSCL_TAP_CONTROL, WBSCL_H_NUM_OF_TAPS_CBCR, mask_sh),\
 175        SF(WBSCL_DEST_SIZE, WBSCL_DEST_HEIGHT, mask_sh),\
 176        SF(WBSCL_DEST_SIZE, WBSCL_DEST_WIDTH, mask_sh),\
 177        SF(WBSCL_HORZ_FILTER_SCALE_RATIO, WBSCL_H_SCALE_RATIO, mask_sh),\
 178        SF(WBSCL_HORZ_FILTER_INIT_Y_RGB, WBSCL_H_INIT_FRAC_Y_RGB, mask_sh),\
 179        SF(WBSCL_HORZ_FILTER_INIT_Y_RGB, WBSCL_H_INIT_INT_Y_RGB, mask_sh),\
 180        SF(WBSCL_HORZ_FILTER_INIT_CBCR, WBSCL_H_INIT_FRAC_CBCR, mask_sh),\
 181        SF(WBSCL_HORZ_FILTER_INIT_CBCR, WBSCL_H_INIT_INT_CBCR, mask_sh),\
 182        SF(WBSCL_VERT_FILTER_SCALE_RATIO, WBSCL_V_SCALE_RATIO, mask_sh),\
 183        SF(WBSCL_VERT_FILTER_INIT_Y_RGB, WBSCL_V_INIT_FRAC_Y_RGB, mask_sh),\
 184        SF(WBSCL_VERT_FILTER_INIT_Y_RGB, WBSCL_V_INIT_INT_Y_RGB, mask_sh),\
 185        SF(WBSCL_VERT_FILTER_INIT_CBCR, WBSCL_V_INIT_FRAC_CBCR, mask_sh),\
 186        SF(WBSCL_VERT_FILTER_INIT_CBCR, WBSCL_V_INIT_INT_CBCR, mask_sh),\
 187        SF(WBSCL_ROUND_OFFSET, WBSCL_ROUND_OFFSET_Y_RGB, mask_sh),\
 188        SF(WBSCL_ROUND_OFFSET, WBSCL_ROUND_OFFSET_CBCR, mask_sh),\
 189        SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_FLAG, mask_sh),\
 190        SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_ACK, mask_sh),\
 191        SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_MASK, mask_sh),\
 192        SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_INT_STATUS, mask_sh),\
 193        SF(WBSCL_OVERFLOW_STATUS, WBSCL_DATA_OVERFLOW_INT_TYPE, mask_sh),\
 194        SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_FLAG, mask_sh),\
 195        SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_ACK, mask_sh),\
 196        SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_MASK, mask_sh),\
 197        SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_INT_STATUS, mask_sh),\
 198        SF(WBSCL_COEF_RAM_CONFLICT_STATUS, WBSCL_HOST_CONFLICT_INT_TYPE, mask_sh),\
 199        SF(WBSCL_TEST_CNTL, WBSCL_TEST_CRC_EN, mask_sh),\
 200        SF(WBSCL_TEST_CNTL, WBSCL_TEST_CRC_CONT_EN, mask_sh),\
 201        SF(WBSCL_TEST_CRC_RED, WBSCL_TEST_CRC_RED_MASK, mask_sh),\
 202        SF(WBSCL_TEST_CRC_RED, WBSCL_TEST_CRC_SIG_RED, mask_sh),\
 203        SF(WBSCL_TEST_CRC_GREEN, WBSCL_TEST_CRC_GREEN_MASK, mask_sh),\
 204        SF(WBSCL_TEST_CRC_GREEN, WBSCL_TEST_CRC_SIG_GREEN, mask_sh),\
 205        SF(WBSCL_TEST_CRC_BLUE, WBSCL_TEST_CRC_BLUE_MASK, mask_sh),\
 206        SF(WBSCL_TEST_CRC_BLUE, WBSCL_TEST_CRC_SIG_BLUE, mask_sh),\
 207        SF(WBSCL_BACKPRESSURE_CNT_EN, WBSCL_BACKPRESSURE_CNT_EN, mask_sh),\
 208        SF(WB_MCIF_BACKPRESSURE_CNT, WB_MCIF_Y_MAX_BACKPRESSURE, mask_sh),\
 209        SF(WB_MCIF_BACKPRESSURE_CNT, WB_MCIF_C_MAX_BACKPRESSURE, mask_sh),\
 210        SF(WBSCL_CLAMP_Y_RGB, WBSCL_CLAMP_UPPER_Y_RGB, mask_sh),\
 211        SF(WBSCL_CLAMP_Y_RGB, WBSCL_CLAMP_LOWER_Y_RGB, mask_sh),\
 212        SF(WBSCL_CLAMP_CBCR, WBSCL_CLAMP_UPPER_CBCR, mask_sh),\
 213        SF(WBSCL_CLAMP_CBCR, WBSCL_CLAMP_LOWER_CBCR, mask_sh),\
 214        SF(WBSCL_OUTSIDE_PIX_STRATEGY, WBSCL_OUTSIDE_PIX_STRATEGY, mask_sh),\
 215        SF(WBSCL_OUTSIDE_PIX_STRATEGY, WBSCL_BLACK_COLOR_G_Y, mask_sh),\
 216        SF(WBSCL_OUTSIDE_PIX_STRATEGY_CBCR, WBSCL_BLACK_COLOR_B_CB, mask_sh),\
 217        SF(WBSCL_OUTSIDE_PIX_STRATEGY_CBCR, WBSCL_BLACK_COLOR_R_CR, mask_sh),\
 218        SF(WBSCL_DEBUG, WBSCL_DEBUG, mask_sh),\
 219        SF(WBSCL_TEST_DEBUG_INDEX, WBSCL_TEST_DEBUG_INDEX, mask_sh),\
 220        SF(WBSCL_TEST_DEBUG_INDEX, WBSCL_TEST_DEBUG_WRITE_EN, mask_sh),\
 221        SF(WBSCL_TEST_DEBUG_DATA, WBSCL_TEST_DEBUG_DATA, mask_sh),\
 222        SF(WB_WARM_UP_MODE_CTL1, WIDTH_WARMUP, mask_sh),\
 223        SF(WB_WARM_UP_MODE_CTL1, HEIGHT_WARMUP, mask_sh),\
 224        SF(WB_WARM_UP_MODE_CTL1, GMC_WARM_UP_ENABLE, mask_sh),\
 225        SF(WB_WARM_UP_MODE_CTL2, DATA_VALUE_WARMUP, mask_sh),\
 226        SF(WB_WARM_UP_MODE_CTL2, MODE_WARMUP, mask_sh),\
 227        SF(WB_WARM_UP_MODE_CTL2, DATA_DEPTH_WARMUP, mask_sh)
 228
 229#define DWBC_REG_FIELD_LIST_DCN2_0(type) \
 230        type WB_ENABLE;\
 231        type DISPCLK_R_WB_GATE_DIS;\
 232        type DISPCLK_G_WB_GATE_DIS;\
 233        type DISPCLK_G_WBSCL_GATE_DIS;\
 234        type WB_TEST_CLK_SEL;\
 235        type WB_LB_LS_DIS;\
 236        type WB_LB_SD_DIS;\
 237        type WB_LUT_LS_DIS;\
 238        type WBSCL_LB_MEM_PWR_MODE_SEL;\
 239        type WBSCL_LB_MEM_PWR_DIS;\
 240        type WBSCL_LB_MEM_PWR_FORCE;\
 241        type WBSCL_LB_MEM_PWR_STATE;\
 242        type WB_RAM_PW_SAVE_MODE;\
 243        type WBSCL_LUT_MEM_PWR_STATE;\
 244        type CNV_OUT_BPC;\
 245        type CNV_FRAME_CAPTURE_RATE;\
 246        type CNV_WINDOW_CROP_EN;\
 247        type CNV_STEREO_TYPE;\
 248        type CNV_INTERLACED_MODE;\
 249        type CNV_EYE_SELECTION;\
 250        type CNV_STEREO_POLARITY;\
 251        type CNV_INTERLACED_FIELD_ORDER;\
 252        type CNV_STEREO_SPLIT;\
 253        type CNV_NEW_CONTENT;\
 254        type CNV_FRAME_CAPTURE_EN_CURRENT;\
 255        type CNV_FRAME_CAPTURE_EN;\
 256        type CNV_WINDOW_START_X;\
 257        type CNV_WINDOW_START_Y;\
 258        type CNV_WINDOW_WIDTH;\
 259        type CNV_WINDOW_HEIGHT;\
 260        type CNV_UPDATE_PENDING;\
 261        type CNV_UPDATE_TAKEN;\
 262        type CNV_UPDATE_LOCK;\
 263        type CNV_SOURCE_WIDTH;\
 264        type CNV_SOURCE_HEIGHT;\
 265        type CNV_TEST_CRC_EN;\
 266        type CNV_TEST_CRC_CONT_EN;\
 267        type CNV_TEST_CRC_RED_MASK;\
 268        type CNV_TEST_CRC_SIG_RED;\
 269        type CNV_TEST_CRC_GREEN_MASK;\
 270        type CNV_TEST_CRC_SIG_GREEN;\
 271        type CNV_TEST_CRC_BLUE_MASK;\
 272        type CNV_TEST_CRC_SIG_BLUE;\
 273        type WB_DEBUG_EN;\
 274        type WB_DEBUG_SEL;\
 275        type WB_DBG_MODE_EN;\
 276        type WB_DBG_DIN_FMT;\
 277        type WB_DBG_36MODE;\
 278        type WB_DBG_CMAP;\
 279        type WB_DBG_PXLRATE_ERROR;\
 280        type WB_DBG_SOURCE_WIDTH;\
 281        type WB_HW_DEBUG;\
 282        type CNV_TEST_DEBUG_INDEX;\
 283        type CNV_TEST_DEBUG_WRITE_EN;\
 284        type CNV_TEST_DEBUG_DATA;\
 285        type WB_SOFT_RESET;\
 286        type WBSCL_COEF_RAM_TAP_PAIR_IDX;\
 287        type WBSCL_COEF_RAM_PHASE;\
 288        type WBSCL_COEF_RAM_FILTER_TYPE;\
 289        type WBSCL_COEF_RAM_SEL;\
 290        type WBSCL_COEF_RAM_SEL_CURRENT;\
 291        type WBSCL_COEF_RAM_RD_SEL;\
 292        type WBSCL_COEF_RAM_EVEN_TAP_COEF;\
 293        type WBSCL_COEF_RAM_EVEN_TAP_COEF_EN;\
 294        type WBSCL_COEF_RAM_ODD_TAP_COEF;\
 295        type WBSCL_COEF_RAM_ODD_TAP_COEF_EN;\
 296        type WBSCL_MODE;\
 297        type WBSCL_OUT_BIT_DEPTH;\
 298        type WBSCL_V_NUM_OF_TAPS_Y_RGB;\
 299        type WBSCL_V_NUM_OF_TAPS_CBCR;\
 300        type WBSCL_H_NUM_OF_TAPS_Y_RGB;\
 301        type WBSCL_H_NUM_OF_TAPS_CBCR;\
 302        type WBSCL_DEST_HEIGHT;\
 303        type WBSCL_DEST_WIDTH;\
 304        type WBSCL_H_SCALE_RATIO;\
 305        type WBSCL_H_INIT_FRAC_Y_RGB;\
 306        type WBSCL_H_INIT_INT_Y_RGB;\
 307        type WBSCL_H_INIT_FRAC_CBCR;\
 308        type WBSCL_H_INIT_INT_CBCR;\
 309        type WBSCL_V_SCALE_RATIO;\
 310        type WBSCL_V_INIT_FRAC_Y_RGB;\
 311        type WBSCL_V_INIT_INT_Y_RGB;\
 312        type WBSCL_V_INIT_FRAC_CBCR;\
 313        type WBSCL_V_INIT_INT_CBCR;\
 314        type WBSCL_ROUND_OFFSET_Y_RGB;\
 315        type WBSCL_ROUND_OFFSET_CBCR;\
 316        type WBSCL_DATA_OVERFLOW_FLAG;\
 317        type WBSCL_DATA_OVERFLOW_ACK;\
 318        type WBSCL_DATA_OVERFLOW_MASK;\
 319        type WBSCL_DATA_OVERFLOW_INT_STATUS;\
 320        type WBSCL_DATA_OVERFLOW_INT_TYPE;\
 321        type WBSCL_HOST_CONFLICT_FLAG;\
 322        type WBSCL_HOST_CONFLICT_ACK;\
 323        type WBSCL_HOST_CONFLICT_MASK;\
 324        type WBSCL_HOST_CONFLICT_INT_STATUS;\
 325        type WBSCL_HOST_CONFLICT_INT_TYPE;\
 326        type WBSCL_TEST_CRC_EN;\
 327        type WBSCL_TEST_CRC_CONT_EN;\
 328        type WBSCL_TEST_CRC_RED_MASK;\
 329        type WBSCL_TEST_CRC_SIG_RED;\
 330        type WBSCL_TEST_CRC_GREEN_MASK;\
 331        type WBSCL_TEST_CRC_SIG_GREEN;\
 332        type WBSCL_TEST_CRC_BLUE_MASK;\
 333        type WBSCL_TEST_CRC_SIG_BLUE;\
 334        type WBSCL_BACKPRESSURE_CNT_EN;\
 335        type WB_MCIF_Y_MAX_BACKPRESSURE;\
 336        type WB_MCIF_C_MAX_BACKPRESSURE;\
 337        type WBSCL_CLAMP_UPPER_Y_RGB;\
 338        type WBSCL_CLAMP_LOWER_Y_RGB;\
 339        type WBSCL_CLAMP_UPPER_CBCR;\
 340        type WBSCL_CLAMP_LOWER_CBCR;\
 341        type WBSCL_OUTSIDE_PIX_STRATEGY;\
 342        type WBSCL_BLACK_COLOR_G_Y;\
 343        type WBSCL_BLACK_COLOR_B_CB;\
 344        type WBSCL_BLACK_COLOR_R_CR;\
 345        type WBSCL_DEBUG;\
 346        type WBSCL_TEST_DEBUG_INDEX;\
 347        type WBSCL_TEST_DEBUG_WRITE_EN;\
 348        type WBSCL_TEST_DEBUG_DATA;\
 349        type WIDTH_WARMUP;\
 350        type HEIGHT_WARMUP;\
 351        type GMC_WARM_UP_ENABLE;\
 352        type DATA_VALUE_WARMUP;\
 353        type MODE_WARMUP;\
 354        type DATA_DEPTH_WARMUP; \
 355
 356struct dcn20_dwbc_registers {
 357        /* DCN2.0 */
 358        uint32_t WB_ENABLE;
 359        uint32_t WB_EC_CONFIG;
 360        uint32_t CNV_MODE;
 361        uint32_t CNV_WINDOW_START;
 362        uint32_t CNV_WINDOW_SIZE;
 363        uint32_t CNV_UPDATE;
 364        uint32_t CNV_SOURCE_SIZE;
 365        uint32_t CNV_TEST_CNTL;
 366        uint32_t CNV_TEST_CRC_RED;
 367        uint32_t CNV_TEST_CRC_GREEN;
 368        uint32_t CNV_TEST_CRC_BLUE;
 369        uint32_t WB_DEBUG_CTRL;
 370        uint32_t WB_DBG_MODE;
 371        uint32_t WB_HW_DEBUG;
 372        uint32_t CNV_TEST_DEBUG_INDEX;
 373        uint32_t CNV_TEST_DEBUG_DATA;
 374        uint32_t WB_SOFT_RESET;
 375        uint32_t WBSCL_COEF_RAM_SELECT;
 376        uint32_t WBSCL_COEF_RAM_TAP_DATA;
 377        uint32_t WBSCL_MODE;
 378        uint32_t WBSCL_TAP_CONTROL;
 379        uint32_t WBSCL_DEST_SIZE;
 380        uint32_t WBSCL_HORZ_FILTER_SCALE_RATIO;
 381        uint32_t WBSCL_HORZ_FILTER_INIT_Y_RGB;
 382        uint32_t WBSCL_HORZ_FILTER_INIT_CBCR;
 383        uint32_t WBSCL_VERT_FILTER_SCALE_RATIO;
 384        uint32_t WBSCL_VERT_FILTER_INIT_Y_RGB;
 385        uint32_t WBSCL_VERT_FILTER_INIT_CBCR;
 386        uint32_t WBSCL_ROUND_OFFSET;
 387        uint32_t WBSCL_OVERFLOW_STATUS;
 388        uint32_t WBSCL_COEF_RAM_CONFLICT_STATUS;
 389        uint32_t WBSCL_TEST_CNTL;
 390        uint32_t WBSCL_TEST_CRC_RED;
 391        uint32_t WBSCL_TEST_CRC_GREEN;
 392        uint32_t WBSCL_TEST_CRC_BLUE;
 393        uint32_t WBSCL_BACKPRESSURE_CNT_EN;
 394        uint32_t WB_MCIF_BACKPRESSURE_CNT;
 395        uint32_t WBSCL_CLAMP_Y_RGB;
 396        uint32_t WBSCL_CLAMP_CBCR;
 397        uint32_t WBSCL_OUTSIDE_PIX_STRATEGY;
 398        uint32_t WBSCL_OUTSIDE_PIX_STRATEGY_CBCR;
 399        uint32_t WBSCL_DEBUG;
 400        uint32_t WBSCL_TEST_DEBUG_INDEX;
 401        uint32_t WBSCL_TEST_DEBUG_DATA;
 402        uint32_t WB_WARM_UP_MODE_CTL1;
 403        uint32_t WB_WARM_UP_MODE_CTL2;
 404};
 405
 406
 407struct dcn20_dwbc_mask {
 408        DWBC_REG_FIELD_LIST_DCN2_0(uint32_t)
 409};
 410
 411struct dcn20_dwbc_shift {
 412        DWBC_REG_FIELD_LIST_DCN2_0(uint8_t)
 413};
 414
 415struct dcn20_dwbc {
 416        struct dwbc base;
 417        const struct dcn20_dwbc_registers *dwbc_regs;
 418        const struct dcn20_dwbc_shift *dwbc_shift;
 419        const struct dcn20_dwbc_mask *dwbc_mask;
 420};
 421
 422void dcn20_dwbc_construct(struct dcn20_dwbc *dwbc20,
 423        struct dc_context *ctx,
 424        const struct dcn20_dwbc_registers *dwbc_regs,
 425        const struct dcn20_dwbc_shift *dwbc_shift,
 426        const struct dcn20_dwbc_mask *dwbc_mask,
 427        int inst);
 428
 429bool dwb2_disable(struct dwbc *dwbc);
 430
 431bool dwb2_is_enabled(struct dwbc *dwbc);
 432
 433void dwb2_set_stereo(struct dwbc *dwbc,
 434        struct dwb_stereo_params *stereo_params);
 435
 436void dwb2_set_new_content(struct dwbc *dwbc,
 437        bool is_new_content);
 438
 439void dwb2_config_dwb_cnv(struct dwbc *dwbc,
 440        struct dc_dwb_params *params);
 441
 442void dwb2_set_scaler(struct dwbc *dwbc, struct dc_dwb_params *params);
 443
 444bool dwb_program_vert_scalar(struct dcn20_dwbc *dwbc20,
 445        uint32_t src_height,
 446        uint32_t dest_height,
 447        struct scaling_taps num_taps,
 448        enum dwb_subsample_position subsample_position);
 449
 450bool dwb_program_horz_scalar(struct dcn20_dwbc *dwbc20,
 451        uint32_t src_width,
 452        uint32_t dest_width,
 453        struct scaling_taps num_taps);
 454
 455
 456#endif
 457
 458
 459