1 /* SPDX-License-Identifier: MIT */ 2 /* 3 * Copyright © 2023 Intel Corporation 4 */ 5 6 #ifndef __INTEL_VDSC_REGS_H__ 7 #define __INTEL_VDSC_REGS_H__ 8 9 #include "intel_display_reg_defs.h" 10 11 /* Display Stream Splitter Control */ 12 #define DSS_CTL1 _MMIO(0x67400) 13 #define SPLITTER_ENABLE (1 << 31) 14 #define JOINER_ENABLE (1 << 30) 15 #define DUAL_LINK_MODE_INTERLEAVE (1 << 24) 16 #define DUAL_LINK_MODE_FRONTBACK (0 << 24) 17 #define OVERLAP_PIXELS_MASK (0xf << 16) 18 #define OVERLAP_PIXELS(pixels) ((pixels) << 16) 19 #define LEFT_DL_BUF_TARGET_DEPTH_MASK (0xfff << 0) 20 #define LEFT_DL_BUF_TARGET_DEPTH(pixels) ((pixels) << 0) 21 #define MAX_DL_BUFFER_TARGET_DEPTH 0x5a0 22 23 #define DSS_CTL2 _MMIO(0x67404) 24 #define VDSC0_ENABLE REG_BIT(31) 25 #define VDSC2_ENABLE REG_BIT(30) 26 #define SMALL_JOINER_CONFIG_3_ENGINES REG_BIT(23) 27 #define VDSC1_ENABLE REG_BIT(15) 28 #define RIGHT_DL_BUF_TARGET_DEPTH_MASK (0xfff << 0) 29 #define RIGHT_DL_BUF_TARGET_DEPTH(pixels) ((pixels) << 0) 30 31 #define _ICL_PIPE_DSS_CTL1_PB 0x78200 32 #define _ICL_PIPE_DSS_CTL1_PC 0x78400 33 #define ICL_PIPE_DSS_CTL1(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 34 _ICL_PIPE_DSS_CTL1_PB, \ 35 _ICL_PIPE_DSS_CTL1_PC) 36 #define BIG_JOINER_ENABLE (1 << 29) 37 #define PRIMARY_BIG_JOINER_ENABLE (1 << 28) 38 #define VGA_CENTERING_ENABLE (1 << 27) 39 #define SPLITTER_CONFIGURATION_MASK REG_GENMASK(26, 25) 40 #define SPLITTER_CONFIGURATION_2_SEGMENT REG_FIELD_PREP(SPLITTER_CONFIGURATION_MASK, 0) 41 #define SPLITTER_CONFIGURATION_4_SEGMENT REG_FIELD_PREP(SPLITTER_CONFIGURATION_MASK, 1) 42 #define ULTRA_JOINER_ENABLE REG_BIT(23) 43 #define PRIMARY_ULTRA_JOINER_ENABLE REG_BIT(22) 44 #define UNCOMPRESSED_JOINER_PRIMARY (1 << 21) 45 #define UNCOMPRESSED_JOINER_SECONDARY (1 << 20) 46 47 #define _ICL_PIPE_DSS_CTL2_PB 0x78204 48 #define _ICL_PIPE_DSS_CTL2_PC 0x78404 49 #define ICL_PIPE_DSS_CTL2(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 50 _ICL_PIPE_DSS_CTL2_PB, \ 51 _ICL_PIPE_DSS_CTL2_PC) 52 53 /* Icelake Display Stream Compression Registers */ 54 #define DSCA_PICTURE_PARAMETER_SET_0 _MMIO(0x6B200) 55 #define DSCC_PICTURE_PARAMETER_SET_0 _MMIO(0x6BA00) 56 #define _DSCA_PPS_0 0x6B200 57 #define _DSCC_PPS_0 0x6BA00 58 #define DSCA_PPS(pps) _MMIO(_DSCA_PPS_0 + ((pps) < 12 ? (pps) : (pps) + 12) * 4) 59 #define DSCC_PPS(pps) _MMIO(_DSCC_PPS_0 + ((pps) < 12 ? (pps) : (pps) + 12) * 4) 60 #define _ICL_DSC0_PICTURE_PARAMETER_SET_0_PB 0x78270 61 #define _ICL_DSC1_PICTURE_PARAMETER_SET_0_PB 0x78370 62 #define _BMG_DSC2_PICTURE_PARAMETER_SET_0_PB 0x78970 63 #define _ICL_DSC0_PICTURE_PARAMETER_SET_0_PC 0x78470 64 #define _ICL_DSC1_PICTURE_PARAMETER_SET_0_PC 0x78570 65 #define _BMG_DSC2_PICTURE_PARAMETER_SET_0_PC 0x78A70 66 #define ICL_DSC0_PICTURE_PARAMETER_SET_0(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 67 _ICL_DSC0_PICTURE_PARAMETER_SET_0_PB, \ 68 _ICL_DSC0_PICTURE_PARAMETER_SET_0_PC) 69 #define ICL_DSC1_PICTURE_PARAMETER_SET_0(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 70 _ICL_DSC1_PICTURE_PARAMETER_SET_0_PB, \ 71 _ICL_DSC1_PICTURE_PARAMETER_SET_0_PC) 72 #define _ICL_DSC0_PPS_0(pipe) _PICK_EVEN((pipe) - PIPE_B, \ 73 _ICL_DSC0_PICTURE_PARAMETER_SET_0_PB, \ 74 _ICL_DSC0_PICTURE_PARAMETER_SET_0_PC) 75 #define _ICL_DSC1_PPS_0(pipe) _PICK_EVEN((pipe) - PIPE_B, \ 76 _ICL_DSC1_PICTURE_PARAMETER_SET_0_PB, \ 77 _ICL_DSC1_PICTURE_PARAMETER_SET_0_PC) 78 #define _BMG_DSC2_PPS_0(pipe) _PICK_EVEN((pipe) - PIPE_B, \ 79 _BMG_DSC2_PICTURE_PARAMETER_SET_0_PB, \ 80 _BMG_DSC2_PICTURE_PARAMETER_SET_0_PC) 81 #define ICL_DSC0_PPS(pipe, pps) _MMIO(_ICL_DSC0_PPS_0(pipe) + ((pps) * 4)) 82 #define ICL_DSC1_PPS(pipe, pps) _MMIO(_ICL_DSC1_PPS_0(pipe) + ((pps) * 4)) 83 #define BMG_DSC2_PPS(pipe, pps) _MMIO(_BMG_DSC2_PPS_0(pipe) + ((pps) * 4)) 84 85 /* PPS 0 */ 86 #define DSC_PPS0_NATIVE_422_ENABLE REG_BIT(23) 87 #define DSC_PPS0_NATIVE_420_ENABLE REG_BIT(22) 88 #define DSC_PPS0_ALT_ICH_SEL REG_BIT(20) 89 #define DSC_PPS0_VBR_ENABLE REG_BIT(19) 90 #define DSC_PPS0_422_ENABLE REG_BIT(18) 91 #define DSC_PPS0_COLOR_SPACE_CONVERSION REG_BIT(17) 92 #define DSC_PPS0_BLOCK_PREDICTION REG_BIT(16) 93 #define DSC_PPS0_LINE_BUF_DEPTH_MASK REG_GENMASK(15, 12) 94 #define DSC_PPS0_LINE_BUF_DEPTH(depth) REG_FIELD_PREP(DSC_PPS0_LINE_BUF_DEPTH_MASK, depth) 95 #define DSC_PPS0_BPC_MASK REG_GENMASK(11, 8) 96 #define DSC_PPS0_BPC(bpc) REG_FIELD_PREP(DSC_PPS0_BPC_MASK, bpc) 97 #define DSC_PPS0_VER_MINOR_MASK REG_GENMASK(7, 4) 98 #define DSC_PPS0_VER_MINOR(minor) REG_FIELD_PREP(DSC_PPS0_VER_MINOR_MASK, minor) 99 #define DSC_PPS0_VER_MAJOR_MASK REG_GENMASK(3, 0) 100 #define DSC_PPS0_VER_MAJOR(major) REG_FIELD_PREP(DSC_PPS0_VER_MAJOR_MASK, major) 101 102 /* PPS 1 */ 103 #define DSC_PPS1_BPP_MASK REG_GENMASK(9, 0) 104 #define DSC_PPS1_BPP(bpp) REG_FIELD_PREP(DSC_PPS1_BPP_MASK, bpp) 105 106 /* PPS 2 */ 107 #define DSC_PPS2_PIC_WIDTH_MASK REG_GENMASK(31, 16) 108 #define DSC_PPS2_PIC_HEIGHT_MASK REG_GENMASK(15, 0) 109 #define DSC_PPS2_PIC_WIDTH(pic_width) REG_FIELD_PREP(DSC_PPS2_PIC_WIDTH_MASK, pic_width) 110 #define DSC_PPS2_PIC_HEIGHT(pic_height) REG_FIELD_PREP(DSC_PPS2_PIC_HEIGHT_MASK, pic_height) 111 112 /* PPS 3 */ 113 #define DSC_PPS3_SLICE_WIDTH_MASK REG_GENMASK(31, 16) 114 #define DSC_PPS3_SLICE_HEIGHT_MASK REG_GENMASK(15, 0) 115 #define DSC_PPS3_SLICE_WIDTH(slice_width) REG_FIELD_PREP(DSC_PPS3_SLICE_WIDTH_MASK, slice_width) 116 #define DSC_PPS3_SLICE_HEIGHT(slice_height) REG_FIELD_PREP(DSC_PPS3_SLICE_HEIGHT_MASK, slice_height) 117 118 /* PPS 4 */ 119 #define DSC_PPS4_INITIAL_DEC_DELAY_MASK REG_GENMASK(31, 16) 120 #define DSC_PPS4_INITIAL_XMIT_DELAY_MASK REG_GENMASK(9, 0) 121 #define DSC_PPS4_INITIAL_DEC_DELAY(dec_delay) REG_FIELD_PREP(DSC_PPS4_INITIAL_DEC_DELAY_MASK, \ 122 dec_delay) 123 #define DSC_PPS4_INITIAL_XMIT_DELAY(xmit_delay) REG_FIELD_PREP(DSC_PPS4_INITIAL_XMIT_DELAY_MASK, \ 124 xmit_delay) 125 126 /* PPS 5 */ 127 #define DSC_PPS5_SCALE_DEC_INT_MASK REG_GENMASK(27, 16) 128 #define DSC_PPS5_SCALE_INC_INT_MASK REG_GENMASK(15, 0) 129 #define DSC_PPS5_SCALE_DEC_INT(scale_dec) REG_FIELD_PREP(DSC_PPS5_SCALE_DEC_INT_MASK, scale_dec) 130 #define DSC_PPS5_SCALE_INC_INT(scale_inc) REG_FIELD_PREP(DSC_PPS5_SCALE_INC_INT_MASK, scale_inc) 131 132 /* PPS 6 */ 133 #define DSC_PPS6_FLATNESS_MAX_QP_MASK REG_GENMASK(28, 24) 134 #define DSC_PPS6_FLATNESS_MIN_QP_MASK REG_GENMASK(20, 16) 135 #define DSC_PPS6_FIRST_LINE_BPG_OFFSET_MASK REG_GENMASK(12, 8) 136 #define DSC_PPS6_INITIAL_SCALE_VALUE_MASK REG_GENMASK(5, 0) 137 #define DSC_PPS6_FLATNESS_MAX_QP(max_qp) REG_FIELD_PREP(DSC_PPS6_FLATNESS_MAX_QP_MASK, max_qp) 138 #define DSC_PPS6_FLATNESS_MIN_QP(min_qp) REG_FIELD_PREP(DSC_PPS6_FLATNESS_MIN_QP_MASK, min_qp) 139 #define DSC_PPS6_FIRST_LINE_BPG_OFFSET(offset) REG_FIELD_PREP(DSC_PPS6_FIRST_LINE_BPG_OFFSET_MASK, \ 140 offset) 141 #define DSC_PPS6_INITIAL_SCALE_VALUE(value) REG_FIELD_PREP(DSC_PPS6_INITIAL_SCALE_VALUE_MASK, \ 142 value) 143 144 /* PPS 7 */ 145 #define DSC_PPS7_NFL_BPG_OFFSET_MASK REG_GENMASK(31, 16) 146 #define DSC_PPS7_SLICE_BPG_OFFSET_MASK REG_GENMASK(15, 0) 147 #define DSC_PPS7_NFL_BPG_OFFSET(bpg_offset) REG_FIELD_PREP(DSC_PPS7_NFL_BPG_OFFSET_MASK, bpg_offset) 148 #define DSC_PPS7_SLICE_BPG_OFFSET(bpg_offset) REG_FIELD_PREP(DSC_PPS7_SLICE_BPG_OFFSET_MASK, \ 149 bpg_offset) 150 /* PPS 8 */ 151 #define DSC_PPS8_INITIAL_OFFSET_MASK REG_GENMASK(31, 16) 152 #define DSC_PPS8_FINAL_OFFSET_MASK REG_GENMASK(15, 0) 153 #define DSC_PPS8_INITIAL_OFFSET(initial_offset) REG_FIELD_PREP(DSC_PPS8_INITIAL_OFFSET_MASK, \ 154 initial_offset) 155 #define DSC_PPS8_FINAL_OFFSET(final_offset) REG_FIELD_PREP(DSC_PPS8_FINAL_OFFSET_MASK, \ 156 final_offset) 157 158 /* PPS 9 */ 159 #define DSC_PPS9_RC_EDGE_FACTOR_MASK REG_GENMASK(19, 16) 160 #define DSC_PPS9_RC_MODEL_SIZE_MASK REG_GENMASK(15, 0) 161 #define DSC_PPS9_RC_EDGE_FACTOR(rc_edge_fact) REG_FIELD_PREP(DSC_PPS9_RC_EDGE_FACTOR_MASK, \ 162 rc_edge_fact) 163 #define DSC_PPS9_RC_MODEL_SIZE(rc_model_size) REG_FIELD_PREP(DSC_PPS9_RC_MODEL_SIZE_MASK, \ 164 rc_model_size) 165 166 /* PPS 10 */ 167 #define DSC_PPS10_RC_TGT_OFF_LOW_MASK REG_GENMASK(23, 20) 168 #define DSC_PPS10_RC_TGT_OFF_HIGH_MASK REG_GENMASK(19, 16) 169 #define DSC_PPS10_RC_QUANT_INC_LIMIT1_MASK REG_GENMASK(12, 8) 170 #define DSC_PPS10_RC_QUANT_INC_LIMIT0_MASK REG_GENMASK(4, 0) 171 #define DSC_PPS10_RC_TARGET_OFF_LOW(rc_tgt_off_low) REG_FIELD_PREP(DSC_PPS10_RC_TGT_OFF_LOW_MASK, \ 172 rc_tgt_off_low) 173 #define DSC_PPS10_RC_TARGET_OFF_HIGH(rc_tgt_off_high) REG_FIELD_PREP(DSC_PPS10_RC_TGT_OFF_HIGH_MASK, \ 174 rc_tgt_off_high) 175 #define DSC_PPS10_RC_QUANT_INC_LIMIT1(lim) REG_FIELD_PREP(DSC_PPS10_RC_QUANT_INC_LIMIT1_MASK, lim) 176 #define DSC_PPS10_RC_QUANT_INC_LIMIT0(lim) REG_FIELD_PREP(DSC_PPS10_RC_QUANT_INC_LIMIT0_MASK, lim) 177 178 /* PPS 16 */ 179 #define DSC_PPS16_SLICE_ROW_PR_FRME_MASK REG_GENMASK(31, 20) 180 #define DSC_PPS16_SLICE_PER_LINE_MASK REG_GENMASK(18, 16) 181 #define DSC_PPS16_SLICE_CHUNK_SIZE_MASK REG_GENMASK(15, 0) 182 #define DSC_PPS16_SLICE_ROW_PER_FRAME(slice_row_per_frame) REG_FIELD_PREP(DSC_PPS16_SLICE_ROW_PR_FRME_MASK, \ 183 slice_row_per_frame) 184 #define DSC_PPS16_SLICE_PER_LINE(slice_per_line) REG_FIELD_PREP(DSC_PPS16_SLICE_PER_LINE_MASK, \ 185 slice_per_line) 186 #define DSC_PPS16_SLICE_CHUNK_SIZE(slice_chunk_size) REG_FIELD_PREP(DSC_PPS16_SLICE_CHUNK_SIZE_MASK, \ 187 slice_chunk_size) 188 189 /* PPS 17 (MTL+) */ 190 #define DSC_PPS17_SL_BPG_OFFSET_MASK REG_GENMASK(31, 27) 191 #define DSC_PPS17_SL_BPG_OFFSET(offset) REG_FIELD_PREP(DSC_PPS17_SL_BPG_OFFSET_MASK, offset) 192 193 /* PPS 18 (MTL+) */ 194 #define DSC_PPS18_NSL_BPG_OFFSET_MASK REG_GENMASK(31, 16) 195 #define DSC_PPS18_SL_OFFSET_ADJ_MASK REG_GENMASK(15, 0) 196 #define DSC_PPS18_NSL_BPG_OFFSET(offset) REG_FIELD_PREP(DSC_PPS18_NSL_BPG_OFFSET_MASK, offset) 197 #define DSC_PPS18_SL_OFFSET_ADJ(offset) REG_FIELD_PREP(DSC_PPS18_SL_OFFSET_ADJ_MASK, offset) 198 199 #define _LNL_DSC0_SU_PARAMETER_SET_0_PA 0x78064 200 #define _LNL_DSC1_SU_PARAMETER_SET_0_PA 0x78164 201 #define _LNL_DSC0_SU_PARAMETER_SET_0_PB 0x78264 202 #define _LNL_DSC1_SU_PARAMETER_SET_0_PB 0x78364 203 #define LNL_DSC0_SU_PARAMETER_SET_0(pipe) _MMIO_PIPE((pipe), _LNL_DSC0_SU_PARAMETER_SET_0_PA, _LNL_DSC0_SU_PARAMETER_SET_0_PB) 204 #define LNL_DSC1_SU_PARAMETER_SET_0(pipe) _MMIO_PIPE((pipe), _LNL_DSC1_SU_PARAMETER_SET_0_PA, _LNL_DSC1_SU_PARAMETER_SET_0_PB) 205 206 #define DSC_SUPS0_SU_SLICE_ROW_PER_FRAME_MASK REG_GENMASK(31, 20) 207 #define DSC_SUPS0_SU_SLICE_ROW_PER_FRAME(rows) REG_FIELD_PREP(DSC_SUPS0_SU_SLICE_ROW_PER_FRAME_MASK, (rows)) 208 #define DSC_SUPS0_SU_PIC_HEIGHT_MASK REG_GENMASK(15, 0) 209 #define DSC_SUPS0_SU_PIC_HEIGHT(h) REG_FIELD_PREP(DSC_SUPS0_SU_PIC_HEIGHT_MASK, (h)) 210 211 /* Icelake Rate Control Buffer Threshold Registers */ 212 #define DSCA_RC_BUF_THRESH_0 _MMIO(0x6B230) 213 #define DSCA_RC_BUF_THRESH_0_UDW _MMIO(0x6B230 + 4) 214 #define DSCC_RC_BUF_THRESH_0 _MMIO(0x6BA30) 215 #define DSCC_RC_BUF_THRESH_0_UDW _MMIO(0x6BA30 + 4) 216 #define _ICL_DSC0_RC_BUF_THRESH_0_PB (0x78254) 217 #define _ICL_DSC0_RC_BUF_THRESH_0_UDW_PB (0x78254 + 4) 218 #define _ICL_DSC1_RC_BUF_THRESH_0_PB (0x78354) 219 #define _ICL_DSC1_RC_BUF_THRESH_0_UDW_PB (0x78354 + 4) 220 #define _ICL_DSC0_RC_BUF_THRESH_0_PC (0x78454) 221 #define _ICL_DSC0_RC_BUF_THRESH_0_UDW_PC (0x78454 + 4) 222 #define _ICL_DSC1_RC_BUF_THRESH_0_PC (0x78554) 223 #define _ICL_DSC1_RC_BUF_THRESH_0_UDW_PC (0x78554 + 4) 224 #define ICL_DSC0_RC_BUF_THRESH_0(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 225 _ICL_DSC0_RC_BUF_THRESH_0_PB, \ 226 _ICL_DSC0_RC_BUF_THRESH_0_PC) 227 #define ICL_DSC0_RC_BUF_THRESH_0_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 228 _ICL_DSC0_RC_BUF_THRESH_0_UDW_PB, \ 229 _ICL_DSC0_RC_BUF_THRESH_0_UDW_PC) 230 #define ICL_DSC1_RC_BUF_THRESH_0(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 231 _ICL_DSC1_RC_BUF_THRESH_0_PB, \ 232 _ICL_DSC1_RC_BUF_THRESH_0_PC) 233 #define ICL_DSC1_RC_BUF_THRESH_0_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 234 _ICL_DSC1_RC_BUF_THRESH_0_UDW_PB, \ 235 _ICL_DSC1_RC_BUF_THRESH_0_UDW_PC) 236 237 #define DSCA_RC_BUF_THRESH_1 _MMIO(0x6B238) 238 #define DSCA_RC_BUF_THRESH_1_UDW _MMIO(0x6B238 + 4) 239 #define DSCC_RC_BUF_THRESH_1 _MMIO(0x6BA38) 240 #define DSCC_RC_BUF_THRESH_1_UDW _MMIO(0x6BA38 + 4) 241 #define _ICL_DSC0_RC_BUF_THRESH_1_PB (0x7825C) 242 #define _ICL_DSC0_RC_BUF_THRESH_1_UDW_PB (0x7825C + 4) 243 #define _ICL_DSC1_RC_BUF_THRESH_1_PB (0x7835C) 244 #define _ICL_DSC1_RC_BUF_THRESH_1_UDW_PB (0x7835C + 4) 245 #define _ICL_DSC0_RC_BUF_THRESH_1_PC (0x7845C) 246 #define _ICL_DSC0_RC_BUF_THRESH_1_UDW_PC (0x7845C + 4) 247 #define _ICL_DSC1_RC_BUF_THRESH_1_PC (0x7855C) 248 #define _ICL_DSC1_RC_BUF_THRESH_1_UDW_PC (0x7855C + 4) 249 #define ICL_DSC0_RC_BUF_THRESH_1(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 250 _ICL_DSC0_RC_BUF_THRESH_1_PB, \ 251 _ICL_DSC0_RC_BUF_THRESH_1_PC) 252 #define ICL_DSC0_RC_BUF_THRESH_1_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 253 _ICL_DSC0_RC_BUF_THRESH_1_UDW_PB, \ 254 _ICL_DSC0_RC_BUF_THRESH_1_UDW_PC) 255 #define ICL_DSC1_RC_BUF_THRESH_1(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 256 _ICL_DSC1_RC_BUF_THRESH_1_PB, \ 257 _ICL_DSC1_RC_BUF_THRESH_1_PC) 258 #define ICL_DSC1_RC_BUF_THRESH_1_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 259 _ICL_DSC1_RC_BUF_THRESH_1_UDW_PB, \ 260 _ICL_DSC1_RC_BUF_THRESH_1_UDW_PC) 261 262 /* Icelake DSC Rate Control Range Parameter Registers */ 263 #define DSCA_RC_RANGE_PARAMETERS_0 _MMIO(0x6B240) 264 #define DSCA_RC_RANGE_PARAMETERS_0_UDW _MMIO(0x6B240 + 4) 265 #define DSCC_RC_RANGE_PARAMETERS_0 _MMIO(0x6BA40) 266 #define DSCC_RC_RANGE_PARAMETERS_0_UDW _MMIO(0x6BA40 + 4) 267 #define _ICL_DSC0_RC_RANGE_PARAMETERS_0_PB (0x78208) 268 #define _ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW_PB (0x78208 + 4) 269 #define _ICL_DSC1_RC_RANGE_PARAMETERS_0_PB (0x78308) 270 #define _ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW_PB (0x78308 + 4) 271 #define _ICL_DSC0_RC_RANGE_PARAMETERS_0_PC (0x78408) 272 #define _ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW_PC (0x78408 + 4) 273 #define _ICL_DSC1_RC_RANGE_PARAMETERS_0_PC (0x78508) 274 #define _ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW_PC (0x78508 + 4) 275 #define ICL_DSC0_RC_RANGE_PARAMETERS_0(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 276 _ICL_DSC0_RC_RANGE_PARAMETERS_0_PB, \ 277 _ICL_DSC0_RC_RANGE_PARAMETERS_0_PC) 278 #define ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 279 _ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW_PB, \ 280 _ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW_PC) 281 #define ICL_DSC1_RC_RANGE_PARAMETERS_0(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 282 _ICL_DSC1_RC_RANGE_PARAMETERS_0_PB, \ 283 _ICL_DSC1_RC_RANGE_PARAMETERS_0_PC) 284 #define ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 285 _ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW_PB, \ 286 _ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW_PC) 287 #define RC_BPG_OFFSET_SHIFT 10 288 #define RC_MAX_QP_SHIFT 5 289 #define RC_MIN_QP_SHIFT 0 290 291 #define DSCA_RC_RANGE_PARAMETERS_1 _MMIO(0x6B248) 292 #define DSCA_RC_RANGE_PARAMETERS_1_UDW _MMIO(0x6B248 + 4) 293 #define DSCC_RC_RANGE_PARAMETERS_1 _MMIO(0x6BA48) 294 #define DSCC_RC_RANGE_PARAMETERS_1_UDW _MMIO(0x6BA48 + 4) 295 #define _ICL_DSC0_RC_RANGE_PARAMETERS_1_PB (0x78210) 296 #define _ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW_PB (0x78210 + 4) 297 #define _ICL_DSC1_RC_RANGE_PARAMETERS_1_PB (0x78310) 298 #define _ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW_PB (0x78310 + 4) 299 #define _ICL_DSC0_RC_RANGE_PARAMETERS_1_PC (0x78410) 300 #define _ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW_PC (0x78410 + 4) 301 #define _ICL_DSC1_RC_RANGE_PARAMETERS_1_PC (0x78510) 302 #define _ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW_PC (0x78510 + 4) 303 #define ICL_DSC0_RC_RANGE_PARAMETERS_1(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 304 _ICL_DSC0_RC_RANGE_PARAMETERS_1_PB, \ 305 _ICL_DSC0_RC_RANGE_PARAMETERS_1_PC) 306 #define ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 307 _ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW_PB, \ 308 _ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW_PC) 309 #define ICL_DSC1_RC_RANGE_PARAMETERS_1(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 310 _ICL_DSC1_RC_RANGE_PARAMETERS_1_PB, \ 311 _ICL_DSC1_RC_RANGE_PARAMETERS_1_PC) 312 #define ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 313 _ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW_PB, \ 314 _ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW_PC) 315 316 #define DSCA_RC_RANGE_PARAMETERS_2 _MMIO(0x6B250) 317 #define DSCA_RC_RANGE_PARAMETERS_2_UDW _MMIO(0x6B250 + 4) 318 #define DSCC_RC_RANGE_PARAMETERS_2 _MMIO(0x6BA50) 319 #define DSCC_RC_RANGE_PARAMETERS_2_UDW _MMIO(0x6BA50 + 4) 320 #define _ICL_DSC0_RC_RANGE_PARAMETERS_2_PB (0x78218) 321 #define _ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW_PB (0x78218 + 4) 322 #define _ICL_DSC1_RC_RANGE_PARAMETERS_2_PB (0x78318) 323 #define _ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW_PB (0x78318 + 4) 324 #define _ICL_DSC0_RC_RANGE_PARAMETERS_2_PC (0x78418) 325 #define _ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW_PC (0x78418 + 4) 326 #define _ICL_DSC1_RC_RANGE_PARAMETERS_2_PC (0x78518) 327 #define _ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW_PC (0x78518 + 4) 328 #define ICL_DSC0_RC_RANGE_PARAMETERS_2(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 329 _ICL_DSC0_RC_RANGE_PARAMETERS_2_PB, \ 330 _ICL_DSC0_RC_RANGE_PARAMETERS_2_PC) 331 #define ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 332 _ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW_PB, \ 333 _ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW_PC) 334 #define ICL_DSC1_RC_RANGE_PARAMETERS_2(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 335 _ICL_DSC1_RC_RANGE_PARAMETERS_2_PB, \ 336 _ICL_DSC1_RC_RANGE_PARAMETERS_2_PC) 337 #define ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 338 _ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW_PB, \ 339 _ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW_PC) 340 341 #define DSCA_RC_RANGE_PARAMETERS_3 _MMIO(0x6B258) 342 #define DSCA_RC_RANGE_PARAMETERS_3_UDW _MMIO(0x6B258 + 4) 343 #define DSCC_RC_RANGE_PARAMETERS_3 _MMIO(0x6BA58) 344 #define DSCC_RC_RANGE_PARAMETERS_3_UDW _MMIO(0x6BA58 + 4) 345 #define _ICL_DSC0_RC_RANGE_PARAMETERS_3_PB (0x78220) 346 #define _ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW_PB (0x78220 + 4) 347 #define _ICL_DSC1_RC_RANGE_PARAMETERS_3_PB (0x78320) 348 #define _ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW_PB (0x78320 + 4) 349 #define _ICL_DSC0_RC_RANGE_PARAMETERS_3_PC (0x78420) 350 #define _ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW_PC (0x78420 + 4) 351 #define _ICL_DSC1_RC_RANGE_PARAMETERS_3_PC (0x78520) 352 #define _ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW_PC (0x78520 + 4) 353 #define ICL_DSC0_RC_RANGE_PARAMETERS_3(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 354 _ICL_DSC0_RC_RANGE_PARAMETERS_3_PB, \ 355 _ICL_DSC0_RC_RANGE_PARAMETERS_3_PC) 356 #define ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 357 _ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW_PB, \ 358 _ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW_PC) 359 #define ICL_DSC1_RC_RANGE_PARAMETERS_3(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 360 _ICL_DSC1_RC_RANGE_PARAMETERS_3_PB, \ 361 _ICL_DSC1_RC_RANGE_PARAMETERS_3_PC) 362 #define ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW(pipe) _MMIO_PIPE((pipe) - PIPE_B, \ 363 _ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW_PB, \ 364 _ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW_PC) 365 366 #endif /* __INTEL_VDSC_REGS_H__ */ 367