1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23#ifndef _DRM_DP_HELPER_H_
24#define _DRM_DP_HELPER_H_
25
26#include <linux/delay.h>
27#include <linux/i2c.h>
28#include <linux/types.h>
29#include <drm/drm_connector.h>
30
31struct drm_device;
32struct drm_dp_aux;
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50#define DP_MSA_MISC_SYNC_CLOCK (1 << 0)
51#define DP_MSA_MISC_INTERLACE_VTOTAL_EVEN (1 << 8)
52#define DP_MSA_MISC_STEREO_NO_3D (0 << 9)
53#define DP_MSA_MISC_STEREO_PROG_RIGHT_EYE (1 << 9)
54#define DP_MSA_MISC_STEREO_PROG_LEFT_EYE (3 << 9)
55
56#define DP_MSA_MISC_6_BPC (0 << 5)
57#define DP_MSA_MISC_8_BPC (1 << 5)
58#define DP_MSA_MISC_10_BPC (2 << 5)
59#define DP_MSA_MISC_12_BPC (3 << 5)
60#define DP_MSA_MISC_16_BPC (4 << 5)
61
62#define DP_MSA_MISC_RAW_6_BPC (1 << 5)
63#define DP_MSA_MISC_RAW_7_BPC (2 << 5)
64#define DP_MSA_MISC_RAW_8_BPC (3 << 5)
65#define DP_MSA_MISC_RAW_10_BPC (4 << 5)
66#define DP_MSA_MISC_RAW_12_BPC (5 << 5)
67#define DP_MSA_MISC_RAW_14_BPC (6 << 5)
68#define DP_MSA_MISC_RAW_16_BPC (7 << 5)
69
70#define _DP_MSA_MISC_COLOR(misc1_7, misc0_21, misc0_3, misc0_4) \
71 ((misc1_7) << 15 | (misc0_4) << 4 | (misc0_3) << 3 | ((misc0_21) << 1))
72#define DP_MSA_MISC_COLOR_RGB _DP_MSA_MISC_COLOR(0, 0, 0, 0)
73#define DP_MSA_MISC_COLOR_CEA_RGB _DP_MSA_MISC_COLOR(0, 0, 1, 0)
74#define DP_MSA_MISC_COLOR_RGB_WIDE_FIXED _DP_MSA_MISC_COLOR(0, 3, 0, 0)
75#define DP_MSA_MISC_COLOR_RGB_WIDE_FLOAT _DP_MSA_MISC_COLOR(0, 3, 0, 1)
76#define DP_MSA_MISC_COLOR_Y_ONLY _DP_MSA_MISC_COLOR(1, 0, 0, 0)
77#define DP_MSA_MISC_COLOR_RAW _DP_MSA_MISC_COLOR(1, 1, 0, 0)
78#define DP_MSA_MISC_COLOR_YCBCR_422_BT601 _DP_MSA_MISC_COLOR(0, 1, 1, 0)
79#define DP_MSA_MISC_COLOR_YCBCR_422_BT709 _DP_MSA_MISC_COLOR(0, 1, 1, 1)
80#define DP_MSA_MISC_COLOR_YCBCR_444_BT601 _DP_MSA_MISC_COLOR(0, 2, 1, 0)
81#define DP_MSA_MISC_COLOR_YCBCR_444_BT709 _DP_MSA_MISC_COLOR(0, 2, 1, 1)
82#define DP_MSA_MISC_COLOR_XVYCC_422_BT601 _DP_MSA_MISC_COLOR(0, 1, 0, 0)
83#define DP_MSA_MISC_COLOR_XVYCC_422_BT709 _DP_MSA_MISC_COLOR(0, 1, 0, 1)
84#define DP_MSA_MISC_COLOR_XVYCC_444_BT601 _DP_MSA_MISC_COLOR(0, 2, 0, 0)
85#define DP_MSA_MISC_COLOR_XVYCC_444_BT709 _DP_MSA_MISC_COLOR(0, 2, 0, 1)
86#define DP_MSA_MISC_COLOR_OPRGB _DP_MSA_MISC_COLOR(0, 0, 1, 1)
87#define DP_MSA_MISC_COLOR_DCI_P3 _DP_MSA_MISC_COLOR(0, 3, 1, 0)
88#define DP_MSA_MISC_COLOR_COLOR_PROFILE _DP_MSA_MISC_COLOR(0, 3, 1, 1)
89#define DP_MSA_MISC_COLOR_VSC_SDP (1 << 14)
90
91#define DP_AUX_MAX_PAYLOAD_BYTES 16
92
93#define DP_AUX_I2C_WRITE 0x0
94#define DP_AUX_I2C_READ 0x1
95#define DP_AUX_I2C_WRITE_STATUS_UPDATE 0x2
96#define DP_AUX_I2C_MOT 0x4
97#define DP_AUX_NATIVE_WRITE 0x8
98#define DP_AUX_NATIVE_READ 0x9
99
100#define DP_AUX_NATIVE_REPLY_ACK (0x0 << 0)
101#define DP_AUX_NATIVE_REPLY_NACK (0x1 << 0)
102#define DP_AUX_NATIVE_REPLY_DEFER (0x2 << 0)
103#define DP_AUX_NATIVE_REPLY_MASK (0x3 << 0)
104
105#define DP_AUX_I2C_REPLY_ACK (0x0 << 2)
106#define DP_AUX_I2C_REPLY_NACK (0x1 << 2)
107#define DP_AUX_I2C_REPLY_DEFER (0x2 << 2)
108#define DP_AUX_I2C_REPLY_MASK (0x3 << 2)
109
110
111
112
113#define DP_DPCD_REV 0x000
114# define DP_DPCD_REV_10 0x10
115# define DP_DPCD_REV_11 0x11
116# define DP_DPCD_REV_12 0x12
117# define DP_DPCD_REV_13 0x13
118# define DP_DPCD_REV_14 0x14
119
120#define DP_MAX_LINK_RATE 0x001
121
122#define DP_MAX_LANE_COUNT 0x002
123# define DP_MAX_LANE_COUNT_MASK 0x1f
124# define DP_TPS3_SUPPORTED (1 << 6)
125# define DP_ENHANCED_FRAME_CAP (1 << 7)
126
127#define DP_MAX_DOWNSPREAD 0x003
128# define DP_MAX_DOWNSPREAD_0_5 (1 << 0)
129# define DP_STREAM_REGENERATION_STATUS_CAP (1 << 1)
130# define DP_NO_AUX_HANDSHAKE_LINK_TRAINING (1 << 6)
131# define DP_TPS4_SUPPORTED (1 << 7)
132
133#define DP_NORP 0x004
134
135#define DP_DOWNSTREAMPORT_PRESENT 0x005
136# define DP_DWN_STRM_PORT_PRESENT (1 << 0)
137# define DP_DWN_STRM_PORT_TYPE_MASK 0x06
138# define DP_DWN_STRM_PORT_TYPE_DP (0 << 1)
139# define DP_DWN_STRM_PORT_TYPE_ANALOG (1 << 1)
140# define DP_DWN_STRM_PORT_TYPE_TMDS (2 << 1)
141# define DP_DWN_STRM_PORT_TYPE_OTHER (3 << 1)
142# define DP_FORMAT_CONVERSION (1 << 3)
143# define DP_DETAILED_CAP_INFO_AVAILABLE (1 << 4)
144
145#define DP_MAIN_LINK_CHANNEL_CODING 0x006
146# define DP_CAP_ANSI_8B10B (1 << 0)
147# define DP_CAP_ANSI_128B132B (1 << 1)
148
149#define DP_DOWN_STREAM_PORT_COUNT 0x007
150# define DP_PORT_COUNT_MASK 0x0f
151# define DP_MSA_TIMING_PAR_IGNORED (1 << 6)
152# define DP_OUI_SUPPORT (1 << 7)
153
154#define DP_RECEIVE_PORT_0_CAP_0 0x008
155# define DP_LOCAL_EDID_PRESENT (1 << 1)
156# define DP_ASSOCIATED_TO_PRECEDING_PORT (1 << 2)
157
158#define DP_RECEIVE_PORT_0_BUFFER_SIZE 0x009
159
160#define DP_RECEIVE_PORT_1_CAP_0 0x00a
161#define DP_RECEIVE_PORT_1_BUFFER_SIZE 0x00b
162
163#define DP_I2C_SPEED_CAP 0x00c
164# define DP_I2C_SPEED_1K 0x01
165# define DP_I2C_SPEED_5K 0x02
166# define DP_I2C_SPEED_10K 0x04
167# define DP_I2C_SPEED_100K 0x08
168# define DP_I2C_SPEED_400K 0x10
169# define DP_I2C_SPEED_1M 0x20
170
171#define DP_EDP_CONFIGURATION_CAP 0x00d
172# define DP_ALTERNATE_SCRAMBLER_RESET_CAP (1 << 0)
173# define DP_FRAMING_CHANGE_CAP (1 << 1)
174# define DP_DPCD_DISPLAY_CONTROL_CAPABLE (1 << 3)
175
176#define DP_TRAINING_AUX_RD_INTERVAL 0x00e
177# define DP_TRAINING_AUX_RD_MASK 0x7F
178# define DP_EXTENDED_RECEIVER_CAP_FIELD_PRESENT (1 << 7)
179
180#define DP_ADAPTER_CAP 0x00f
181# define DP_FORCE_LOAD_SENSE_CAP (1 << 0)
182# define DP_ALTERNATE_I2C_PATTERN_CAP (1 << 1)
183
184#define DP_SUPPORTED_LINK_RATES 0x010
185# define DP_MAX_SUPPORTED_RATES 8
186
187
188#define DP_FAUX_CAP 0x020
189# define DP_FAUX_CAP_1 (1 << 0)
190
191#define DP_SINK_VIDEO_FALLBACK_FORMATS 0x020
192# define DP_FALLBACK_1024x768_60HZ_24BPP (1 << 0)
193# define DP_FALLBACK_1280x720_60HZ_24BPP (1 << 1)
194# define DP_FALLBACK_1920x1080_60HZ_24BPP (1 << 2)
195
196#define DP_MSTM_CAP 0x021
197# define DP_MST_CAP (1 << 0)
198# define DP_SINGLE_STREAM_SIDEBAND_MSG (1 << 1)
199
200#define DP_NUMBER_OF_AUDIO_ENDPOINTS 0x022
201
202
203#define DP_AV_GRANULARITY 0x023
204# define DP_AG_FACTOR_MASK (0xf << 0)
205# define DP_AG_FACTOR_3MS (0 << 0)
206# define DP_AG_FACTOR_2MS (1 << 0)
207# define DP_AG_FACTOR_1MS (2 << 0)
208# define DP_AG_FACTOR_500US (3 << 0)
209# define DP_AG_FACTOR_200US (4 << 0)
210# define DP_AG_FACTOR_100US (5 << 0)
211# define DP_AG_FACTOR_10US (6 << 0)
212# define DP_AG_FACTOR_1US (7 << 0)
213# define DP_VG_FACTOR_MASK (0xf << 4)
214# define DP_VG_FACTOR_3MS (0 << 4)
215# define DP_VG_FACTOR_2MS (1 << 4)
216# define DP_VG_FACTOR_1MS (2 << 4)
217# define DP_VG_FACTOR_500US (3 << 4)
218# define DP_VG_FACTOR_200US (4 << 4)
219# define DP_VG_FACTOR_100US (5 << 4)
220
221#define DP_AUD_DEC_LAT0 0x024
222#define DP_AUD_DEC_LAT1 0x025
223
224#define DP_AUD_PP_LAT0 0x026
225#define DP_AUD_PP_LAT1 0x027
226
227#define DP_VID_INTER_LAT 0x028
228
229#define DP_VID_PROG_LAT 0x029
230
231#define DP_REP_LAT 0x02a
232
233#define DP_AUD_DEL_INS0 0x02b
234#define DP_AUD_DEL_INS1 0x02c
235#define DP_AUD_DEL_INS2 0x02d
236
237
238#define DP_RECEIVER_ALPM_CAP 0x02e
239# define DP_ALPM_CAP (1 << 0)
240
241#define DP_SINK_DEVICE_AUX_FRAME_SYNC_CAP 0x02f
242# define DP_AUX_FRAME_SYNC_CAP (1 << 0)
243
244#define DP_GUID 0x030
245
246#define DP_DSC_SUPPORT 0x060
247# define DP_DSC_DECOMPRESSION_IS_SUPPORTED (1 << 0)
248
249#define DP_DSC_REV 0x061
250# define DP_DSC_MAJOR_MASK (0xf << 0)
251# define DP_DSC_MINOR_MASK (0xf << 4)
252# define DP_DSC_MAJOR_SHIFT 0
253# define DP_DSC_MINOR_SHIFT 4
254
255#define DP_DSC_RC_BUF_BLK_SIZE 0x062
256# define DP_DSC_RC_BUF_BLK_SIZE_1 0x0
257# define DP_DSC_RC_BUF_BLK_SIZE_4 0x1
258# define DP_DSC_RC_BUF_BLK_SIZE_16 0x2
259# define DP_DSC_RC_BUF_BLK_SIZE_64 0x3
260
261#define DP_DSC_RC_BUF_SIZE 0x063
262
263#define DP_DSC_SLICE_CAP_1 0x064
264# define DP_DSC_1_PER_DP_DSC_SINK (1 << 0)
265# define DP_DSC_2_PER_DP_DSC_SINK (1 << 1)
266# define DP_DSC_4_PER_DP_DSC_SINK (1 << 3)
267# define DP_DSC_6_PER_DP_DSC_SINK (1 << 4)
268# define DP_DSC_8_PER_DP_DSC_SINK (1 << 5)
269# define DP_DSC_10_PER_DP_DSC_SINK (1 << 6)
270# define DP_DSC_12_PER_DP_DSC_SINK (1 << 7)
271
272#define DP_DSC_LINE_BUF_BIT_DEPTH 0x065
273# define DP_DSC_LINE_BUF_BIT_DEPTH_MASK (0xf << 0)
274# define DP_DSC_LINE_BUF_BIT_DEPTH_9 0x0
275# define DP_DSC_LINE_BUF_BIT_DEPTH_10 0x1
276# define DP_DSC_LINE_BUF_BIT_DEPTH_11 0x2
277# define DP_DSC_LINE_BUF_BIT_DEPTH_12 0x3
278# define DP_DSC_LINE_BUF_BIT_DEPTH_13 0x4
279# define DP_DSC_LINE_BUF_BIT_DEPTH_14 0x5
280# define DP_DSC_LINE_BUF_BIT_DEPTH_15 0x6
281# define DP_DSC_LINE_BUF_BIT_DEPTH_16 0x7
282# define DP_DSC_LINE_BUF_BIT_DEPTH_8 0x8
283
284#define DP_DSC_BLK_PREDICTION_SUPPORT 0x066
285# define DP_DSC_BLK_PREDICTION_IS_SUPPORTED (1 << 0)
286
287#define DP_DSC_MAX_BITS_PER_PIXEL_LOW 0x067
288
289#define DP_DSC_MAX_BITS_PER_PIXEL_HI 0x068
290# define DP_DSC_MAX_BITS_PER_PIXEL_HI_MASK (0x3 << 0)
291# define DP_DSC_MAX_BITS_PER_PIXEL_HI_SHIFT 8
292
293#define DP_DSC_DEC_COLOR_FORMAT_CAP 0x069
294# define DP_DSC_RGB (1 << 0)
295# define DP_DSC_YCbCr444 (1 << 1)
296# define DP_DSC_YCbCr422_Simple (1 << 2)
297# define DP_DSC_YCbCr422_Native (1 << 3)
298# define DP_DSC_YCbCr420_Native (1 << 4)
299
300#define DP_DSC_DEC_COLOR_DEPTH_CAP 0x06A
301# define DP_DSC_8_BPC (1 << 1)
302# define DP_DSC_10_BPC (1 << 2)
303# define DP_DSC_12_BPC (1 << 3)
304
305#define DP_DSC_PEAK_THROUGHPUT 0x06B
306# define DP_DSC_THROUGHPUT_MODE_0_MASK (0xf << 0)
307# define DP_DSC_THROUGHPUT_MODE_0_SHIFT 0
308# define DP_DSC_THROUGHPUT_MODE_0_UNSUPPORTED 0
309# define DP_DSC_THROUGHPUT_MODE_0_340 (1 << 0)
310# define DP_DSC_THROUGHPUT_MODE_0_400 (2 << 0)
311# define DP_DSC_THROUGHPUT_MODE_0_450 (3 << 0)
312# define DP_DSC_THROUGHPUT_MODE_0_500 (4 << 0)
313# define DP_DSC_THROUGHPUT_MODE_0_550 (5 << 0)
314# define DP_DSC_THROUGHPUT_MODE_0_600 (6 << 0)
315# define DP_DSC_THROUGHPUT_MODE_0_650 (7 << 0)
316# define DP_DSC_THROUGHPUT_MODE_0_700 (8 << 0)
317# define DP_DSC_THROUGHPUT_MODE_0_750 (9 << 0)
318# define DP_DSC_THROUGHPUT_MODE_0_800 (10 << 0)
319# define DP_DSC_THROUGHPUT_MODE_0_850 (11 << 0)
320# define DP_DSC_THROUGHPUT_MODE_0_900 (12 << 0)
321# define DP_DSC_THROUGHPUT_MODE_0_950 (13 << 0)
322# define DP_DSC_THROUGHPUT_MODE_0_1000 (14 << 0)
323# define DP_DSC_THROUGHPUT_MODE_0_170 (15 << 0)
324# define DP_DSC_THROUGHPUT_MODE_1_MASK (0xf << 4)
325# define DP_DSC_THROUGHPUT_MODE_1_SHIFT 4
326# define DP_DSC_THROUGHPUT_MODE_1_UNSUPPORTED 0
327# define DP_DSC_THROUGHPUT_MODE_1_340 (1 << 4)
328# define DP_DSC_THROUGHPUT_MODE_1_400 (2 << 4)
329# define DP_DSC_THROUGHPUT_MODE_1_450 (3 << 4)
330# define DP_DSC_THROUGHPUT_MODE_1_500 (4 << 4)
331# define DP_DSC_THROUGHPUT_MODE_1_550 (5 << 4)
332# define DP_DSC_THROUGHPUT_MODE_1_600 (6 << 4)
333# define DP_DSC_THROUGHPUT_MODE_1_650 (7 << 4)
334# define DP_DSC_THROUGHPUT_MODE_1_700 (8 << 4)
335# define DP_DSC_THROUGHPUT_MODE_1_750 (9 << 4)
336# define DP_DSC_THROUGHPUT_MODE_1_800 (10 << 4)
337# define DP_DSC_THROUGHPUT_MODE_1_850 (11 << 4)
338# define DP_DSC_THROUGHPUT_MODE_1_900 (12 << 4)
339# define DP_DSC_THROUGHPUT_MODE_1_950 (13 << 4)
340# define DP_DSC_THROUGHPUT_MODE_1_1000 (14 << 4)
341# define DP_DSC_THROUGHPUT_MODE_1_170 (15 << 4)
342
343#define DP_DSC_MAX_SLICE_WIDTH 0x06C
344#define DP_DSC_MIN_SLICE_WIDTH_VALUE 2560
345#define DP_DSC_SLICE_WIDTH_MULTIPLIER 320
346
347#define DP_DSC_SLICE_CAP_2 0x06D
348# define DP_DSC_16_PER_DP_DSC_SINK (1 << 0)
349# define DP_DSC_20_PER_DP_DSC_SINK (1 << 1)
350# define DP_DSC_24_PER_DP_DSC_SINK (1 << 2)
351
352#define DP_DSC_BITS_PER_PIXEL_INC 0x06F
353# define DP_DSC_BITS_PER_PIXEL_1_16 0x0
354# define DP_DSC_BITS_PER_PIXEL_1_8 0x1
355# define DP_DSC_BITS_PER_PIXEL_1_4 0x2
356# define DP_DSC_BITS_PER_PIXEL_1_2 0x3
357# define DP_DSC_BITS_PER_PIXEL_1 0x4
358
359#define DP_PSR_SUPPORT 0x070
360# define DP_PSR_IS_SUPPORTED 1
361# define DP_PSR2_IS_SUPPORTED 2
362# define DP_PSR2_WITH_Y_COORD_IS_SUPPORTED 3
363
364#define DP_PSR_CAPS 0x071
365# define DP_PSR_NO_TRAIN_ON_EXIT 1
366# define DP_PSR_SETUP_TIME_330 (0 << 1)
367# define DP_PSR_SETUP_TIME_275 (1 << 1)
368# define DP_PSR_SETUP_TIME_220 (2 << 1)
369# define DP_PSR_SETUP_TIME_165 (3 << 1)
370# define DP_PSR_SETUP_TIME_110 (4 << 1)
371# define DP_PSR_SETUP_TIME_55 (5 << 1)
372# define DP_PSR_SETUP_TIME_0 (6 << 1)
373# define DP_PSR_SETUP_TIME_MASK (7 << 1)
374# define DP_PSR_SETUP_TIME_SHIFT 1
375# define DP_PSR2_SU_Y_COORDINATE_REQUIRED (1 << 4)
376# define DP_PSR2_SU_GRANULARITY_REQUIRED (1 << 5)
377
378#define DP_PSR2_SU_X_GRANULARITY 0x072
379#define DP_PSR2_SU_Y_GRANULARITY 0x074
380
381
382
383
384
385
386
387
388
389
390#define DP_DOWNSTREAM_PORT_0 0x80
391# define DP_DS_PORT_TYPE_MASK (7 << 0)
392# define DP_DS_PORT_TYPE_DP 0
393# define DP_DS_PORT_TYPE_VGA 1
394# define DP_DS_PORT_TYPE_DVI 2
395# define DP_DS_PORT_TYPE_HDMI 3
396# define DP_DS_PORT_TYPE_NON_EDID 4
397# define DP_DS_PORT_TYPE_DP_DUALMODE 5
398# define DP_DS_PORT_TYPE_WIRELESS 6
399# define DP_DS_PORT_HPD (1 << 3)
400# define DP_DS_NON_EDID_MASK (0xf << 4)
401# define DP_DS_NON_EDID_720x480i_60 (1 << 4)
402# define DP_DS_NON_EDID_720x480i_50 (2 << 4)
403# define DP_DS_NON_EDID_1920x1080i_60 (3 << 4)
404# define DP_DS_NON_EDID_1920x1080i_50 (4 << 4)
405# define DP_DS_NON_EDID_1280x720_60 (5 << 4)
406# define DP_DS_NON_EDID_1280x720_50 (7 << 4)
407
408
409
410# define DP_DS_MAX_BPC_MASK (3 << 0)
411# define DP_DS_8BPC 0
412# define DP_DS_10BPC 1
413# define DP_DS_12BPC 2
414# define DP_DS_16BPC 3
415
416# define DP_PCON_MAX_FRL_BW (7 << 2)
417# define DP_PCON_MAX_0GBPS (0 << 2)
418# define DP_PCON_MAX_9GBPS (1 << 2)
419# define DP_PCON_MAX_18GBPS (2 << 2)
420# define DP_PCON_MAX_24GBPS (3 << 2)
421# define DP_PCON_MAX_32GBPS (4 << 2)
422# define DP_PCON_MAX_40GBPS (5 << 2)
423# define DP_PCON_MAX_48GBPS (6 << 2)
424# define DP_PCON_SOURCE_CTL_MODE (1 << 5)
425
426
427# define DP_DS_DVI_DUAL_LINK (1 << 1)
428# define DP_DS_DVI_HIGH_COLOR_DEPTH (1 << 2)
429
430# define DP_DS_HDMI_FRAME_SEQ_TO_FRAME_PACK (1 << 0)
431# define DP_DS_HDMI_YCBCR422_PASS_THROUGH (1 << 1)
432# define DP_DS_HDMI_YCBCR420_PASS_THROUGH (1 << 2)
433# define DP_DS_HDMI_YCBCR444_TO_422_CONV (1 << 3)
434# define DP_DS_HDMI_YCBCR444_TO_420_CONV (1 << 4)
435
436
437
438
439
440
441
442
443# define DP_DS_HDMI_BT601_RGB_YCBCR_CONV (1 << 5)
444# define DP_DS_HDMI_BT709_RGB_YCBCR_CONV (1 << 6)
445# define DP_DS_HDMI_BT2020_RGB_YCBCR_CONV (1 << 7)
446
447#define DP_MAX_DOWNSTREAM_PORTS 0x10
448
449
450#define DP_FEC_CAPABILITY 0x090
451# define DP_FEC_CAPABLE (1 << 0)
452# define DP_FEC_UNCORR_BLK_ERROR_COUNT_CAP (1 << 1)
453# define DP_FEC_CORR_BLK_ERROR_COUNT_CAP (1 << 2)
454# define DP_FEC_BIT_ERROR_COUNT_CAP (1 << 3)
455
456
457#define DP_PCON_DSC_ENCODER_CAP_SIZE 0xC
458#define DP_PCON_DSC_ENCODER 0x092
459# define DP_PCON_DSC_ENCODER_SUPPORTED (1 << 0)
460# define DP_PCON_DSC_PPS_ENC_OVERRIDE (1 << 1)
461
462
463#define DP_PCON_DSC_VERSION 0x093
464# define DP_PCON_DSC_MAJOR_MASK (0xF << 0)
465# define DP_PCON_DSC_MINOR_MASK (0xF << 4)
466# define DP_PCON_DSC_MAJOR_SHIFT 0
467# define DP_PCON_DSC_MINOR_SHIFT 4
468
469
470#define DP_PCON_DSC_RC_BUF_BLK_INFO 0x094
471# define DP_PCON_DSC_RC_BUF_BLK_SIZE (0x3 << 0)
472# define DP_PCON_DSC_RC_BUF_BLK_1KB 0
473# define DP_PCON_DSC_RC_BUF_BLK_4KB 1
474# define DP_PCON_DSC_RC_BUF_BLK_16KB 2
475# define DP_PCON_DSC_RC_BUF_BLK_64KB 3
476
477
478#define DP_PCON_DSC_RC_BUF_SIZE 0x095
479
480
481#define DP_PCON_DSC_SLICE_CAP_1 0x096
482# define DP_PCON_DSC_1_PER_DSC_ENC (0x1 << 0)
483# define DP_PCON_DSC_2_PER_DSC_ENC (0x1 << 1)
484# define DP_PCON_DSC_4_PER_DSC_ENC (0x1 << 3)
485# define DP_PCON_DSC_6_PER_DSC_ENC (0x1 << 4)
486# define DP_PCON_DSC_8_PER_DSC_ENC (0x1 << 5)
487# define DP_PCON_DSC_10_PER_DSC_ENC (0x1 << 6)
488# define DP_PCON_DSC_12_PER_DSC_ENC (0x1 << 7)
489
490#define DP_PCON_DSC_BUF_BIT_DEPTH 0x097
491# define DP_PCON_DSC_BIT_DEPTH_MASK (0xF << 0)
492# define DP_PCON_DSC_DEPTH_9_BITS 0
493# define DP_PCON_DSC_DEPTH_10_BITS 1
494# define DP_PCON_DSC_DEPTH_11_BITS 2
495# define DP_PCON_DSC_DEPTH_12_BITS 3
496# define DP_PCON_DSC_DEPTH_13_BITS 4
497# define DP_PCON_DSC_DEPTH_14_BITS 5
498# define DP_PCON_DSC_DEPTH_15_BITS 6
499# define DP_PCON_DSC_DEPTH_16_BITS 7
500# define DP_PCON_DSC_DEPTH_8_BITS 8
501
502#define DP_PCON_DSC_BLOCK_PREDICTION 0x098
503# define DP_PCON_DSC_BLOCK_PRED_SUPPORT (0x1 << 0)
504
505#define DP_PCON_DSC_ENC_COLOR_FMT_CAP 0x099
506# define DP_PCON_DSC_ENC_RGB (0x1 << 0)
507# define DP_PCON_DSC_ENC_YUV444 (0x1 << 1)
508# define DP_PCON_DSC_ENC_YUV422_S (0x1 << 2)
509# define DP_PCON_DSC_ENC_YUV422_N (0x1 << 3)
510# define DP_PCON_DSC_ENC_YUV420_N (0x1 << 4)
511
512#define DP_PCON_DSC_ENC_COLOR_DEPTH_CAP 0x09A
513# define DP_PCON_DSC_ENC_8BPC (0x1 << 1)
514# define DP_PCON_DSC_ENC_10BPC (0x1 << 2)
515# define DP_PCON_DSC_ENC_12BPC (0x1 << 3)
516
517#define DP_PCON_DSC_MAX_SLICE_WIDTH 0x09B
518
519
520#define DP_PCON_DSC_SLICE_CAP_2 0x09C
521# define DP_PCON_DSC_16_PER_DSC_ENC (0x1 << 0)
522# define DP_PCON_DSC_20_PER_DSC_ENC (0x1 << 1)
523# define DP_PCON_DSC_24_PER_DSC_ENC (0x1 << 2)
524
525
526#define DP_PCON_DSC_BPP_INCR 0x09E
527# define DP_PCON_DSC_BPP_INCR_MASK (0x7 << 0)
528# define DP_PCON_DSC_ONE_16TH_BPP 0
529# define DP_PCON_DSC_ONE_8TH_BPP 1
530# define DP_PCON_DSC_ONE_4TH_BPP 2
531# define DP_PCON_DSC_ONE_HALF_BPP 3
532# define DP_PCON_DSC_ONE_BPP 4
533
534
535#define DP_DSC_BRANCH_OVERALL_THROUGHPUT_0 0x0a0
536#define DP_DSC_BRANCH_OVERALL_THROUGHPUT_1 0x0a1
537#define DP_DSC_BRANCH_MAX_LINE_WIDTH 0x0a2
538
539
540#define DP_LINK_BW_SET 0x100
541# define DP_LINK_RATE_TABLE 0x00
542# define DP_LINK_BW_1_62 0x06
543# define DP_LINK_BW_2_7 0x0a
544# define DP_LINK_BW_5_4 0x14
545# define DP_LINK_BW_8_1 0x1e
546# define DP_LINK_BW_10 0x01
547# define DP_LINK_BW_13_5 0x04
548# define DP_LINK_BW_20 0x02
549
550#define DP_LANE_COUNT_SET 0x101
551# define DP_LANE_COUNT_MASK 0x0f
552# define DP_LANE_COUNT_ENHANCED_FRAME_EN (1 << 7)
553
554#define DP_TRAINING_PATTERN_SET 0x102
555# define DP_TRAINING_PATTERN_DISABLE 0
556# define DP_TRAINING_PATTERN_1 1
557# define DP_TRAINING_PATTERN_2 2
558# define DP_TRAINING_PATTERN_3 3
559# define DP_TRAINING_PATTERN_4 7
560# define DP_TRAINING_PATTERN_MASK 0x3
561# define DP_TRAINING_PATTERN_MASK_1_4 0xf
562
563
564# define DP_LINK_QUAL_PATTERN_11_DISABLE (0 << 2)
565# define DP_LINK_QUAL_PATTERN_11_D10_2 (1 << 2)
566# define DP_LINK_QUAL_PATTERN_11_ERROR_RATE (2 << 2)
567# define DP_LINK_QUAL_PATTERN_11_PRBS7 (3 << 2)
568# define DP_LINK_QUAL_PATTERN_11_MASK (3 << 2)
569
570# define DP_RECOVERED_CLOCK_OUT_EN (1 << 4)
571# define DP_LINK_SCRAMBLING_DISABLE (1 << 5)
572
573# define DP_SYMBOL_ERROR_COUNT_BOTH (0 << 6)
574# define DP_SYMBOL_ERROR_COUNT_DISPARITY (1 << 6)
575# define DP_SYMBOL_ERROR_COUNT_SYMBOL (2 << 6)
576# define DP_SYMBOL_ERROR_COUNT_MASK (3 << 6)
577
578#define DP_TRAINING_LANE0_SET 0x103
579#define DP_TRAINING_LANE1_SET 0x104
580#define DP_TRAINING_LANE2_SET 0x105
581#define DP_TRAINING_LANE3_SET 0x106
582
583# define DP_TRAIN_VOLTAGE_SWING_MASK 0x3
584# define DP_TRAIN_VOLTAGE_SWING_SHIFT 0
585# define DP_TRAIN_MAX_SWING_REACHED (1 << 2)
586# define DP_TRAIN_VOLTAGE_SWING_LEVEL_0 (0 << 0)
587# define DP_TRAIN_VOLTAGE_SWING_LEVEL_1 (1 << 0)
588# define DP_TRAIN_VOLTAGE_SWING_LEVEL_2 (2 << 0)
589# define DP_TRAIN_VOLTAGE_SWING_LEVEL_3 (3 << 0)
590
591# define DP_TRAIN_PRE_EMPHASIS_MASK (3 << 3)
592# define DP_TRAIN_PRE_EMPH_LEVEL_0 (0 << 3)
593# define DP_TRAIN_PRE_EMPH_LEVEL_1 (1 << 3)
594# define DP_TRAIN_PRE_EMPH_LEVEL_2 (2 << 3)
595# define DP_TRAIN_PRE_EMPH_LEVEL_3 (3 << 3)
596
597# define DP_TRAIN_PRE_EMPHASIS_SHIFT 3
598# define DP_TRAIN_MAX_PRE_EMPHASIS_REACHED (1 << 5)
599
600# define DP_TX_FFE_PRESET_VALUE_MASK (0xf << 0)
601
602#define DP_DOWNSPREAD_CTRL 0x107
603# define DP_SPREAD_AMP_0_5 (1 << 4)
604# define DP_MSA_TIMING_PAR_IGNORE_EN (1 << 7)
605
606#define DP_MAIN_LINK_CHANNEL_CODING_SET 0x108
607# define DP_SET_ANSI_8B10B (1 << 0)
608# define DP_SET_ANSI_128B132B (1 << 1)
609
610#define DP_I2C_SPEED_CONTROL_STATUS 0x109
611
612
613#define DP_EDP_CONFIGURATION_SET 0x10a
614# define DP_ALTERNATE_SCRAMBLER_RESET_ENABLE (1 << 0)
615# define DP_FRAMING_CHANGE_ENABLE (1 << 1)
616# define DP_PANEL_SELF_TEST_ENABLE (1 << 7)
617
618#define DP_LINK_QUAL_LANE0_SET 0x10b
619#define DP_LINK_QUAL_LANE1_SET 0x10c
620#define DP_LINK_QUAL_LANE2_SET 0x10d
621#define DP_LINK_QUAL_LANE3_SET 0x10e
622# define DP_LINK_QUAL_PATTERN_DISABLE 0
623# define DP_LINK_QUAL_PATTERN_D10_2 1
624# define DP_LINK_QUAL_PATTERN_ERROR_RATE 2
625# define DP_LINK_QUAL_PATTERN_PRBS7 3
626# define DP_LINK_QUAL_PATTERN_80BIT_CUSTOM 4
627# define DP_LINK_QUAL_PATTERN_CP2520_PAT_1 5
628# define DP_LINK_QUAL_PATTERN_CP2520_PAT_2 6
629# define DP_LINK_QUAL_PATTERN_CP2520_PAT_3 7
630
631# define DP_LINK_QUAL_PATTERN_128B132B_TPS1 0x08
632# define DP_LINK_QUAL_PATTERN_128B132B_TPS2 0x10
633# define DP_LINK_QUAL_PATTERN_PRSBS9 0x18
634# define DP_LINK_QUAL_PATTERN_PRSBS11 0x20
635# define DP_LINK_QUAL_PATTERN_PRSBS15 0x28
636# define DP_LINK_QUAL_PATTERN_PRSBS23 0x30
637# define DP_LINK_QUAL_PATTERN_PRSBS31 0x38
638# define DP_LINK_QUAL_PATTERN_CUSTOM 0x40
639# define DP_LINK_QUAL_PATTERN_SQUARE 0x48
640
641#define DP_TRAINING_LANE0_1_SET2 0x10f
642#define DP_TRAINING_LANE2_3_SET2 0x110
643# define DP_LANE02_POST_CURSOR2_SET_MASK (3 << 0)
644# define DP_LANE02_MAX_POST_CURSOR2_REACHED (1 << 2)
645# define DP_LANE13_POST_CURSOR2_SET_MASK (3 << 4)
646# define DP_LANE13_MAX_POST_CURSOR2_REACHED (1 << 6)
647
648#define DP_MSTM_CTRL 0x111
649# define DP_MST_EN (1 << 0)
650# define DP_UP_REQ_EN (1 << 1)
651# define DP_UPSTREAM_IS_SRC (1 << 2)
652
653#define DP_AUDIO_DELAY0 0x112
654#define DP_AUDIO_DELAY1 0x113
655#define DP_AUDIO_DELAY2 0x114
656
657#define DP_LINK_RATE_SET 0x115
658# define DP_LINK_RATE_SET_SHIFT 0
659# define DP_LINK_RATE_SET_MASK (7 << 0)
660
661#define DP_RECEIVER_ALPM_CONFIG 0x116
662# define DP_ALPM_ENABLE (1 << 0)
663# define DP_ALPM_LOCK_ERROR_IRQ_HPD_ENABLE (1 << 1)
664
665#define DP_SINK_DEVICE_AUX_FRAME_SYNC_CONF 0x117
666# define DP_AUX_FRAME_SYNC_ENABLE (1 << 0)
667# define DP_IRQ_HPD_ENABLE (1 << 1)
668
669#define DP_UPSTREAM_DEVICE_DP_PWR_NEED 0x118
670# define DP_PWR_NOT_NEEDED (1 << 0)
671
672#define DP_FEC_CONFIGURATION 0x120
673# define DP_FEC_READY (1 << 0)
674# define DP_FEC_ERR_COUNT_SEL_MASK (7 << 1)
675# define DP_FEC_ERR_COUNT_DIS (0 << 1)
676# define DP_FEC_UNCORR_BLK_ERROR_COUNT (1 << 1)
677# define DP_FEC_CORR_BLK_ERROR_COUNT (2 << 1)
678# define DP_FEC_BIT_ERROR_COUNT (3 << 1)
679# define DP_FEC_LANE_SELECT_MASK (3 << 4)
680# define DP_FEC_LANE_0_SELECT (0 << 4)
681# define DP_FEC_LANE_1_SELECT (1 << 4)
682# define DP_FEC_LANE_2_SELECT (2 << 4)
683# define DP_FEC_LANE_3_SELECT (3 << 4)
684
685#define DP_AUX_FRAME_SYNC_VALUE 0x15c
686# define DP_AUX_FRAME_SYNC_VALID (1 << 0)
687
688#define DP_DSC_ENABLE 0x160
689# define DP_DECOMPRESSION_EN (1 << 0)
690
691#define DP_PSR_EN_CFG 0x170
692# define DP_PSR_ENABLE BIT(0)
693# define DP_PSR_MAIN_LINK_ACTIVE BIT(1)
694# define DP_PSR_CRC_VERIFICATION BIT(2)
695# define DP_PSR_FRAME_CAPTURE BIT(3)
696# define DP_PSR_SU_REGION_SCANLINE_CAPTURE BIT(4)
697# define DP_PSR_IRQ_HPD_WITH_CRC_ERRORS BIT(5)
698# define DP_PSR_ENABLE_PSR2 BIT(6)
699
700#define DP_ADAPTER_CTRL 0x1a0
701# define DP_ADAPTER_CTRL_FORCE_LOAD_SENSE (1 << 0)
702
703#define DP_BRANCH_DEVICE_CTRL 0x1a1
704# define DP_BRANCH_DEVICE_IRQ_HPD (1 << 0)
705
706#define DP_PAYLOAD_ALLOCATE_SET 0x1c0
707#define DP_PAYLOAD_ALLOCATE_START_TIME_SLOT 0x1c1
708#define DP_PAYLOAD_ALLOCATE_TIME_SLOT_COUNT 0x1c2
709
710
711#define DP_SINK_COUNT 0x200
712
713# define DP_GET_SINK_COUNT(x) ((((x) & 0x80) >> 1) | ((x) & 0x3f))
714# define DP_SINK_CP_READY (1 << 6)
715
716#define DP_DEVICE_SERVICE_IRQ_VECTOR 0x201
717# define DP_REMOTE_CONTROL_COMMAND_PENDING (1 << 0)
718# define DP_AUTOMATED_TEST_REQUEST (1 << 1)
719# define DP_CP_IRQ (1 << 2)
720# define DP_MCCS_IRQ (1 << 3)
721# define DP_DOWN_REP_MSG_RDY (1 << 4)
722# define DP_UP_REQ_MSG_RDY (1 << 5)
723# define DP_SINK_SPECIFIC_IRQ (1 << 6)
724
725#define DP_LANE0_1_STATUS 0x202
726#define DP_LANE2_3_STATUS 0x203
727# define DP_LANE_CR_DONE (1 << 0)
728# define DP_LANE_CHANNEL_EQ_DONE (1 << 1)
729# define DP_LANE_SYMBOL_LOCKED (1 << 2)
730
731#define DP_CHANNEL_EQ_BITS (DP_LANE_CR_DONE | \
732 DP_LANE_CHANNEL_EQ_DONE | \
733 DP_LANE_SYMBOL_LOCKED)
734
735#define DP_LANE_ALIGN_STATUS_UPDATED 0x204
736
737#define DP_INTERLANE_ALIGN_DONE (1 << 0)
738#define DP_DOWNSTREAM_PORT_STATUS_CHANGED (1 << 6)
739#define DP_LINK_STATUS_UPDATED (1 << 7)
740
741#define DP_SINK_STATUS 0x205
742# define DP_RECEIVE_PORT_0_STATUS (1 << 0)
743# define DP_RECEIVE_PORT_1_STATUS (1 << 1)
744# define DP_STREAM_REGENERATION_STATUS (1 << 2)
745
746#define DP_ADJUST_REQUEST_LANE0_1 0x206
747#define DP_ADJUST_REQUEST_LANE2_3 0x207
748# define DP_ADJUST_VOLTAGE_SWING_LANE0_MASK 0x03
749# define DP_ADJUST_VOLTAGE_SWING_LANE0_SHIFT 0
750# define DP_ADJUST_PRE_EMPHASIS_LANE0_MASK 0x0c
751# define DP_ADJUST_PRE_EMPHASIS_LANE0_SHIFT 2
752# define DP_ADJUST_VOLTAGE_SWING_LANE1_MASK 0x30
753# define DP_ADJUST_VOLTAGE_SWING_LANE1_SHIFT 4
754# define DP_ADJUST_PRE_EMPHASIS_LANE1_MASK 0xc0
755# define DP_ADJUST_PRE_EMPHASIS_LANE1_SHIFT 6
756
757
758# define DP_ADJUST_TX_FFE_PRESET_LANE0_MASK (0xf << 0)
759# define DP_ADJUST_TX_FFE_PRESET_LANE0_SHIFT 0
760# define DP_ADJUST_TX_FFE_PRESET_LANE1_MASK (0xf << 4)
761# define DP_ADJUST_TX_FFE_PRESET_LANE1_SHIFT 4
762
763#define DP_ADJUST_REQUEST_POST_CURSOR2 0x20c
764# define DP_ADJUST_POST_CURSOR2_LANE0_MASK 0x03
765# define DP_ADJUST_POST_CURSOR2_LANE0_SHIFT 0
766# define DP_ADJUST_POST_CURSOR2_LANE1_MASK 0x0c
767# define DP_ADJUST_POST_CURSOR2_LANE1_SHIFT 2
768# define DP_ADJUST_POST_CURSOR2_LANE2_MASK 0x30
769# define DP_ADJUST_POST_CURSOR2_LANE2_SHIFT 4
770# define DP_ADJUST_POST_CURSOR2_LANE3_MASK 0xc0
771# define DP_ADJUST_POST_CURSOR2_LANE3_SHIFT 6
772
773#define DP_TEST_REQUEST 0x218
774# define DP_TEST_LINK_TRAINING (1 << 0)
775# define DP_TEST_LINK_VIDEO_PATTERN (1 << 1)
776# define DP_TEST_LINK_EDID_READ (1 << 2)
777# define DP_TEST_LINK_PHY_TEST_PATTERN (1 << 3)
778# define DP_TEST_LINK_FAUX_PATTERN (1 << 4)
779# define DP_TEST_LINK_AUDIO_PATTERN (1 << 5)
780# define DP_TEST_LINK_AUDIO_DISABLED_VIDEO (1 << 6)
781
782#define DP_TEST_LINK_RATE 0x219
783# define DP_LINK_RATE_162 (0x6)
784# define DP_LINK_RATE_27 (0xa)
785
786#define DP_TEST_LANE_COUNT 0x220
787
788#define DP_TEST_PATTERN 0x221
789# define DP_NO_TEST_PATTERN 0x0
790# define DP_COLOR_RAMP 0x1
791# define DP_BLACK_AND_WHITE_VERTICAL_LINES 0x2
792# define DP_COLOR_SQUARE 0x3
793
794#define DP_TEST_H_TOTAL_HI 0x222
795#define DP_TEST_H_TOTAL_LO 0x223
796
797#define DP_TEST_V_TOTAL_HI 0x224
798#define DP_TEST_V_TOTAL_LO 0x225
799
800#define DP_TEST_H_START_HI 0x226
801#define DP_TEST_H_START_LO 0x227
802
803#define DP_TEST_V_START_HI 0x228
804#define DP_TEST_V_START_LO 0x229
805
806#define DP_TEST_HSYNC_HI 0x22A
807# define DP_TEST_HSYNC_POLARITY (1 << 7)
808# define DP_TEST_HSYNC_WIDTH_HI_MASK (127 << 0)
809#define DP_TEST_HSYNC_WIDTH_LO 0x22B
810
811#define DP_TEST_VSYNC_HI 0x22C
812# define DP_TEST_VSYNC_POLARITY (1 << 7)
813# define DP_TEST_VSYNC_WIDTH_HI_MASK (127 << 0)
814#define DP_TEST_VSYNC_WIDTH_LO 0x22D
815
816#define DP_TEST_H_WIDTH_HI 0x22E
817#define DP_TEST_H_WIDTH_LO 0x22F
818
819#define DP_TEST_V_HEIGHT_HI 0x230
820#define DP_TEST_V_HEIGHT_LO 0x231
821
822#define DP_TEST_MISC0 0x232
823# define DP_TEST_SYNC_CLOCK (1 << 0)
824# define DP_TEST_COLOR_FORMAT_MASK (3 << 1)
825# define DP_TEST_COLOR_FORMAT_SHIFT 1
826# define DP_COLOR_FORMAT_RGB (0 << 1)
827# define DP_COLOR_FORMAT_YCbCr422 (1 << 1)
828# define DP_COLOR_FORMAT_YCbCr444 (2 << 1)
829# define DP_TEST_DYNAMIC_RANGE_VESA (0 << 3)
830# define DP_TEST_DYNAMIC_RANGE_CEA (1 << 3)
831# define DP_TEST_YCBCR_COEFFICIENTS (1 << 4)
832# define DP_YCBCR_COEFFICIENTS_ITU601 (0 << 4)
833# define DP_YCBCR_COEFFICIENTS_ITU709 (1 << 4)
834# define DP_TEST_BIT_DEPTH_MASK (7 << 5)
835# define DP_TEST_BIT_DEPTH_SHIFT 5
836# define DP_TEST_BIT_DEPTH_6 (0 << 5)
837# define DP_TEST_BIT_DEPTH_8 (1 << 5)
838# define DP_TEST_BIT_DEPTH_10 (2 << 5)
839# define DP_TEST_BIT_DEPTH_12 (3 << 5)
840# define DP_TEST_BIT_DEPTH_16 (4 << 5)
841
842#define DP_TEST_MISC1 0x233
843# define DP_TEST_REFRESH_DENOMINATOR (1 << 0)
844# define DP_TEST_INTERLACED (1 << 1)
845
846#define DP_TEST_REFRESH_RATE_NUMERATOR 0x234
847
848#define DP_TEST_MISC0 0x232
849
850#define DP_TEST_CRC_R_CR 0x240
851#define DP_TEST_CRC_G_Y 0x242
852#define DP_TEST_CRC_B_CB 0x244
853
854#define DP_TEST_SINK_MISC 0x246
855# define DP_TEST_CRC_SUPPORTED (1 << 5)
856# define DP_TEST_COUNT_MASK 0xf
857
858#define DP_PHY_TEST_PATTERN 0x248
859# define DP_PHY_TEST_PATTERN_SEL_MASK 0x7
860# define DP_PHY_TEST_PATTERN_NONE 0x0
861# define DP_PHY_TEST_PATTERN_D10_2 0x1
862# define DP_PHY_TEST_PATTERN_ERROR_COUNT 0x2
863# define DP_PHY_TEST_PATTERN_PRBS7 0x3
864# define DP_PHY_TEST_PATTERN_80BIT_CUSTOM 0x4
865# define DP_PHY_TEST_PATTERN_CP2520 0x5
866
867#define DP_TEST_HBR2_SCRAMBLER_RESET 0x24A
868#define DP_TEST_80BIT_CUSTOM_PATTERN_7_0 0x250
869#define DP_TEST_80BIT_CUSTOM_PATTERN_15_8 0x251
870#define DP_TEST_80BIT_CUSTOM_PATTERN_23_16 0x252
871#define DP_TEST_80BIT_CUSTOM_PATTERN_31_24 0x253
872#define DP_TEST_80BIT_CUSTOM_PATTERN_39_32 0x254
873#define DP_TEST_80BIT_CUSTOM_PATTERN_47_40 0x255
874#define DP_TEST_80BIT_CUSTOM_PATTERN_55_48 0x256
875#define DP_TEST_80BIT_CUSTOM_PATTERN_63_56 0x257
876#define DP_TEST_80BIT_CUSTOM_PATTERN_71_64 0x258
877#define DP_TEST_80BIT_CUSTOM_PATTERN_79_72 0x259
878
879#define DP_TEST_RESPONSE 0x260
880# define DP_TEST_ACK (1 << 0)
881# define DP_TEST_NAK (1 << 1)
882# define DP_TEST_EDID_CHECKSUM_WRITE (1 << 2)
883
884#define DP_TEST_EDID_CHECKSUM 0x261
885
886#define DP_TEST_SINK 0x270
887# define DP_TEST_SINK_START (1 << 0)
888#define DP_TEST_AUDIO_MODE 0x271
889#define DP_TEST_AUDIO_PATTERN_TYPE 0x272
890#define DP_TEST_AUDIO_PERIOD_CH1 0x273
891#define DP_TEST_AUDIO_PERIOD_CH2 0x274
892#define DP_TEST_AUDIO_PERIOD_CH3 0x275
893#define DP_TEST_AUDIO_PERIOD_CH4 0x276
894#define DP_TEST_AUDIO_PERIOD_CH5 0x277
895#define DP_TEST_AUDIO_PERIOD_CH6 0x278
896#define DP_TEST_AUDIO_PERIOD_CH7 0x279
897#define DP_TEST_AUDIO_PERIOD_CH8 0x27A
898
899#define DP_FEC_STATUS 0x280
900# define DP_FEC_DECODE_EN_DETECTED (1 << 0)
901# define DP_FEC_DECODE_DIS_DETECTED (1 << 1)
902
903#define DP_FEC_ERROR_COUNT_LSB 0x0281
904
905#define DP_FEC_ERROR_COUNT_MSB 0x0282
906# define DP_FEC_ERROR_COUNT_MASK 0x7F
907# define DP_FEC_ERR_COUNT_VALID (1 << 7)
908
909#define DP_PAYLOAD_TABLE_UPDATE_STATUS 0x2c0
910# define DP_PAYLOAD_TABLE_UPDATED (1 << 0)
911# define DP_PAYLOAD_ACT_HANDLED (1 << 1)
912
913#define DP_VC_PAYLOAD_ID_SLOT_1 0x2c1
914
915
916
917#define DP_SOURCE_OUI 0x300
918
919
920#define DP_SINK_OUI 0x400
921
922
923#define DP_BRANCH_OUI 0x500
924#define DP_BRANCH_ID 0x503
925#define DP_BRANCH_REVISION_START 0x509
926#define DP_BRANCH_HW_REV 0x509
927#define DP_BRANCH_SW_REV 0x50A
928
929
930#define DP_SET_POWER 0x600
931# define DP_SET_POWER_D0 0x1
932# define DP_SET_POWER_D3 0x2
933# define DP_SET_POWER_MASK 0x3
934# define DP_SET_POWER_D3_AUX_ON 0x5
935
936
937#define DP_EDP_DPCD_REV 0x700
938# define DP_EDP_11 0x00
939# define DP_EDP_12 0x01
940# define DP_EDP_13 0x02
941# define DP_EDP_14 0x03
942# define DP_EDP_14a 0x04
943# define DP_EDP_14b 0x05
944
945#define DP_EDP_GENERAL_CAP_1 0x701
946# define DP_EDP_TCON_BACKLIGHT_ADJUSTMENT_CAP (1 << 0)
947# define DP_EDP_BACKLIGHT_PIN_ENABLE_CAP (1 << 1)
948# define DP_EDP_BACKLIGHT_AUX_ENABLE_CAP (1 << 2)
949# define DP_EDP_PANEL_SELF_TEST_PIN_ENABLE_CAP (1 << 3)
950# define DP_EDP_PANEL_SELF_TEST_AUX_ENABLE_CAP (1 << 4)
951# define DP_EDP_FRC_ENABLE_CAP (1 << 5)
952# define DP_EDP_COLOR_ENGINE_CAP (1 << 6)
953# define DP_EDP_SET_POWER_CAP (1 << 7)
954
955#define DP_EDP_BACKLIGHT_ADJUSTMENT_CAP 0x702
956# define DP_EDP_BACKLIGHT_BRIGHTNESS_PWM_PIN_CAP (1 << 0)
957# define DP_EDP_BACKLIGHT_BRIGHTNESS_AUX_SET_CAP (1 << 1)
958# define DP_EDP_BACKLIGHT_BRIGHTNESS_BYTE_COUNT (1 << 2)
959# define DP_EDP_BACKLIGHT_AUX_PWM_PRODUCT_CAP (1 << 3)
960# define DP_EDP_BACKLIGHT_FREQ_PWM_PIN_PASSTHRU_CAP (1 << 4)
961# define DP_EDP_BACKLIGHT_FREQ_AUX_SET_CAP (1 << 5)
962# define DP_EDP_DYNAMIC_BACKLIGHT_CAP (1 << 6)
963# define DP_EDP_VBLANK_BACKLIGHT_UPDATE_CAP (1 << 7)
964
965#define DP_EDP_GENERAL_CAP_2 0x703
966# define DP_EDP_OVERDRIVE_ENGINE_ENABLED (1 << 0)
967
968#define DP_EDP_GENERAL_CAP_3 0x704
969# define DP_EDP_X_REGION_CAP_MASK (0xf << 0)
970# define DP_EDP_X_REGION_CAP_SHIFT 0
971# define DP_EDP_Y_REGION_CAP_MASK (0xf << 4)
972# define DP_EDP_Y_REGION_CAP_SHIFT 4
973
974#define DP_EDP_DISPLAY_CONTROL_REGISTER 0x720
975# define DP_EDP_BACKLIGHT_ENABLE (1 << 0)
976# define DP_EDP_BLACK_VIDEO_ENABLE (1 << 1)
977# define DP_EDP_FRC_ENABLE (1 << 2)
978# define DP_EDP_COLOR_ENGINE_ENABLE (1 << 3)
979# define DP_EDP_VBLANK_BACKLIGHT_UPDATE_ENABLE (1 << 7)
980
981#define DP_EDP_BACKLIGHT_MODE_SET_REGISTER 0x721
982# define DP_EDP_BACKLIGHT_CONTROL_MODE_MASK (3 << 0)
983# define DP_EDP_BACKLIGHT_CONTROL_MODE_PWM (0 << 0)
984# define DP_EDP_BACKLIGHT_CONTROL_MODE_PRESET (1 << 0)
985# define DP_EDP_BACKLIGHT_CONTROL_MODE_DPCD (2 << 0)
986# define DP_EDP_BACKLIGHT_CONTROL_MODE_PRODUCT (3 << 0)
987# define DP_EDP_BACKLIGHT_FREQ_PWM_PIN_PASSTHRU_ENABLE (1 << 2)
988# define DP_EDP_BACKLIGHT_FREQ_AUX_SET_ENABLE (1 << 3)
989# define DP_EDP_DYNAMIC_BACKLIGHT_ENABLE (1 << 4)
990# define DP_EDP_REGIONAL_BACKLIGHT_ENABLE (1 << 5)
991# define DP_EDP_UPDATE_REGION_BRIGHTNESS (1 << 6)
992
993#define DP_EDP_BACKLIGHT_BRIGHTNESS_MSB 0x722
994#define DP_EDP_BACKLIGHT_BRIGHTNESS_LSB 0x723
995
996#define DP_EDP_PWMGEN_BIT_COUNT 0x724
997#define DP_EDP_PWMGEN_BIT_COUNT_CAP_MIN 0x725
998#define DP_EDP_PWMGEN_BIT_COUNT_CAP_MAX 0x726
999# define DP_EDP_PWMGEN_BIT_COUNT_MASK (0x1f << 0)
1000
1001#define DP_EDP_BACKLIGHT_CONTROL_STATUS 0x727
1002
1003#define DP_EDP_BACKLIGHT_FREQ_SET 0x728
1004# define DP_EDP_BACKLIGHT_FREQ_BASE_KHZ 27000
1005
1006#define DP_EDP_BACKLIGHT_FREQ_CAP_MIN_MSB 0x72a
1007#define DP_EDP_BACKLIGHT_FREQ_CAP_MIN_MID 0x72b
1008#define DP_EDP_BACKLIGHT_FREQ_CAP_MIN_LSB 0x72c
1009
1010#define DP_EDP_BACKLIGHT_FREQ_CAP_MAX_MSB 0x72d
1011#define DP_EDP_BACKLIGHT_FREQ_CAP_MAX_MID 0x72e
1012#define DP_EDP_BACKLIGHT_FREQ_CAP_MAX_LSB 0x72f
1013
1014#define DP_EDP_DBC_MINIMUM_BRIGHTNESS_SET 0x732
1015#define DP_EDP_DBC_MAXIMUM_BRIGHTNESS_SET 0x733
1016
1017#define DP_EDP_REGIONAL_BACKLIGHT_BASE 0x740
1018#define DP_EDP_REGIONAL_BACKLIGHT_0 0x741
1019
1020#define DP_EDP_MSO_LINK_CAPABILITIES 0x7a4
1021# define DP_EDP_MSO_NUMBER_OF_LINKS_MASK (7 << 0)
1022# define DP_EDP_MSO_NUMBER_OF_LINKS_SHIFT 0
1023# define DP_EDP_MSO_INDEPENDENT_LINK_BIT (1 << 3)
1024
1025
1026#define DP_SIDEBAND_MSG_DOWN_REQ_BASE 0x1000
1027#define DP_SIDEBAND_MSG_UP_REP_BASE 0x1200
1028#define DP_SIDEBAND_MSG_DOWN_REP_BASE 0x1400
1029#define DP_SIDEBAND_MSG_UP_REQ_BASE 0x1600
1030
1031
1032#define DP_SINK_COUNT_ESI 0x2002
1033
1034# define DP_SINK_COUNT_CP_READY (1 << 6)
1035
1036#define DP_DEVICE_SERVICE_IRQ_VECTOR_ESI0 0x2003
1037
1038#define DP_DEVICE_SERVICE_IRQ_VECTOR_ESI1 0x2004
1039# define DP_RX_GTC_MSTR_REQ_STATUS_CHANGE (1 << 0)
1040# define DP_LOCK_ACQUISITION_REQUEST (1 << 1)
1041# define DP_CEC_IRQ (1 << 2)
1042
1043#define DP_LINK_SERVICE_IRQ_VECTOR_ESI0 0x2005
1044# define RX_CAP_CHANGED (1 << 0)
1045# define LINK_STATUS_CHANGED (1 << 1)
1046# define STREAM_STATUS_CHANGED (1 << 2)
1047# define HDMI_LINK_STATUS_CHANGED (1 << 3)
1048# define CONNECTED_OFF_ENTRY_REQUESTED (1 << 4)
1049
1050#define DP_PSR_ERROR_STATUS 0x2006
1051# define DP_PSR_LINK_CRC_ERROR (1 << 0)
1052# define DP_PSR_RFB_STORAGE_ERROR (1 << 1)
1053# define DP_PSR_VSC_SDP_UNCORRECTABLE_ERROR (1 << 2)
1054
1055#define DP_PSR_ESI 0x2007
1056# define DP_PSR_CAPS_CHANGE (1 << 0)
1057
1058#define DP_PSR_STATUS 0x2008
1059# define DP_PSR_SINK_INACTIVE 0
1060# define DP_PSR_SINK_ACTIVE_SRC_SYNCED 1
1061# define DP_PSR_SINK_ACTIVE_RFB 2
1062# define DP_PSR_SINK_ACTIVE_SINK_SYNCED 3
1063# define DP_PSR_SINK_ACTIVE_RESYNC 4
1064# define DP_PSR_SINK_INTERNAL_ERROR 7
1065# define DP_PSR_SINK_STATE_MASK 0x07
1066
1067#define DP_SYNCHRONIZATION_LATENCY_IN_SINK 0x2009
1068# define DP_MAX_RESYNC_FRAME_COUNT_MASK (0xf << 0)
1069# define DP_MAX_RESYNC_FRAME_COUNT_SHIFT 0
1070# define DP_LAST_ACTUAL_SYNCHRONIZATION_LATENCY_MASK (0xf << 4)
1071# define DP_LAST_ACTUAL_SYNCHRONIZATION_LATENCY_SHIFT 4
1072
1073#define DP_LAST_RECEIVED_PSR_SDP 0x200a
1074# define DP_PSR_STATE_BIT (1 << 0)
1075# define DP_UPDATE_RFB_BIT (1 << 1)
1076# define DP_CRC_VALID_BIT (1 << 2)
1077# define DP_SU_VALID (1 << 3)
1078# define DP_FIRST_SCAN_LINE_SU_REGION (1 << 4)
1079# define DP_LAST_SCAN_LINE_SU_REGION (1 << 5)
1080# define DP_Y_COORDINATE_VALID (1 << 6)
1081
1082#define DP_RECEIVER_ALPM_STATUS 0x200b
1083# define DP_ALPM_LOCK_TIMEOUT_ERROR (1 << 0)
1084
1085#define DP_LANE0_1_STATUS_ESI 0x200c
1086#define DP_LANE2_3_STATUS_ESI 0x200d
1087#define DP_LANE_ALIGN_STATUS_UPDATED_ESI 0x200e
1088#define DP_SINK_STATUS_ESI 0x200f
1089
1090
1091#define DP_DP13_DPCD_REV 0x2200
1092
1093#define DP_DPRX_FEATURE_ENUMERATION_LIST 0x2210
1094# define DP_GTC_CAP (1 << 0)
1095# define DP_SST_SPLIT_SDP_CAP (1 << 1)
1096# define DP_AV_SYNC_CAP (1 << 2)
1097# define DP_VSC_SDP_EXT_FOR_COLORIMETRY_SUPPORTED (1 << 3)
1098# define DP_VSC_EXT_VESA_SDP_SUPPORTED (1 << 4)
1099# define DP_VSC_EXT_VESA_SDP_CHAINING_SUPPORTED (1 << 5)
1100# define DP_VSC_EXT_CEA_SDP_SUPPORTED (1 << 6)
1101# define DP_VSC_EXT_CEA_SDP_CHAINING_SUPPORTED (1 << 7)
1102
1103#define DP_128B132B_SUPPORTED_LINK_RATES 0x2215
1104# define DP_UHBR10 (1 << 0)
1105# define DP_UHBR20 (1 << 1)
1106# define DP_UHBR13_5 (1 << 2)
1107
1108#define DP_128B132B_TRAINING_AUX_RD_INTERVAL 0x2216
1109# define DP_128B132B_TRAINING_AUX_RD_INTERVAL_MASK 0x7f
1110
1111
1112
1113#define DP_CEC_TUNNELING_CAPABILITY 0x3000
1114# define DP_CEC_TUNNELING_CAPABLE (1 << 0)
1115# define DP_CEC_SNOOPING_CAPABLE (1 << 1)
1116# define DP_CEC_MULTIPLE_LA_CAPABLE (1 << 2)
1117
1118#define DP_CEC_TUNNELING_CONTROL 0x3001
1119# define DP_CEC_TUNNELING_ENABLE (1 << 0)
1120# define DP_CEC_SNOOPING_ENABLE (1 << 1)
1121
1122#define DP_CEC_RX_MESSAGE_INFO 0x3002
1123# define DP_CEC_RX_MESSAGE_LEN_MASK (0xf << 0)
1124# define DP_CEC_RX_MESSAGE_LEN_SHIFT 0
1125# define DP_CEC_RX_MESSAGE_HPD_STATE (1 << 4)
1126# define DP_CEC_RX_MESSAGE_HPD_LOST (1 << 5)
1127# define DP_CEC_RX_MESSAGE_ACKED (1 << 6)
1128# define DP_CEC_RX_MESSAGE_ENDED (1 << 7)
1129
1130#define DP_CEC_TX_MESSAGE_INFO 0x3003
1131# define DP_CEC_TX_MESSAGE_LEN_MASK (0xf << 0)
1132# define DP_CEC_TX_MESSAGE_LEN_SHIFT 0
1133# define DP_CEC_TX_RETRY_COUNT_MASK (0x7 << 4)
1134# define DP_CEC_TX_RETRY_COUNT_SHIFT 4
1135# define DP_CEC_TX_MESSAGE_SEND (1 << 7)
1136
1137#define DP_CEC_TUNNELING_IRQ_FLAGS 0x3004
1138# define DP_CEC_RX_MESSAGE_INFO_VALID (1 << 0)
1139# define DP_CEC_RX_MESSAGE_OVERFLOW (1 << 1)
1140# define DP_CEC_TX_MESSAGE_SENT (1 << 4)
1141# define DP_CEC_TX_LINE_ERROR (1 << 5)
1142# define DP_CEC_TX_ADDRESS_NACK_ERROR (1 << 6)
1143# define DP_CEC_TX_DATA_NACK_ERROR (1 << 7)
1144
1145#define DP_CEC_LOGICAL_ADDRESS_MASK 0x300E
1146# define DP_CEC_LOGICAL_ADDRESS_0 (1 << 0)
1147# define DP_CEC_LOGICAL_ADDRESS_1 (1 << 1)
1148# define DP_CEC_LOGICAL_ADDRESS_2 (1 << 2)
1149# define DP_CEC_LOGICAL_ADDRESS_3 (1 << 3)
1150# define DP_CEC_LOGICAL_ADDRESS_4 (1 << 4)
1151# define DP_CEC_LOGICAL_ADDRESS_5 (1 << 5)
1152# define DP_CEC_LOGICAL_ADDRESS_6 (1 << 6)
1153# define DP_CEC_LOGICAL_ADDRESS_7 (1 << 7)
1154#define DP_CEC_LOGICAL_ADDRESS_MASK_2 0x300F
1155# define DP_CEC_LOGICAL_ADDRESS_8 (1 << 0)
1156# define DP_CEC_LOGICAL_ADDRESS_9 (1 << 1)
1157# define DP_CEC_LOGICAL_ADDRESS_10 (1 << 2)
1158# define DP_CEC_LOGICAL_ADDRESS_11 (1 << 3)
1159# define DP_CEC_LOGICAL_ADDRESS_12 (1 << 4)
1160# define DP_CEC_LOGICAL_ADDRESS_13 (1 << 5)
1161# define DP_CEC_LOGICAL_ADDRESS_14 (1 << 6)
1162# define DP_CEC_LOGICAL_ADDRESS_15 (1 << 7)
1163
1164#define DP_CEC_RX_MESSAGE_BUFFER 0x3010
1165#define DP_CEC_TX_MESSAGE_BUFFER 0x3020
1166#define DP_CEC_MESSAGE_BUFFER_LENGTH 0x10
1167
1168
1169#define DP_PCON_HDMI_LINK_CONFIG_1 0x305A
1170# define DP_PCON_ENABLE_MAX_FRL_BW (7 << 0)
1171# define DP_PCON_ENABLE_MAX_BW_0GBPS 0
1172# define DP_PCON_ENABLE_MAX_BW_9GBPS 1
1173# define DP_PCON_ENABLE_MAX_BW_18GBPS 2
1174# define DP_PCON_ENABLE_MAX_BW_24GBPS 3
1175# define DP_PCON_ENABLE_MAX_BW_32GBPS 4
1176# define DP_PCON_ENABLE_MAX_BW_40GBPS 5
1177# define DP_PCON_ENABLE_MAX_BW_48GBPS 6
1178# define DP_PCON_ENABLE_SOURCE_CTL_MODE (1 << 3)
1179# define DP_PCON_ENABLE_CONCURRENT_LINK (1 << 4)
1180# define DP_PCON_ENABLE_SEQUENTIAL_LINK (0 << 4)
1181# define DP_PCON_ENABLE_LINK_FRL_MODE (1 << 5)
1182# define DP_PCON_ENABLE_HPD_READY (1 << 6)
1183# define DP_PCON_ENABLE_HDMI_LINK (1 << 7)
1184
1185
1186#define DP_PCON_HDMI_LINK_CONFIG_2 0x305B
1187# define DP_PCON_MAX_LINK_BW_MASK (0x3F << 0)
1188# define DP_PCON_FRL_BW_MASK_9GBPS (1 << 0)
1189# define DP_PCON_FRL_BW_MASK_18GBPS (1 << 1)
1190# define DP_PCON_FRL_BW_MASK_24GBPS (1 << 2)
1191# define DP_PCON_FRL_BW_MASK_32GBPS (1 << 3)
1192# define DP_PCON_FRL_BW_MASK_40GBPS (1 << 4)
1193# define DP_PCON_FRL_BW_MASK_48GBPS (1 << 5)
1194# define DP_PCON_FRL_LINK_TRAIN_EXTENDED (1 << 6)
1195# define DP_PCON_FRL_LINK_TRAIN_NORMAL (0 << 6)
1196
1197
1198#define DP_PCON_HDMI_TX_LINK_STATUS 0x303B
1199# define DP_PCON_HDMI_TX_LINK_ACTIVE (1 << 0)
1200# define DP_PCON_FRL_READY (1 << 1)
1201
1202
1203#define DP_PCON_HDMI_POST_FRL_STATUS 0x3036
1204# define DP_PCON_HDMI_LINK_MODE (1 << 0)
1205# define DP_PCON_HDMI_MODE_TMDS 0
1206# define DP_PCON_HDMI_MODE_FRL 1
1207# define DP_PCON_HDMI_FRL_TRAINED_BW (0x3F << 1)
1208# define DP_PCON_FRL_TRAINED_BW_9GBPS (1 << 1)
1209# define DP_PCON_FRL_TRAINED_BW_18GBPS (1 << 2)
1210# define DP_PCON_FRL_TRAINED_BW_24GBPS (1 << 3)
1211# define DP_PCON_FRL_TRAINED_BW_32GBPS (1 << 4)
1212# define DP_PCON_FRL_TRAINED_BW_40GBPS (1 << 5)
1213# define DP_PCON_FRL_TRAINED_BW_48GBPS (1 << 6)
1214
1215#define DP_PROTOCOL_CONVERTER_CONTROL_0 0x3050
1216# define DP_HDMI_DVI_OUTPUT_CONFIG (1 << 0)
1217#define DP_PROTOCOL_CONVERTER_CONTROL_1 0x3051
1218# define DP_CONVERSION_TO_YCBCR420_ENABLE (1 << 0)
1219# define DP_HDMI_EDID_PROCESSING_DISABLE (1 << 1)
1220# define DP_HDMI_AUTONOMOUS_SCRAMBLING_DISABLE (1 << 2)
1221# define DP_HDMI_FORCE_SCRAMBLING (1 << 3)
1222#define DP_PROTOCOL_CONVERTER_CONTROL_2 0x3052
1223# define DP_CONVERSION_TO_YCBCR422_ENABLE (1 << 0)
1224# define DP_PCON_ENABLE_DSC_ENCODER (1 << 1)
1225# define DP_PCON_ENCODER_PPS_OVERRIDE_MASK (0x3 << 2)
1226# define DP_PCON_ENC_PPS_OVERRIDE_DISABLED 0
1227# define DP_PCON_ENC_PPS_OVERRIDE_EN_PARAMS 1
1228# define DP_PCON_ENC_PPS_OVERRIDE_EN_BUFFER 2
1229# define DP_CONVERSION_RGB_YCBCR_MASK (7 << 4)
1230# define DP_CONVERSION_BT601_RGB_YCBCR_ENABLE (1 << 4)
1231# define DP_CONVERSION_BT709_RGB_YCBCR_ENABLE (1 << 5)
1232# define DP_CONVERSION_BT2020_RGB_YCBCR_ENABLE (1 << 6)
1233
1234
1235#define DP_PCON_HDMI_ERROR_STATUS_LN0 0x3037
1236#define DP_PCON_HDMI_ERROR_STATUS_LN1 0x3038
1237#define DP_PCON_HDMI_ERROR_STATUS_LN2 0x3039
1238#define DP_PCON_HDMI_ERROR_STATUS_LN3 0x303A
1239# define DP_PCON_HDMI_ERROR_COUNT_MASK (0x7 << 0)
1240# define DP_PCON_HDMI_ERROR_COUNT_THREE_PLUS (1 << 0)
1241# define DP_PCON_HDMI_ERROR_COUNT_TEN_PLUS (1 << 1)
1242# define DP_PCON_HDMI_ERROR_COUNT_HUNDRED_PLUS (1 << 2)
1243
1244
1245
1246
1247#define DP_PCON_HDMI_PPS_OVERRIDE_BASE 0x3100
1248
1249
1250
1251
1252
1253#define DP_PCON_HDMI_PPS_OVRD_SLICE_HEIGHT 0x3180
1254
1255
1256
1257
1258
1259#define DP_PCON_HDMI_PPS_OVRD_SLICE_WIDTH 0x3182
1260
1261
1262
1263
1264
1265#define DP_PCON_HDMI_PPS_OVRD_BPP 0x3184
1266
1267
1268#define DP_AUX_HDCP_BKSV 0x68000
1269#define DP_AUX_HDCP_RI_PRIME 0x68005
1270#define DP_AUX_HDCP_AKSV 0x68007
1271#define DP_AUX_HDCP_AN 0x6800C
1272#define DP_AUX_HDCP_V_PRIME(h) (0x68014 + h * 4)
1273#define DP_AUX_HDCP_BCAPS 0x68028
1274# define DP_BCAPS_REPEATER_PRESENT BIT(1)
1275# define DP_BCAPS_HDCP_CAPABLE BIT(0)
1276#define DP_AUX_HDCP_BSTATUS 0x68029
1277# define DP_BSTATUS_REAUTH_REQ BIT(3)
1278# define DP_BSTATUS_LINK_FAILURE BIT(2)
1279# define DP_BSTATUS_R0_PRIME_READY BIT(1)
1280# define DP_BSTATUS_READY BIT(0)
1281#define DP_AUX_HDCP_BINFO 0x6802A
1282#define DP_AUX_HDCP_KSV_FIFO 0x6802C
1283#define DP_AUX_HDCP_AINFO 0x6803B
1284
1285
1286#define DP_HDCP_2_2_REG_RTX_OFFSET 0x69000
1287#define DP_HDCP_2_2_REG_TXCAPS_OFFSET 0x69008
1288#define DP_HDCP_2_2_REG_CERT_RX_OFFSET 0x6900B
1289#define DP_HDCP_2_2_REG_RRX_OFFSET 0x69215
1290#define DP_HDCP_2_2_REG_RX_CAPS_OFFSET 0x6921D
1291#define DP_HDCP_2_2_REG_EKPUB_KM_OFFSET 0x69220
1292#define DP_HDCP_2_2_REG_EKH_KM_WR_OFFSET 0x692A0
1293#define DP_HDCP_2_2_REG_M_OFFSET 0x692B0
1294#define DP_HDCP_2_2_REG_HPRIME_OFFSET 0x692C0
1295#define DP_HDCP_2_2_REG_EKH_KM_RD_OFFSET 0x692E0
1296#define DP_HDCP_2_2_REG_RN_OFFSET 0x692F0
1297#define DP_HDCP_2_2_REG_LPRIME_OFFSET 0x692F8
1298#define DP_HDCP_2_2_REG_EDKEY_KS_OFFSET 0x69318
1299#define DP_HDCP_2_2_REG_RIV_OFFSET 0x69328
1300#define DP_HDCP_2_2_REG_RXINFO_OFFSET 0x69330
1301#define DP_HDCP_2_2_REG_SEQ_NUM_V_OFFSET 0x69332
1302#define DP_HDCP_2_2_REG_VPRIME_OFFSET 0x69335
1303#define DP_HDCP_2_2_REG_RECV_ID_LIST_OFFSET 0x69345
1304#define DP_HDCP_2_2_REG_V_OFFSET 0x693E0
1305#define DP_HDCP_2_2_REG_SEQ_NUM_M_OFFSET 0x693F0
1306#define DP_HDCP_2_2_REG_K_OFFSET 0x693F3
1307#define DP_HDCP_2_2_REG_STREAM_ID_TYPE_OFFSET 0x693F5
1308#define DP_HDCP_2_2_REG_MPRIME_OFFSET 0x69473
1309#define DP_HDCP_2_2_REG_RXSTATUS_OFFSET 0x69493
1310#define DP_HDCP_2_2_REG_STREAM_TYPE_OFFSET 0x69494
1311#define DP_HDCP_2_2_REG_DBG_OFFSET 0x69518
1312
1313
1314#define DP_LT_TUNABLE_PHY_REPEATER_FIELD_DATA_STRUCTURE_REV 0xf0000
1315#define DP_MAX_LINK_RATE_PHY_REPEATER 0xf0001
1316#define DP_PHY_REPEATER_CNT 0xf0002
1317#define DP_PHY_REPEATER_MODE 0xf0003
1318#define DP_MAX_LANE_COUNT_PHY_REPEATER 0xf0004
1319#define DP_Repeater_FEC_CAPABILITY 0xf0004
1320#define DP_PHY_REPEATER_EXTENDED_WAIT_TIMEOUT 0xf0005
1321
1322enum drm_dp_phy {
1323 DP_PHY_DPRX,
1324
1325 DP_PHY_LTTPR1,
1326 DP_PHY_LTTPR2,
1327 DP_PHY_LTTPR3,
1328 DP_PHY_LTTPR4,
1329 DP_PHY_LTTPR5,
1330 DP_PHY_LTTPR6,
1331 DP_PHY_LTTPR7,
1332 DP_PHY_LTTPR8,
1333
1334 DP_MAX_LTTPR_COUNT = DP_PHY_LTTPR8,
1335};
1336
1337#define DP_PHY_LTTPR(i) (DP_PHY_LTTPR1 + (i))
1338
1339#define __DP_LTTPR1_BASE 0xf0010
1340#define __DP_LTTPR2_BASE 0xf0060
1341#define DP_LTTPR_BASE(dp_phy) \
1342 (__DP_LTTPR1_BASE + (__DP_LTTPR2_BASE - __DP_LTTPR1_BASE) * \
1343 ((dp_phy) - DP_PHY_LTTPR1))
1344
1345#define DP_LTTPR_REG(dp_phy, lttpr1_reg) \
1346 (DP_LTTPR_BASE(dp_phy) - DP_LTTPR_BASE(DP_PHY_LTTPR1) + (lttpr1_reg))
1347
1348#define DP_TRAINING_PATTERN_SET_PHY_REPEATER1 0xf0010
1349#define DP_TRAINING_PATTERN_SET_PHY_REPEATER(dp_phy) \
1350 DP_LTTPR_REG(dp_phy, DP_TRAINING_PATTERN_SET_PHY_REPEATER1)
1351
1352#define DP_TRAINING_LANE0_SET_PHY_REPEATER1 0xf0011
1353#define DP_TRAINING_LANE0_SET_PHY_REPEATER(dp_phy) \
1354 DP_LTTPR_REG(dp_phy, DP_TRAINING_LANE0_SET_PHY_REPEATER1)
1355
1356#define DP_TRAINING_LANE1_SET_PHY_REPEATER1 0xf0012
1357#define DP_TRAINING_LANE2_SET_PHY_REPEATER1 0xf0013
1358#define DP_TRAINING_LANE3_SET_PHY_REPEATER1 0xf0014
1359#define DP_TRAINING_AUX_RD_INTERVAL_PHY_REPEATER1 0xf0020
1360#define DP_TRAINING_AUX_RD_INTERVAL_PHY_REPEATER(dp_phy) \
1361 DP_LTTPR_REG(dp_phy, DP_TRAINING_AUX_RD_INTERVAL_PHY_REPEATER1)
1362
1363#define DP_TRANSMITTER_CAPABILITY_PHY_REPEATER1 0xf0021
1364# define DP_VOLTAGE_SWING_LEVEL_3_SUPPORTED BIT(0)
1365# define DP_PRE_EMPHASIS_LEVEL_3_SUPPORTED BIT(1)
1366
1367#define DP_LANE0_1_STATUS_PHY_REPEATER1 0xf0030
1368#define DP_LANE0_1_STATUS_PHY_REPEATER(dp_phy) \
1369 DP_LTTPR_REG(dp_phy, DP_LANE0_1_STATUS_PHY_REPEATER1)
1370
1371#define DP_LANE2_3_STATUS_PHY_REPEATER1 0xf0031
1372
1373#define DP_LANE_ALIGN_STATUS_UPDATED_PHY_REPEATER1 0xf0032
1374#define DP_ADJUST_REQUEST_LANE0_1_PHY_REPEATER1 0xf0033
1375#define DP_ADJUST_REQUEST_LANE2_3_PHY_REPEATER1 0xf0034
1376#define DP_SYMBOL_ERROR_COUNT_LANE0_PHY_REPEATER1 0xf0035
1377#define DP_SYMBOL_ERROR_COUNT_LANE1_PHY_REPEATER1 0xf0037
1378#define DP_SYMBOL_ERROR_COUNT_LANE2_PHY_REPEATER1 0xf0039
1379#define DP_SYMBOL_ERROR_COUNT_LANE3_PHY_REPEATER1 0xf003b
1380
1381#define __DP_FEC1_BASE 0xf0290
1382#define __DP_FEC2_BASE 0xf0298
1383#define DP_FEC_BASE(dp_phy) \
1384 (__DP_FEC1_BASE + ((__DP_FEC2_BASE - __DP_FEC1_BASE) * \
1385 ((dp_phy) - DP_PHY_LTTPR1)))
1386
1387#define DP_FEC_REG(dp_phy, fec1_reg) \
1388 (DP_FEC_BASE(dp_phy) - DP_FEC_BASE(DP_PHY_LTTPR1) + fec1_reg)
1389
1390#define DP_FEC_STATUS_PHY_REPEATER1 0xf0290
1391#define DP_FEC_STATUS_PHY_REPEATER(dp_phy) \
1392 DP_FEC_REG(dp_phy, DP_FEC_STATUS_PHY_REPEATER1)
1393
1394#define DP_FEC_ERROR_COUNT_PHY_REPEATER1 0xf0291
1395#define DP_FEC_CAPABILITY_PHY_REPEATER1 0xf0294
1396
1397#define DP_LTTPR_MAX_ADD 0xf02ff
1398
1399#define DP_DPCD_MAX_ADD 0xfffff
1400
1401
1402#define DP_PHY_REPEATER_MODE_TRANSPARENT 0x55
1403#define DP_PHY_REPEATER_MODE_NON_TRANSPARENT 0xaa
1404
1405
1406#define DP_HDCP_2_2_AKE_INIT_OFFSET DP_HDCP_2_2_REG_RTX_OFFSET
1407#define DP_HDCP_2_2_AKE_SEND_CERT_OFFSET DP_HDCP_2_2_REG_CERT_RX_OFFSET
1408#define DP_HDCP_2_2_AKE_NO_STORED_KM_OFFSET DP_HDCP_2_2_REG_EKPUB_KM_OFFSET
1409#define DP_HDCP_2_2_AKE_STORED_KM_OFFSET DP_HDCP_2_2_REG_EKH_KM_WR_OFFSET
1410#define DP_HDCP_2_2_AKE_SEND_HPRIME_OFFSET DP_HDCP_2_2_REG_HPRIME_OFFSET
1411#define DP_HDCP_2_2_AKE_SEND_PAIRING_INFO_OFFSET \
1412 DP_HDCP_2_2_REG_EKH_KM_RD_OFFSET
1413#define DP_HDCP_2_2_LC_INIT_OFFSET DP_HDCP_2_2_REG_RN_OFFSET
1414#define DP_HDCP_2_2_LC_SEND_LPRIME_OFFSET DP_HDCP_2_2_REG_LPRIME_OFFSET
1415#define DP_HDCP_2_2_SKE_SEND_EKS_OFFSET DP_HDCP_2_2_REG_EDKEY_KS_OFFSET
1416#define DP_HDCP_2_2_REP_SEND_RECVID_LIST_OFFSET DP_HDCP_2_2_REG_RXINFO_OFFSET
1417#define DP_HDCP_2_2_REP_SEND_ACK_OFFSET DP_HDCP_2_2_REG_V_OFFSET
1418#define DP_HDCP_2_2_REP_STREAM_MANAGE_OFFSET DP_HDCP_2_2_REG_SEQ_NUM_M_OFFSET
1419#define DP_HDCP_2_2_REP_STREAM_READY_OFFSET DP_HDCP_2_2_REG_MPRIME_OFFSET
1420
1421#define HDCP_2_2_DP_RXSTATUS_LEN 1
1422#define HDCP_2_2_DP_RXSTATUS_READY(x) ((x) & BIT(0))
1423#define HDCP_2_2_DP_RXSTATUS_H_PRIME(x) ((x) & BIT(1))
1424#define HDCP_2_2_DP_RXSTATUS_PAIRING(x) ((x) & BIT(2))
1425#define HDCP_2_2_DP_RXSTATUS_REAUTH_REQ(x) ((x) & BIT(3))
1426#define HDCP_2_2_DP_RXSTATUS_LINK_FAILED(x) ((x) & BIT(4))
1427
1428
1429
1430#define DP_PEER_DEVICE_NONE 0x0
1431#define DP_PEER_DEVICE_SOURCE_OR_SST 0x1
1432#define DP_PEER_DEVICE_MST_BRANCHING 0x2
1433#define DP_PEER_DEVICE_SST_SINK 0x3
1434#define DP_PEER_DEVICE_DP_LEGACY_CONV 0x4
1435
1436
1437#define DP_GET_MSG_TRANSACTION_VERSION 0x00
1438#define DP_LINK_ADDRESS 0x01
1439#define DP_CONNECTION_STATUS_NOTIFY 0x02
1440#define DP_ENUM_PATH_RESOURCES 0x10
1441#define DP_ALLOCATE_PAYLOAD 0x11
1442#define DP_QUERY_PAYLOAD 0x12
1443#define DP_RESOURCE_STATUS_NOTIFY 0x13
1444#define DP_CLEAR_PAYLOAD_ID_TABLE 0x14
1445#define DP_REMOTE_DPCD_READ 0x20
1446#define DP_REMOTE_DPCD_WRITE 0x21
1447#define DP_REMOTE_I2C_READ 0x22
1448#define DP_REMOTE_I2C_WRITE 0x23
1449#define DP_POWER_UP_PHY 0x24
1450#define DP_POWER_DOWN_PHY 0x25
1451#define DP_SINK_EVENT_NOTIFY 0x30
1452#define DP_QUERY_STREAM_ENC_STATUS 0x38
1453#define DP_QUERY_STREAM_ENC_STATUS_STATE_NO_EXIST 0
1454#define DP_QUERY_STREAM_ENC_STATUS_STATE_INACTIVE 1
1455#define DP_QUERY_STREAM_ENC_STATUS_STATE_ACTIVE 2
1456
1457
1458#define DP_SIDEBAND_REPLY_ACK 0x00
1459#define DP_SIDEBAND_REPLY_NAK 0x01
1460
1461
1462#define DP_NAK_WRITE_FAILURE 0x01
1463#define DP_NAK_INVALID_READ 0x02
1464#define DP_NAK_CRC_FAILURE 0x03
1465#define DP_NAK_BAD_PARAM 0x04
1466#define DP_NAK_DEFER 0x05
1467#define DP_NAK_LINK_FAILURE 0x06
1468#define DP_NAK_NO_RESOURCES 0x07
1469#define DP_NAK_DPCD_FAIL 0x08
1470#define DP_NAK_I2C_NAK 0x09
1471#define DP_NAK_ALLOCATE_FAIL 0x0a
1472
1473#define MODE_I2C_START 1
1474#define MODE_I2C_WRITE 2
1475#define MODE_I2C_READ 4
1476#define MODE_I2C_STOP 8
1477
1478
1479#define DP_MST_PHYSICAL_PORT_0 0
1480#define DP_MST_LOGICAL_PORT_0 8
1481
1482#define DP_LINK_CONSTANT_N_VALUE 0x8000
1483#define DP_LINK_STATUS_SIZE 6
1484bool drm_dp_channel_eq_ok(const u8 link_status[DP_LINK_STATUS_SIZE],
1485 int lane_count);
1486bool drm_dp_clock_recovery_ok(const u8 link_status[DP_LINK_STATUS_SIZE],
1487 int lane_count);
1488u8 drm_dp_get_adjust_request_voltage(const u8 link_status[DP_LINK_STATUS_SIZE],
1489 int lane);
1490u8 drm_dp_get_adjust_request_pre_emphasis(const u8 link_status[DP_LINK_STATUS_SIZE],
1491 int lane);
1492u8 drm_dp_get_adjust_request_post_cursor(const u8 link_status[DP_LINK_STATUS_SIZE],
1493 unsigned int lane);
1494
1495#define DP_BRANCH_OUI_HEADER_SIZE 0xc
1496#define DP_RECEIVER_CAP_SIZE 0xf
1497#define DP_DSC_RECEIVER_CAP_SIZE 0xf
1498#define EDP_PSR_RECEIVER_CAP_SIZE 2
1499#define EDP_DISPLAY_CTL_CAP_SIZE 3
1500#define DP_LTTPR_COMMON_CAP_SIZE 8
1501#define DP_LTTPR_PHY_CAP_SIZE 3
1502
1503void drm_dp_link_train_clock_recovery_delay(const struct drm_dp_aux *aux,
1504 const u8 dpcd[DP_RECEIVER_CAP_SIZE]);
1505void drm_dp_lttpr_link_train_clock_recovery_delay(void);
1506void drm_dp_link_train_channel_eq_delay(const struct drm_dp_aux *aux,
1507 const u8 dpcd[DP_RECEIVER_CAP_SIZE]);
1508void drm_dp_lttpr_link_train_channel_eq_delay(const struct drm_dp_aux *aux,
1509 const u8 caps[DP_LTTPR_PHY_CAP_SIZE]);
1510
1511u8 drm_dp_link_rate_to_bw_code(int link_rate);
1512int drm_dp_bw_code_to_link_rate(u8 link_bw);
1513
1514#define DP_SDP_AUDIO_TIMESTAMP 0x01
1515#define DP_SDP_AUDIO_STREAM 0x02
1516#define DP_SDP_EXTENSION 0x04
1517#define DP_SDP_AUDIO_COPYMANAGEMENT 0x05
1518#define DP_SDP_ISRC 0x06
1519#define DP_SDP_VSC 0x07
1520#define DP_SDP_CAMERA_GENERIC(i) (0x08 + (i))
1521#define DP_SDP_PPS 0x10
1522#define DP_SDP_VSC_EXT_VESA 0x20
1523#define DP_SDP_VSC_EXT_CEA 0x21
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533struct dp_sdp_header {
1534 u8 HB0;
1535 u8 HB1;
1536 u8 HB2;
1537 u8 HB3;
1538} __packed;
1539
1540#define EDP_SDP_HEADER_REVISION_MASK 0x1F
1541#define EDP_SDP_HEADER_VALID_PAYLOAD_BYTES 0x1F
1542#define DP_SDP_PPS_HEADER_PAYLOAD_BYTES_MINUS_1 0x7F
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565struct dp_sdp {
1566 struct dp_sdp_header sdp_header;
1567 u8 db[32];
1568} __packed;
1569
1570#define EDP_VSC_PSR_STATE_ACTIVE (1<<0)
1571#define EDP_VSC_PSR_UPDATE_RFB (1<<1)
1572#define EDP_VSC_PSR_CRC_VALUES_VALID (1<<2)
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589enum dp_pixelformat {
1590 DP_PIXELFORMAT_RGB = 0,
1591 DP_PIXELFORMAT_YUV444 = 0x1,
1592 DP_PIXELFORMAT_YUV422 = 0x2,
1593 DP_PIXELFORMAT_YUV420 = 0x3,
1594 DP_PIXELFORMAT_Y_ONLY = 0x4,
1595 DP_PIXELFORMAT_RAW = 0x5,
1596 DP_PIXELFORMAT_RESERVED = 0x6,
1597};
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623enum dp_colorimetry {
1624 DP_COLORIMETRY_DEFAULT = 0,
1625 DP_COLORIMETRY_RGB_WIDE_FIXED = 0x1,
1626 DP_COLORIMETRY_BT709_YCC = 0x1,
1627 DP_COLORIMETRY_RGB_WIDE_FLOAT = 0x2,
1628 DP_COLORIMETRY_XVYCC_601 = 0x2,
1629 DP_COLORIMETRY_OPRGB = 0x3,
1630 DP_COLORIMETRY_XVYCC_709 = 0x3,
1631 DP_COLORIMETRY_DCI_P3_RGB = 0x4,
1632 DP_COLORIMETRY_SYCC_601 = 0x4,
1633 DP_COLORIMETRY_RGB_CUSTOM = 0x5,
1634 DP_COLORIMETRY_OPYCC_601 = 0x5,
1635 DP_COLORIMETRY_BT2020_RGB = 0x6,
1636 DP_COLORIMETRY_BT2020_CYCC = 0x6,
1637 DP_COLORIMETRY_BT2020_YCC = 0x7,
1638};
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650enum dp_dynamic_range {
1651 DP_DYNAMIC_RANGE_VESA = 0,
1652 DP_DYNAMIC_RANGE_CTA = 1,
1653};
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669enum dp_content_type {
1670 DP_CONTENT_TYPE_NOT_DEFINED = 0x00,
1671 DP_CONTENT_TYPE_GRAPHICS = 0x01,
1672 DP_CONTENT_TYPE_PHOTO = 0x02,
1673 DP_CONTENT_TYPE_VIDEO = 0x03,
1674 DP_CONTENT_TYPE_GAME = 0x04,
1675};
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693struct drm_dp_vsc_sdp {
1694 unsigned char sdp_type;
1695 unsigned char revision;
1696 unsigned char length;
1697 enum dp_pixelformat pixelformat;
1698 enum dp_colorimetry colorimetry;
1699 int bpc;
1700 enum dp_dynamic_range dynamic_range;
1701 enum dp_content_type content_type;
1702};
1703
1704void drm_dp_vsc_sdp_log(const char *level, struct device *dev,
1705 const struct drm_dp_vsc_sdp *vsc);
1706
1707int drm_dp_psr_setup_time(const u8 psr_cap[EDP_PSR_RECEIVER_CAP_SIZE]);
1708
1709static inline int
1710drm_dp_max_link_rate(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1711{
1712 return drm_dp_bw_code_to_link_rate(dpcd[DP_MAX_LINK_RATE]);
1713}
1714
1715static inline u8
1716drm_dp_max_lane_count(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1717{
1718 return dpcd[DP_MAX_LANE_COUNT] & DP_MAX_LANE_COUNT_MASK;
1719}
1720
1721static inline bool
1722drm_dp_enhanced_frame_cap(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1723{
1724 return dpcd[DP_DPCD_REV] >= 0x11 &&
1725 (dpcd[DP_MAX_LANE_COUNT] & DP_ENHANCED_FRAME_CAP);
1726}
1727
1728static inline bool
1729drm_dp_fast_training_cap(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1730{
1731 return dpcd[DP_DPCD_REV] >= 0x11 &&
1732 (dpcd[DP_MAX_DOWNSPREAD] & DP_NO_AUX_HANDSHAKE_LINK_TRAINING);
1733}
1734
1735static inline bool
1736drm_dp_tps3_supported(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1737{
1738 return dpcd[DP_DPCD_REV] >= 0x12 &&
1739 dpcd[DP_MAX_LANE_COUNT] & DP_TPS3_SUPPORTED;
1740}
1741
1742static inline bool
1743drm_dp_tps4_supported(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1744{
1745 return dpcd[DP_DPCD_REV] >= 0x14 &&
1746 dpcd[DP_MAX_DOWNSPREAD] & DP_TPS4_SUPPORTED;
1747}
1748
1749static inline u8
1750drm_dp_training_pattern_mask(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1751{
1752 return (dpcd[DP_DPCD_REV] >= 0x14) ? DP_TRAINING_PATTERN_MASK_1_4 :
1753 DP_TRAINING_PATTERN_MASK;
1754}
1755
1756static inline bool
1757drm_dp_is_branch(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1758{
1759 return dpcd[DP_DOWNSTREAMPORT_PRESENT] & DP_DWN_STRM_PORT_PRESENT;
1760}
1761
1762
1763u8 drm_dp_dsc_sink_max_slice_count(const u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE],
1764 bool is_edp);
1765u8 drm_dp_dsc_sink_line_buf_depth(const u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE]);
1766int drm_dp_dsc_sink_supported_input_bpcs(const u8 dsc_dpc[DP_DSC_RECEIVER_CAP_SIZE],
1767 u8 dsc_bpc[3]);
1768
1769static inline bool
1770drm_dp_sink_supports_dsc(const u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE])
1771{
1772 return dsc_dpcd[DP_DSC_SUPPORT - DP_DSC_SUPPORT] &
1773 DP_DSC_DECOMPRESSION_IS_SUPPORTED;
1774}
1775
1776static inline u16
1777drm_edp_dsc_sink_output_bpp(const u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE])
1778{
1779 return dsc_dpcd[DP_DSC_MAX_BITS_PER_PIXEL_LOW - DP_DSC_SUPPORT] |
1780 (dsc_dpcd[DP_DSC_MAX_BITS_PER_PIXEL_HI - DP_DSC_SUPPORT] &
1781 DP_DSC_MAX_BITS_PER_PIXEL_HI_MASK <<
1782 DP_DSC_MAX_BITS_PER_PIXEL_HI_SHIFT);
1783}
1784
1785static inline u32
1786drm_dp_dsc_sink_max_slice_width(const u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE])
1787{
1788
1789 return dsc_dpcd[DP_DSC_MAX_SLICE_WIDTH - DP_DSC_SUPPORT] *
1790 DP_DSC_SLICE_WIDTH_MULTIPLIER;
1791}
1792
1793
1794static inline bool
1795drm_dp_sink_supports_fec(const u8 fec_capable)
1796{
1797 return fec_capable & DP_FEC_CAPABLE;
1798}
1799
1800static inline bool
1801drm_dp_channel_coding_supported(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1802{
1803 return dpcd[DP_MAIN_LINK_CHANNEL_CODING] & DP_CAP_ANSI_8B10B;
1804}
1805
1806static inline bool
1807drm_dp_alternate_scrambler_reset_cap(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1808{
1809 return dpcd[DP_EDP_CONFIGURATION_CAP] &
1810 DP_ALTERNATE_SCRAMBLER_RESET_CAP;
1811}
1812
1813
1814static inline bool
1815drm_dp_sink_can_do_video_without_timing_msa(const u8 dpcd[DP_RECEIVER_CAP_SIZE])
1816{
1817 return dpcd[DP_DOWN_STREAM_PORT_COUNT] &
1818 DP_MSA_TIMING_PAR_IGNORED;
1819}
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833struct drm_dp_aux_msg {
1834 unsigned int address;
1835 u8 request;
1836 u8 reply;
1837 void *buffer;
1838 size_t size;
1839};
1840
1841struct cec_adapter;
1842struct edid;
1843struct drm_connector;
1844
1845
1846
1847
1848
1849
1850
1851
1852struct drm_dp_aux_cec {
1853 struct mutex lock;
1854 struct cec_adapter *adap;
1855 struct drm_connector *connector;
1856 struct delayed_work unregister_work;
1857};
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905struct drm_dp_aux {
1906 const char *name;
1907 struct i2c_adapter ddc;
1908 struct device *dev;
1909 struct drm_device *drm_dev;
1910 struct drm_crtc *crtc;
1911 struct mutex hw_mutex;
1912 struct work_struct crc_work;
1913 u8 crc_count;
1914 ssize_t (*transfer)(struct drm_dp_aux *aux,
1915 struct drm_dp_aux_msg *msg);
1916
1917
1918
1919 unsigned i2c_nack_count;
1920
1921
1922
1923 unsigned i2c_defer_count;
1924
1925
1926
1927 struct drm_dp_aux_cec cec;
1928
1929
1930
1931 bool is_remote;
1932};
1933
1934ssize_t drm_dp_dpcd_read(struct drm_dp_aux *aux, unsigned int offset,
1935 void *buffer, size_t size);
1936ssize_t drm_dp_dpcd_write(struct drm_dp_aux *aux, unsigned int offset,
1937 void *buffer, size_t size);
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948static inline ssize_t drm_dp_dpcd_readb(struct drm_dp_aux *aux,
1949 unsigned int offset, u8 *valuep)
1950{
1951 return drm_dp_dpcd_read(aux, offset, valuep, 1);
1952}
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963static inline ssize_t drm_dp_dpcd_writeb(struct drm_dp_aux *aux,
1964 unsigned int offset, u8 value)
1965{
1966 return drm_dp_dpcd_write(aux, offset, &value, 1);
1967}
1968
1969int drm_dp_read_dpcd_caps(struct drm_dp_aux *aux,
1970 u8 dpcd[DP_RECEIVER_CAP_SIZE]);
1971
1972int drm_dp_dpcd_read_link_status(struct drm_dp_aux *aux,
1973 u8 status[DP_LINK_STATUS_SIZE]);
1974
1975int drm_dp_dpcd_read_phy_link_status(struct drm_dp_aux *aux,
1976 enum drm_dp_phy dp_phy,
1977 u8 link_status[DP_LINK_STATUS_SIZE]);
1978
1979bool drm_dp_send_real_edid_checksum(struct drm_dp_aux *aux,
1980 u8 real_edid_checksum);
1981
1982int drm_dp_read_downstream_info(struct drm_dp_aux *aux,
1983 const u8 dpcd[DP_RECEIVER_CAP_SIZE],
1984 u8 downstream_ports[DP_MAX_DOWNSTREAM_PORTS]);
1985bool drm_dp_downstream_is_type(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
1986 const u8 port_cap[4], u8 type);
1987bool drm_dp_downstream_is_tmds(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
1988 const u8 port_cap[4],
1989 const struct edid *edid);
1990int drm_dp_downstream_max_dotclock(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
1991 const u8 port_cap[4]);
1992int drm_dp_downstream_max_tmds_clock(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
1993 const u8 port_cap[4],
1994 const struct edid *edid);
1995int drm_dp_downstream_min_tmds_clock(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
1996 const u8 port_cap[4],
1997 const struct edid *edid);
1998int drm_dp_downstream_max_bpc(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
1999 const u8 port_cap[4],
2000 const struct edid *edid);
2001bool drm_dp_downstream_420_passthrough(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
2002 const u8 port_cap[4]);
2003bool drm_dp_downstream_444_to_420_conversion(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
2004 const u8 port_cap[4]);
2005struct drm_display_mode *drm_dp_downstream_mode(struct drm_device *dev,
2006 const u8 dpcd[DP_RECEIVER_CAP_SIZE],
2007 const u8 port_cap[4]);
2008int drm_dp_downstream_id(struct drm_dp_aux *aux, char id[6]);
2009void drm_dp_downstream_debug(struct seq_file *m,
2010 const u8 dpcd[DP_RECEIVER_CAP_SIZE],
2011 const u8 port_cap[4],
2012 const struct edid *edid,
2013 struct drm_dp_aux *aux);
2014enum drm_mode_subconnector
2015drm_dp_subconnector_type(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
2016 const u8 port_cap[4]);
2017void drm_dp_set_subconnector_property(struct drm_connector *connector,
2018 enum drm_connector_status status,
2019 const u8 *dpcd,
2020 const u8 port_cap[4]);
2021
2022struct drm_dp_desc;
2023bool drm_dp_read_sink_count_cap(struct drm_connector *connector,
2024 const u8 dpcd[DP_RECEIVER_CAP_SIZE],
2025 const struct drm_dp_desc *desc);
2026int drm_dp_read_sink_count(struct drm_dp_aux *aux);
2027
2028int drm_dp_read_lttpr_common_caps(struct drm_dp_aux *aux,
2029 u8 caps[DP_LTTPR_COMMON_CAP_SIZE]);
2030int drm_dp_read_lttpr_phy_caps(struct drm_dp_aux *aux,
2031 enum drm_dp_phy dp_phy,
2032 u8 caps[DP_LTTPR_PHY_CAP_SIZE]);
2033int drm_dp_lttpr_count(const u8 cap[DP_LTTPR_COMMON_CAP_SIZE]);
2034int drm_dp_lttpr_max_link_rate(const u8 caps[DP_LTTPR_COMMON_CAP_SIZE]);
2035int drm_dp_lttpr_max_lane_count(const u8 caps[DP_LTTPR_COMMON_CAP_SIZE]);
2036bool drm_dp_lttpr_voltage_swing_level_3_supported(const u8 caps[DP_LTTPR_PHY_CAP_SIZE]);
2037bool drm_dp_lttpr_pre_emphasis_level_3_supported(const u8 caps[DP_LTTPR_PHY_CAP_SIZE]);
2038
2039void drm_dp_remote_aux_init(struct drm_dp_aux *aux);
2040void drm_dp_aux_init(struct drm_dp_aux *aux);
2041int drm_dp_aux_register(struct drm_dp_aux *aux);
2042void drm_dp_aux_unregister(struct drm_dp_aux *aux);
2043
2044int drm_dp_start_crc(struct drm_dp_aux *aux, struct drm_crtc *crtc);
2045int drm_dp_stop_crc(struct drm_dp_aux *aux);
2046
2047struct drm_dp_dpcd_ident {
2048 u8 oui[3];
2049 u8 device_id[6];
2050 u8 hw_rev;
2051 u8 sw_major_rev;
2052 u8 sw_minor_rev;
2053} __packed;
2054
2055
2056
2057
2058
2059
2060struct drm_dp_desc {
2061 struct drm_dp_dpcd_ident ident;
2062 u32 quirks;
2063};
2064
2065int drm_dp_read_desc(struct drm_dp_aux *aux, struct drm_dp_desc *desc,
2066 bool is_branch);
2067
2068
2069
2070
2071
2072
2073
2074
2075enum drm_dp_quirk {
2076
2077
2078
2079
2080
2081
2082 DP_DPCD_QUIRK_CONSTANT_N,
2083
2084
2085
2086
2087
2088
2089 DP_DPCD_QUIRK_NO_PSR,
2090
2091
2092
2093
2094
2095
2096
2097 DP_DPCD_QUIRK_NO_SINK_COUNT,
2098
2099
2100
2101
2102
2103
2104 DP_DPCD_QUIRK_DSC_WITHOUT_VIRTUAL_DPCD,
2105
2106
2107
2108
2109
2110
2111 DP_DPCD_QUIRK_CAN_DO_MAX_LINK_RATE_3_24_GBPS,
2112};
2113
2114
2115
2116
2117
2118
2119
2120
2121static inline bool
2122drm_dp_has_quirk(const struct drm_dp_desc *desc, enum drm_dp_quirk quirk)
2123{
2124 return desc->quirks & BIT(quirk);
2125}
2126
2127#ifdef CONFIG_DRM_DP_CEC
2128void drm_dp_cec_irq(struct drm_dp_aux *aux);
2129void drm_dp_cec_register_connector(struct drm_dp_aux *aux,
2130 struct drm_connector *connector);
2131void drm_dp_cec_unregister_connector(struct drm_dp_aux *aux);
2132void drm_dp_cec_set_edid(struct drm_dp_aux *aux, const struct edid *edid);
2133void drm_dp_cec_unset_edid(struct drm_dp_aux *aux);
2134#else
2135static inline void drm_dp_cec_irq(struct drm_dp_aux *aux)
2136{
2137}
2138
2139static inline void
2140drm_dp_cec_register_connector(struct drm_dp_aux *aux,
2141 struct drm_connector *connector)
2142{
2143}
2144
2145static inline void drm_dp_cec_unregister_connector(struct drm_dp_aux *aux)
2146{
2147}
2148
2149static inline void drm_dp_cec_set_edid(struct drm_dp_aux *aux,
2150 const struct edid *edid)
2151{
2152}
2153
2154static inline void drm_dp_cec_unset_edid(struct drm_dp_aux *aux)
2155{
2156}
2157
2158#endif
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169struct drm_dp_phy_test_params {
2170 int link_rate;
2171 u8 num_lanes;
2172 u8 phy_pattern;
2173 u8 hbr2_reset[2];
2174 u8 custom80[10];
2175 bool enhanced_frame_cap;
2176};
2177
2178int drm_dp_get_phy_test_pattern(struct drm_dp_aux *aux,
2179 struct drm_dp_phy_test_params *data);
2180int drm_dp_set_phy_test_pattern(struct drm_dp_aux *aux,
2181 struct drm_dp_phy_test_params *data, u8 dp_rev);
2182int drm_dp_get_pcon_max_frl_bw(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
2183 const u8 port_cap[4]);
2184int drm_dp_pcon_frl_prepare(struct drm_dp_aux *aux, bool enable_frl_ready_hpd);
2185bool drm_dp_pcon_is_frl_ready(struct drm_dp_aux *aux);
2186int drm_dp_pcon_frl_configure_1(struct drm_dp_aux *aux, int max_frl_gbps,
2187 u8 frl_mode);
2188int drm_dp_pcon_frl_configure_2(struct drm_dp_aux *aux, int max_frl_mask,
2189 u8 frl_type);
2190int drm_dp_pcon_reset_frl_config(struct drm_dp_aux *aux);
2191int drm_dp_pcon_frl_enable(struct drm_dp_aux *aux);
2192
2193bool drm_dp_pcon_hdmi_link_active(struct drm_dp_aux *aux);
2194int drm_dp_pcon_hdmi_link_mode(struct drm_dp_aux *aux, u8 *frl_trained_mask);
2195void drm_dp_pcon_hdmi_frl_link_error_count(struct drm_dp_aux *aux,
2196 struct drm_connector *connector);
2197bool drm_dp_pcon_enc_is_dsc_1_2(const u8 pcon_dsc_dpcd[DP_PCON_DSC_ENCODER_CAP_SIZE]);
2198int drm_dp_pcon_dsc_max_slices(const u8 pcon_dsc_dpcd[DP_PCON_DSC_ENCODER_CAP_SIZE]);
2199int drm_dp_pcon_dsc_max_slice_width(const u8 pcon_dsc_dpcd[DP_PCON_DSC_ENCODER_CAP_SIZE]);
2200int drm_dp_pcon_dsc_bpp_incr(const u8 pcon_dsc_dpcd[DP_PCON_DSC_ENCODER_CAP_SIZE]);
2201int drm_dp_pcon_pps_default(struct drm_dp_aux *aux);
2202int drm_dp_pcon_pps_override_buf(struct drm_dp_aux *aux, u8 pps_buf[128]);
2203int drm_dp_pcon_pps_override_param(struct drm_dp_aux *aux, u8 pps_param[6]);
2204bool drm_dp_downstream_rgb_to_ycbcr_conversion(const u8 dpcd[DP_RECEIVER_CAP_SIZE],
2205 const u8 port_cap[4], u8 color_spc);
2206int drm_dp_pcon_convert_rgb_to_ycbcr(struct drm_dp_aux *aux, u8 color_spc);
2207
2208#endif
2209