xref: /linux/drivers/gpu/drm/i915/display/intel_vdsc_regs.h (revision 1c9982b4961334c1edb0745a04cabd34bc2de675)
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