root/drivers/gpu/drm/i915/display/intel_vdsc_regs.h
/* SPDX-License-Identifier: MIT */
/*
 * Copyright © 2023 Intel Corporation
 */

#ifndef __INTEL_VDSC_REGS_H__
#define __INTEL_VDSC_REGS_H__

#include "intel_display_reg_defs.h"

/* Display Stream Splitter Control */
#define DSS_CTL1                                _MMIO(0x67400)
#define  SPLITTER_ENABLE                        (1 << 31)
#define  JOINER_ENABLE                          (1 << 30)
#define  DUAL_LINK_MODE_INTERLEAVE              (1 << 24)
#define  DUAL_LINK_MODE_FRONTBACK               (0 << 24)
#define  OVERLAP_PIXELS_MASK                    (0xf << 16)
#define  OVERLAP_PIXELS(pixels)                 ((pixels) << 16)
#define  LEFT_DL_BUF_TARGET_DEPTH_MASK          (0xfff << 0)
#define  LEFT_DL_BUF_TARGET_DEPTH(pixels)       ((pixels) << 0)
#define  MAX_DL_BUFFER_TARGET_DEPTH             0x5a0

#define DSS_CTL2                                _MMIO(0x67404)
#define  VDSC0_ENABLE                           REG_BIT(31)
#define  VDSC2_ENABLE                           REG_BIT(30)
#define  SMALL_JOINER_CONFIG_3_ENGINES          REG_BIT(23)
#define  VDSC1_ENABLE                           REG_BIT(15)
#define  RIGHT_DL_BUF_TARGET_DEPTH_MASK         (0xfff << 0)
#define  RIGHT_DL_BUF_TARGET_DEPTH(pixels)      ((pixels) << 0)

#define _ICL_PIPE_DSS_CTL1_PB                   0x78200
#define _ICL_PIPE_DSS_CTL1_PC                   0x78400
#define ICL_PIPE_DSS_CTL1(pipe)                 _MMIO_PIPE((pipe) - PIPE_B, \
                                                           _ICL_PIPE_DSS_CTL1_PB, \
                                                           _ICL_PIPE_DSS_CTL1_PC)
#define  BIG_JOINER_ENABLE                      (1 << 29)
#define  PRIMARY_BIG_JOINER_ENABLE              (1 << 28)
#define  VGA_CENTERING_ENABLE                   (1 << 27)
#define  SPLITTER_CONFIGURATION_MASK            REG_GENMASK(26, 25)
#define  SPLITTER_CONFIGURATION_2_SEGMENT       REG_FIELD_PREP(SPLITTER_CONFIGURATION_MASK, 0)
#define  SPLITTER_CONFIGURATION_4_SEGMENT       REG_FIELD_PREP(SPLITTER_CONFIGURATION_MASK, 1)
#define  ULTRA_JOINER_ENABLE                    REG_BIT(23)
#define  PRIMARY_ULTRA_JOINER_ENABLE            REG_BIT(22)
#define  UNCOMPRESSED_JOINER_PRIMARY            (1 << 21)
#define  UNCOMPRESSED_JOINER_SECONDARY          (1 << 20)

#define _ICL_PIPE_DSS_CTL2_PB                   0x78204
#define _ICL_PIPE_DSS_CTL2_PC                   0x78404
#define ICL_PIPE_DSS_CTL2(pipe)                 _MMIO_PIPE((pipe) - PIPE_B, \
                                                           _ICL_PIPE_DSS_CTL2_PB, \
                                                           _ICL_PIPE_DSS_CTL2_PC)

/* Icelake Display Stream Compression Registers */
#define DSCA_PICTURE_PARAMETER_SET_0            _MMIO(0x6B200)
#define DSCC_PICTURE_PARAMETER_SET_0            _MMIO(0x6BA00)
#define _DSCA_PPS_0                             0x6B200
#define _DSCC_PPS_0                             0x6BA00
#define DSCA_PPS(pps)                           _MMIO(_DSCA_PPS_0 + ((pps) < 12 ? (pps) : (pps) + 12) * 4)
#define DSCC_PPS(pps)                           _MMIO(_DSCC_PPS_0 + ((pps) < 12 ? (pps) : (pps) + 12) * 4)
#define _ICL_DSC0_PICTURE_PARAMETER_SET_0_PB    0x78270
#define _ICL_DSC1_PICTURE_PARAMETER_SET_0_PB    0x78370
#define _BMG_DSC2_PICTURE_PARAMETER_SET_0_PB    0x78970
#define _ICL_DSC0_PICTURE_PARAMETER_SET_0_PC    0x78470
#define _ICL_DSC1_PICTURE_PARAMETER_SET_0_PC    0x78570
#define _BMG_DSC2_PICTURE_PARAMETER_SET_0_PC    0x78A70
#define ICL_DSC0_PICTURE_PARAMETER_SET_0(pipe)  _MMIO_PIPE((pipe) - PIPE_B, \
                                                           _ICL_DSC0_PICTURE_PARAMETER_SET_0_PB, \
                                                           _ICL_DSC0_PICTURE_PARAMETER_SET_0_PC)
#define ICL_DSC1_PICTURE_PARAMETER_SET_0(pipe)  _MMIO_PIPE((pipe) - PIPE_B, \
                                                           _ICL_DSC1_PICTURE_PARAMETER_SET_0_PB, \
                                                           _ICL_DSC1_PICTURE_PARAMETER_SET_0_PC)
#define _ICL_DSC0_PPS_0(pipe)                   _PICK_EVEN((pipe) - PIPE_B, \
                                                           _ICL_DSC0_PICTURE_PARAMETER_SET_0_PB, \
                                                           _ICL_DSC0_PICTURE_PARAMETER_SET_0_PC)
#define _ICL_DSC1_PPS_0(pipe)                   _PICK_EVEN((pipe) - PIPE_B, \
                                                           _ICL_DSC1_PICTURE_PARAMETER_SET_0_PB, \
                                                           _ICL_DSC1_PICTURE_PARAMETER_SET_0_PC)
#define _BMG_DSC2_PPS_0(pipe)                   _PICK_EVEN((pipe) - PIPE_B, \
                                                           _BMG_DSC2_PICTURE_PARAMETER_SET_0_PB, \
                                                           _BMG_DSC2_PICTURE_PARAMETER_SET_0_PC)
#define  ICL_DSC0_PPS(pipe, pps)                _MMIO(_ICL_DSC0_PPS_0(pipe) + ((pps) * 4))
#define  ICL_DSC1_PPS(pipe, pps)                _MMIO(_ICL_DSC1_PPS_0(pipe) + ((pps) * 4))
#define  BMG_DSC2_PPS(pipe, pps)                _MMIO(_BMG_DSC2_PPS_0(pipe) + ((pps) * 4))

/* PPS 0 */
#define   DSC_PPS0_NATIVE_422_ENABLE            REG_BIT(23)
#define   DSC_PPS0_NATIVE_420_ENABLE            REG_BIT(22)
#define   DSC_PPS0_ALT_ICH_SEL                  REG_BIT(20)
#define   DSC_PPS0_VBR_ENABLE                   REG_BIT(19)
#define   DSC_PPS0_422_ENABLE                   REG_BIT(18)
#define   DSC_PPS0_COLOR_SPACE_CONVERSION       REG_BIT(17)
#define   DSC_PPS0_BLOCK_PREDICTION             REG_BIT(16)
#define   DSC_PPS0_LINE_BUF_DEPTH_MASK          REG_GENMASK(15, 12)
#define   DSC_PPS0_LINE_BUF_DEPTH(depth)        REG_FIELD_PREP(DSC_PPS0_LINE_BUF_DEPTH_MASK, depth)
#define   DSC_PPS0_BPC_MASK                     REG_GENMASK(11, 8)
#define   DSC_PPS0_BPC(bpc)                     REG_FIELD_PREP(DSC_PPS0_BPC_MASK, bpc)
#define   DSC_PPS0_VER_MINOR_MASK               REG_GENMASK(7, 4)
#define   DSC_PPS0_VER_MINOR(minor)             REG_FIELD_PREP(DSC_PPS0_VER_MINOR_MASK, minor)
#define   DSC_PPS0_VER_MAJOR_MASK               REG_GENMASK(3, 0)
#define   DSC_PPS0_VER_MAJOR(major)             REG_FIELD_PREP(DSC_PPS0_VER_MAJOR_MASK, major)

/* PPS 1 */
#define   DSC_PPS1_BPP_MASK                     REG_GENMASK(9, 0)
#define   DSC_PPS1_BPP(bpp)                     REG_FIELD_PREP(DSC_PPS1_BPP_MASK, bpp)

/* PPS 2 */
#define   DSC_PPS2_PIC_WIDTH_MASK               REG_GENMASK(31, 16)
#define   DSC_PPS2_PIC_HEIGHT_MASK              REG_GENMASK(15, 0)
#define   DSC_PPS2_PIC_WIDTH(pic_width)         REG_FIELD_PREP(DSC_PPS2_PIC_WIDTH_MASK, pic_width)
#define   DSC_PPS2_PIC_HEIGHT(pic_height)       REG_FIELD_PREP(DSC_PPS2_PIC_HEIGHT_MASK, pic_height)

/* PPS 3 */
#define   DSC_PPS3_SLICE_WIDTH_MASK             REG_GENMASK(31, 16)
#define   DSC_PPS3_SLICE_HEIGHT_MASK            REG_GENMASK(15, 0)
#define   DSC_PPS3_SLICE_WIDTH(slice_width)     REG_FIELD_PREP(DSC_PPS3_SLICE_WIDTH_MASK, slice_width)
#define   DSC_PPS3_SLICE_HEIGHT(slice_height)   REG_FIELD_PREP(DSC_PPS3_SLICE_HEIGHT_MASK, slice_height)

/* PPS 4 */
#define   DSC_PPS4_INITIAL_DEC_DELAY_MASK       REG_GENMASK(31, 16)
#define   DSC_PPS4_INITIAL_XMIT_DELAY_MASK      REG_GENMASK(9, 0)
#define   DSC_PPS4_INITIAL_DEC_DELAY(dec_delay) REG_FIELD_PREP(DSC_PPS4_INITIAL_DEC_DELAY_MASK, \
                                                               dec_delay)
#define   DSC_PPS4_INITIAL_XMIT_DELAY(xmit_delay)       REG_FIELD_PREP(DSC_PPS4_INITIAL_XMIT_DELAY_MASK, \
                                                                       xmit_delay)

/* PPS 5 */
#define   DSC_PPS5_SCALE_DEC_INT_MASK           REG_GENMASK(27, 16)
#define   DSC_PPS5_SCALE_INC_INT_MASK           REG_GENMASK(15, 0)
#define   DSC_PPS5_SCALE_DEC_INT(scale_dec)     REG_FIELD_PREP(DSC_PPS5_SCALE_DEC_INT_MASK, scale_dec)
#define   DSC_PPS5_SCALE_INC_INT(scale_inc)     REG_FIELD_PREP(DSC_PPS5_SCALE_INC_INT_MASK, scale_inc)

/* PPS 6 */
#define   DSC_PPS6_FLATNESS_MAX_QP_MASK         REG_GENMASK(28, 24)
#define   DSC_PPS6_FLATNESS_MIN_QP_MASK         REG_GENMASK(20, 16)
#define   DSC_PPS6_FIRST_LINE_BPG_OFFSET_MASK   REG_GENMASK(12, 8)
#define   DSC_PPS6_INITIAL_SCALE_VALUE_MASK     REG_GENMASK(5, 0)
#define   DSC_PPS6_FLATNESS_MAX_QP(max_qp)      REG_FIELD_PREP(DSC_PPS6_FLATNESS_MAX_QP_MASK, max_qp)
#define   DSC_PPS6_FLATNESS_MIN_QP(min_qp)      REG_FIELD_PREP(DSC_PPS6_FLATNESS_MIN_QP_MASK, min_qp)
#define   DSC_PPS6_FIRST_LINE_BPG_OFFSET(offset)        REG_FIELD_PREP(DSC_PPS6_FIRST_LINE_BPG_OFFSET_MASK, \
                                                                       offset)
#define   DSC_PPS6_INITIAL_SCALE_VALUE(value)   REG_FIELD_PREP(DSC_PPS6_INITIAL_SCALE_VALUE_MASK, \
                                                               value)

/* PPS 7 */
#define   DSC_PPS7_NFL_BPG_OFFSET_MASK          REG_GENMASK(31, 16)
#define   DSC_PPS7_SLICE_BPG_OFFSET_MASK        REG_GENMASK(15, 0)
#define   DSC_PPS7_NFL_BPG_OFFSET(bpg_offset)   REG_FIELD_PREP(DSC_PPS7_NFL_BPG_OFFSET_MASK, bpg_offset)
#define   DSC_PPS7_SLICE_BPG_OFFSET(bpg_offset) REG_FIELD_PREP(DSC_PPS7_SLICE_BPG_OFFSET_MASK, \
                                                               bpg_offset)
/* PPS 8 */
#define   DSC_PPS8_INITIAL_OFFSET_MASK          REG_GENMASK(31, 16)
#define   DSC_PPS8_FINAL_OFFSET_MASK            REG_GENMASK(15, 0)
#define   DSC_PPS8_INITIAL_OFFSET(initial_offset)       REG_FIELD_PREP(DSC_PPS8_INITIAL_OFFSET_MASK, \
                                                                       initial_offset)
#define   DSC_PPS8_FINAL_OFFSET(final_offset)   REG_FIELD_PREP(DSC_PPS8_FINAL_OFFSET_MASK, \
                                                               final_offset)

/* PPS 9 */
#define   DSC_PPS9_RC_EDGE_FACTOR_MASK          REG_GENMASK(19, 16)
#define   DSC_PPS9_RC_MODEL_SIZE_MASK           REG_GENMASK(15, 0)
#define   DSC_PPS9_RC_EDGE_FACTOR(rc_edge_fact) REG_FIELD_PREP(DSC_PPS9_RC_EDGE_FACTOR_MASK, \
                                                               rc_edge_fact)
#define   DSC_PPS9_RC_MODEL_SIZE(rc_model_size) REG_FIELD_PREP(DSC_PPS9_RC_MODEL_SIZE_MASK, \
                                                               rc_model_size)

/* PPS 10 */
#define   DSC_PPS10_RC_TGT_OFF_LOW_MASK         REG_GENMASK(23, 20)
#define   DSC_PPS10_RC_TGT_OFF_HIGH_MASK        REG_GENMASK(19, 16)
#define   DSC_PPS10_RC_QUANT_INC_LIMIT1_MASK    REG_GENMASK(12, 8)
#define   DSC_PPS10_RC_QUANT_INC_LIMIT0_MASK    REG_GENMASK(4, 0)
#define   DSC_PPS10_RC_TARGET_OFF_LOW(rc_tgt_off_low)   REG_FIELD_PREP(DSC_PPS10_RC_TGT_OFF_LOW_MASK, \
                                                                       rc_tgt_off_low)
#define   DSC_PPS10_RC_TARGET_OFF_HIGH(rc_tgt_off_high) REG_FIELD_PREP(DSC_PPS10_RC_TGT_OFF_HIGH_MASK, \
                                                                       rc_tgt_off_high)
#define   DSC_PPS10_RC_QUANT_INC_LIMIT1(lim)    REG_FIELD_PREP(DSC_PPS10_RC_QUANT_INC_LIMIT1_MASK, lim)
#define   DSC_PPS10_RC_QUANT_INC_LIMIT0(lim)    REG_FIELD_PREP(DSC_PPS10_RC_QUANT_INC_LIMIT0_MASK, lim)

/* PPS 16 */
#define   DSC_PPS16_SLICE_ROW_PR_FRME_MASK      REG_GENMASK(31, 20)
#define   DSC_PPS16_SLICE_PER_LINE_MASK         REG_GENMASK(18, 16)
#define   DSC_PPS16_SLICE_CHUNK_SIZE_MASK       REG_GENMASK(15, 0)
#define   DSC_PPS16_SLICE_ROW_PER_FRAME(slice_row_per_frame)    REG_FIELD_PREP(DSC_PPS16_SLICE_ROW_PR_FRME_MASK, \
                                                                               slice_row_per_frame)
#define   DSC_PPS16_SLICE_PER_LINE(slice_per_line)              REG_FIELD_PREP(DSC_PPS16_SLICE_PER_LINE_MASK, \
                                                                               slice_per_line)
#define   DSC_PPS16_SLICE_CHUNK_SIZE(slice_chunk_size)          REG_FIELD_PREP(DSC_PPS16_SLICE_CHUNK_SIZE_MASK, \
                                                                               slice_chunk_size)

/* PPS 17 (MTL+) */
#define   DSC_PPS17_SL_BPG_OFFSET_MASK          REG_GENMASK(31, 27)
#define   DSC_PPS17_SL_BPG_OFFSET(offset)       REG_FIELD_PREP(DSC_PPS17_SL_BPG_OFFSET_MASK, offset)

/* PPS 18 (MTL+) */
#define   DSC_PPS18_NSL_BPG_OFFSET_MASK         REG_GENMASK(31, 16)
#define   DSC_PPS18_SL_OFFSET_ADJ_MASK          REG_GENMASK(15, 0)
#define   DSC_PPS18_NSL_BPG_OFFSET(offset)      REG_FIELD_PREP(DSC_PPS18_NSL_BPG_OFFSET_MASK, offset)
#define   DSC_PPS18_SL_OFFSET_ADJ(offset)       REG_FIELD_PREP(DSC_PPS18_SL_OFFSET_ADJ_MASK, offset)

#define _LNL_DSC0_SU_PARAMETER_SET_0_PA         0x78064
#define _LNL_DSC1_SU_PARAMETER_SET_0_PA         0x78164
#define _LNL_DSC0_SU_PARAMETER_SET_0_PB         0x78264
#define _LNL_DSC1_SU_PARAMETER_SET_0_PB         0x78364
#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)
#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)

#define   DSC_SUPS0_SU_SLICE_ROW_PER_FRAME_MASK         REG_GENMASK(31, 20)
#define   DSC_SUPS0_SU_SLICE_ROW_PER_FRAME(rows)        REG_FIELD_PREP(DSC_SUPS0_SU_SLICE_ROW_PER_FRAME_MASK, (rows))
#define   DSC_SUPS0_SU_PIC_HEIGHT_MASK                  REG_GENMASK(15, 0)
#define   DSC_SUPS0_SU_PIC_HEIGHT(h)                    REG_FIELD_PREP(DSC_SUPS0_SU_PIC_HEIGHT_MASK, (h))

/* Icelake Rate Control Buffer Threshold Registers */
#define DSCA_RC_BUF_THRESH_0                    _MMIO(0x6B230)
#define DSCA_RC_BUF_THRESH_0_UDW                _MMIO(0x6B230 + 4)
#define DSCC_RC_BUF_THRESH_0                    _MMIO(0x6BA30)
#define DSCC_RC_BUF_THRESH_0_UDW                _MMIO(0x6BA30 + 4)
#define _ICL_DSC0_RC_BUF_THRESH_0_PB            (0x78254)
#define _ICL_DSC0_RC_BUF_THRESH_0_UDW_PB        (0x78254 + 4)
#define _ICL_DSC1_RC_BUF_THRESH_0_PB            (0x78354)
#define _ICL_DSC1_RC_BUF_THRESH_0_UDW_PB        (0x78354 + 4)
#define _ICL_DSC0_RC_BUF_THRESH_0_PC            (0x78454)
#define _ICL_DSC0_RC_BUF_THRESH_0_UDW_PC        (0x78454 + 4)
#define _ICL_DSC1_RC_BUF_THRESH_0_PC            (0x78554)
#define _ICL_DSC1_RC_BUF_THRESH_0_UDW_PC        (0x78554 + 4)
#define ICL_DSC0_RC_BUF_THRESH_0(pipe)          _MMIO_PIPE((pipe) - PIPE_B, \
                                                _ICL_DSC0_RC_BUF_THRESH_0_PB, \
                                                _ICL_DSC0_RC_BUF_THRESH_0_PC)
#define ICL_DSC0_RC_BUF_THRESH_0_UDW(pipe)      _MMIO_PIPE((pipe) - PIPE_B, \
                                                _ICL_DSC0_RC_BUF_THRESH_0_UDW_PB, \
                                                _ICL_DSC0_RC_BUF_THRESH_0_UDW_PC)
#define ICL_DSC1_RC_BUF_THRESH_0(pipe)          _MMIO_PIPE((pipe) - PIPE_B, \
                                                _ICL_DSC1_RC_BUF_THRESH_0_PB, \
                                                _ICL_DSC1_RC_BUF_THRESH_0_PC)
#define ICL_DSC1_RC_BUF_THRESH_0_UDW(pipe)      _MMIO_PIPE((pipe) - PIPE_B, \
                                                _ICL_DSC1_RC_BUF_THRESH_0_UDW_PB, \
                                                _ICL_DSC1_RC_BUF_THRESH_0_UDW_PC)

#define DSCA_RC_BUF_THRESH_1                    _MMIO(0x6B238)
#define DSCA_RC_BUF_THRESH_1_UDW                _MMIO(0x6B238 + 4)
#define DSCC_RC_BUF_THRESH_1                    _MMIO(0x6BA38)
#define DSCC_RC_BUF_THRESH_1_UDW                _MMIO(0x6BA38 + 4)
#define _ICL_DSC0_RC_BUF_THRESH_1_PB            (0x7825C)
#define _ICL_DSC0_RC_BUF_THRESH_1_UDW_PB        (0x7825C + 4)
#define _ICL_DSC1_RC_BUF_THRESH_1_PB            (0x7835C)
#define _ICL_DSC1_RC_BUF_THRESH_1_UDW_PB        (0x7835C + 4)
#define _ICL_DSC0_RC_BUF_THRESH_1_PC            (0x7845C)
#define _ICL_DSC0_RC_BUF_THRESH_1_UDW_PC        (0x7845C + 4)
#define _ICL_DSC1_RC_BUF_THRESH_1_PC            (0x7855C)
#define _ICL_DSC1_RC_BUF_THRESH_1_UDW_PC        (0x7855C + 4)
#define ICL_DSC0_RC_BUF_THRESH_1(pipe)          _MMIO_PIPE((pipe) - PIPE_B, \
                                                _ICL_DSC0_RC_BUF_THRESH_1_PB, \
                                                _ICL_DSC0_RC_BUF_THRESH_1_PC)
#define ICL_DSC0_RC_BUF_THRESH_1_UDW(pipe)      _MMIO_PIPE((pipe) - PIPE_B, \
                                                _ICL_DSC0_RC_BUF_THRESH_1_UDW_PB, \
                                                _ICL_DSC0_RC_BUF_THRESH_1_UDW_PC)
#define ICL_DSC1_RC_BUF_THRESH_1(pipe)          _MMIO_PIPE((pipe) - PIPE_B, \
                                                _ICL_DSC1_RC_BUF_THRESH_1_PB, \
                                                _ICL_DSC1_RC_BUF_THRESH_1_PC)
#define ICL_DSC1_RC_BUF_THRESH_1_UDW(pipe)      _MMIO_PIPE((pipe) - PIPE_B, \
                                                _ICL_DSC1_RC_BUF_THRESH_1_UDW_PB, \
                                                _ICL_DSC1_RC_BUF_THRESH_1_UDW_PC)

/* Icelake DSC Rate Control Range Parameter Registers */
#define DSCA_RC_RANGE_PARAMETERS_0              _MMIO(0x6B240)
#define DSCA_RC_RANGE_PARAMETERS_0_UDW          _MMIO(0x6B240 + 4)
#define DSCC_RC_RANGE_PARAMETERS_0              _MMIO(0x6BA40)
#define DSCC_RC_RANGE_PARAMETERS_0_UDW          _MMIO(0x6BA40 + 4)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_0_PB      (0x78208)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW_PB  (0x78208 + 4)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_0_PB      (0x78308)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW_PB  (0x78308 + 4)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_0_PC      (0x78408)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW_PC  (0x78408 + 4)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_0_PC      (0x78508)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW_PC  (0x78508 + 4)
#define ICL_DSC0_RC_RANGE_PARAMETERS_0(pipe)            _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_0_PB, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_0_PC)
#define ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW(pipe)        _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW_PB, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_0_UDW_PC)
#define ICL_DSC1_RC_RANGE_PARAMETERS_0(pipe)            _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_0_PB, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_0_PC)
#define ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW(pipe)        _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW_PB, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_0_UDW_PC)
#define RC_BPG_OFFSET_SHIFT                     10
#define RC_MAX_QP_SHIFT                         5
#define RC_MIN_QP_SHIFT                         0

#define DSCA_RC_RANGE_PARAMETERS_1              _MMIO(0x6B248)
#define DSCA_RC_RANGE_PARAMETERS_1_UDW          _MMIO(0x6B248 + 4)
#define DSCC_RC_RANGE_PARAMETERS_1              _MMIO(0x6BA48)
#define DSCC_RC_RANGE_PARAMETERS_1_UDW          _MMIO(0x6BA48 + 4)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_1_PB      (0x78210)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW_PB  (0x78210 + 4)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_1_PB      (0x78310)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW_PB  (0x78310 + 4)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_1_PC      (0x78410)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW_PC  (0x78410 + 4)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_1_PC      (0x78510)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW_PC  (0x78510 + 4)
#define ICL_DSC0_RC_RANGE_PARAMETERS_1(pipe)            _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_1_PB, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_1_PC)
#define ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW(pipe)        _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW_PB, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_1_UDW_PC)
#define ICL_DSC1_RC_RANGE_PARAMETERS_1(pipe)            _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_1_PB, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_1_PC)
#define ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW(pipe)        _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW_PB, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_1_UDW_PC)

#define DSCA_RC_RANGE_PARAMETERS_2              _MMIO(0x6B250)
#define DSCA_RC_RANGE_PARAMETERS_2_UDW          _MMIO(0x6B250 + 4)
#define DSCC_RC_RANGE_PARAMETERS_2              _MMIO(0x6BA50)
#define DSCC_RC_RANGE_PARAMETERS_2_UDW          _MMIO(0x6BA50 + 4)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_2_PB      (0x78218)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW_PB  (0x78218 + 4)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_2_PB      (0x78318)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW_PB  (0x78318 + 4)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_2_PC      (0x78418)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW_PC  (0x78418 + 4)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_2_PC      (0x78518)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW_PC  (0x78518 + 4)
#define ICL_DSC0_RC_RANGE_PARAMETERS_2(pipe)            _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_2_PB, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_2_PC)
#define ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW(pipe)        _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW_PB, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_2_UDW_PC)
#define ICL_DSC1_RC_RANGE_PARAMETERS_2(pipe)            _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_2_PB, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_2_PC)
#define ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW(pipe)        _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW_PB, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_2_UDW_PC)

#define DSCA_RC_RANGE_PARAMETERS_3              _MMIO(0x6B258)
#define DSCA_RC_RANGE_PARAMETERS_3_UDW          _MMIO(0x6B258 + 4)
#define DSCC_RC_RANGE_PARAMETERS_3              _MMIO(0x6BA58)
#define DSCC_RC_RANGE_PARAMETERS_3_UDW          _MMIO(0x6BA58 + 4)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_3_PB      (0x78220)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW_PB  (0x78220 + 4)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_3_PB      (0x78320)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW_PB  (0x78320 + 4)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_3_PC      (0x78420)
#define _ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW_PC  (0x78420 + 4)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_3_PC      (0x78520)
#define _ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW_PC  (0x78520 + 4)
#define ICL_DSC0_RC_RANGE_PARAMETERS_3(pipe)            _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_3_PB, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_3_PC)
#define ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW(pipe)        _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW_PB, \
                                                        _ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW_PC)
#define ICL_DSC1_RC_RANGE_PARAMETERS_3(pipe)            _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_3_PB, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_3_PC)
#define ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW(pipe)        _MMIO_PIPE((pipe) - PIPE_B, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW_PB, \
                                                        _ICL_DSC1_RC_RANGE_PARAMETERS_3_UDW_PC)

#endif /* __INTEL_VDSC_REGS_H__ */