xref: /rk3399_rockchip-uboot/include/edid.h (revision 9c170041dcf97ed3fe5bbd76e70cda2ed3fcbd92)
1d46b5f7dSTom Wai-Hong Tam /*
2d46b5f7dSTom Wai-Hong Tam  * Copyright (c) 2012 The Chromium OS Authors.
3d46b5f7dSTom Wai-Hong Tam  *
4d46b5f7dSTom Wai-Hong Tam  * (C) Copyright 2010
5d46b5f7dSTom Wai-Hong Tam  * Petr Stetiar <ynezz@true.cz>
6d46b5f7dSTom Wai-Hong Tam  *
71a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
8d46b5f7dSTom Wai-Hong Tam  *
9d46b5f7dSTom Wai-Hong Tam  * Contains stolen code from ddcprobe project which is:
10d46b5f7dSTom Wai-Hong Tam  * Copyright (C) Nalin Dahyabhai <bigfun@pobox.com>
1121016d27SAlgea Cao  * (C) Copyright 2008-2017 Fuzhou Rockchip Electronics Co., Ltd
12d46b5f7dSTom Wai-Hong Tam  */
13d46b5f7dSTom Wai-Hong Tam 
14d46b5f7dSTom Wai-Hong Tam #ifndef __EDID_H_
15d46b5f7dSTom Wai-Hong Tam #define __EDID_H_
16d46b5f7dSTom Wai-Hong Tam 
1721016d27SAlgea Cao #include <div64.h>
18d46b5f7dSTom Wai-Hong Tam #include <linux/types.h>
198e2bab3fSAlgea Cao #include <drm_modes.h>
208e2bab3fSAlgea Cao #include <i2c.h>
21d46b5f7dSTom Wai-Hong Tam 
2200cf1167SSimon Glass /* Size of the EDID data */
2300cf1167SSimon Glass #define EDID_SIZE	128
242dcf1433SSimon Glass #define EDID_EXT_SIZE	256
258e2bab3fSAlgea Cao #define MODE_LEN	240
2621016d27SAlgea Cao 
2721016d27SAlgea Cao #define CEA_EXT	    0x02
2821016d27SAlgea Cao #define VTB_EXT	    0x10
2921016d27SAlgea Cao #define DI_EXT	    0x40
3021016d27SAlgea Cao #define LS_EXT	    0x50
3121016d27SAlgea Cao #define MI_EXT	    0x60
3221016d27SAlgea Cao #define DISPLAYID_EXT 0x70
3321016d27SAlgea Cao 
3421016d27SAlgea Cao #define EDID_TIMING_ASPECT_SHIFT 6
3521016d27SAlgea Cao #define EDID_TIMING_ASPECT_MASK  (0x3 << EDID_TIMING_ASPECT_SHIFT)
3621016d27SAlgea Cao 
3721016d27SAlgea Cao /* need to add 60 */
3821016d27SAlgea Cao #define EDID_TIMING_VFREQ_SHIFT  0
3921016d27SAlgea Cao #define EDID_TIMING_VFREQ_MASK   (0x3f << EDID_TIMING_VFREQ_SHIFT)
4000cf1167SSimon Glass 
4143c6bdd0SJernej Skrabec /* OUI of HDMI vendor specific data block */
4243c6bdd0SJernej Skrabec #define HDMI_IEEE_OUI 0x000c03
4343c6bdd0SJernej Skrabec 
4421016d27SAlgea Cao /* drm mode 4k and 3d */
4521016d27SAlgea Cao #define DRM_MODE_FLAG_420_MASK			(0x03 << 23)
4621016d27SAlgea Cao #define  DRM_MODE_FLAG_420			BIT(23)
4721016d27SAlgea Cao #define  DRM_MODE_FLAG_420_ONLY			BIT(24)
4821016d27SAlgea Cao 
4921016d27SAlgea Cao #define BITS_PER_BYTE         8
5021016d27SAlgea Cao #define BITS_TO_LONGS(nr)     DIV_ROUND_UP(nr, BITS_PER_BYTE * sizeof(long))
51d46b5f7dSTom Wai-Hong Tam #define GET_BIT(_x, _pos) \
52d46b5f7dSTom Wai-Hong Tam 	(((_x) >> (_pos)) & 1)
53d46b5f7dSTom Wai-Hong Tam #define GET_BITS(_x, _pos_msb, _pos_lsb) \
54d46b5f7dSTom Wai-Hong Tam 	(((_x) >> (_pos_lsb)) & ((1 << ((_pos_msb) - (_pos_lsb) + 1)) - 1))
558e2bab3fSAlgea Cao #define DRM_MODE(t, c, hd, hss, hse, ht, vd, vss, vse, vt, vs, f) \
568e2bab3fSAlgea Cao 	.clock = (c), .type = (t),\
5721016d27SAlgea Cao 	.hdisplay = (hd), .hsync_start = (hss), .hsync_end = (hse), \
5821016d27SAlgea Cao 	.htotal = (ht), .vdisplay = (vd), \
5921016d27SAlgea Cao 	.vsync_start = (vss), .vsync_end = (vse), .vtotal = (vt), \
6021016d27SAlgea Cao 	.vscan = (vs), .flags = (f)
61d46b5f7dSTom Wai-Hong Tam 
628e2bab3fSAlgea Cao #define DDC_SEGMENT_ADDR 0x30
638e2bab3fSAlgea Cao #define DDC_ADDR 0x50
648e2bab3fSAlgea Cao #define HDMI_EDID_BLOCK_SIZE 128
658e2bab3fSAlgea Cao #define SCDC_I2C_SLAVE_ADDRESS 0x54
668e2bab3fSAlgea Cao 
67d46b5f7dSTom Wai-Hong Tam /* Aspect ratios used in EDID info. */
68d46b5f7dSTom Wai-Hong Tam enum edid_aspect {
69d46b5f7dSTom Wai-Hong Tam 	ASPECT_625 = 0,
70d46b5f7dSTom Wai-Hong Tam 	ASPECT_75,
71d46b5f7dSTom Wai-Hong Tam 	ASPECT_8,
72d46b5f7dSTom Wai-Hong Tam 	ASPECT_5625,
73d46b5f7dSTom Wai-Hong Tam };
74d46b5f7dSTom Wai-Hong Tam 
7521016d27SAlgea Cao struct est_timings {
7621016d27SAlgea Cao 	u8 t1;
7721016d27SAlgea Cao 	u8 t2;
7821016d27SAlgea Cao 	u8 mfg_rsvd;
7921016d27SAlgea Cao } __packed;
8021016d27SAlgea Cao 
8121016d27SAlgea Cao /* 00=16:10, 01=4:3, 10=5:4, 11=16:9 */
8221016d27SAlgea Cao #define EDID_TIMING_ASPECT_SHIFT 6
8321016d27SAlgea Cao #define EDID_TIMING_ASPECT_MASK  (0x3 << EDID_TIMING_ASPECT_SHIFT)
8421016d27SAlgea Cao 
8521016d27SAlgea Cao /* need to add 60 */
8621016d27SAlgea Cao #define EDID_TIMING_VFREQ_SHIFT  0
8721016d27SAlgea Cao #define EDID_TIMING_VFREQ_MASK   (0x3f << EDID_TIMING_VFREQ_SHIFT)
8821016d27SAlgea Cao 
8921016d27SAlgea Cao struct std_timing {
9021016d27SAlgea Cao 	u8 hsize; /* need to multiply by 8 then add 248 */
9121016d27SAlgea Cao 	u8 vfreq_aspect;
9221016d27SAlgea Cao } __packed;
9321016d27SAlgea Cao 
9421016d27SAlgea Cao struct detailed_pixel_timing {
9521016d27SAlgea Cao 	u8 hactive_lo;
9621016d27SAlgea Cao 	u8 hblank_lo;
9721016d27SAlgea Cao 	u8 hactive_hblank_hi;
9821016d27SAlgea Cao 	u8 vactive_lo;
9921016d27SAlgea Cao 	u8 vblank_lo;
10021016d27SAlgea Cao 	u8 vactive_vblank_hi;
10121016d27SAlgea Cao 	u8 hsync_offset_lo;
10221016d27SAlgea Cao 	u8 hsync_pulse_width_lo;
10321016d27SAlgea Cao 	u8 vsync_offset_pulse_width_lo;
10421016d27SAlgea Cao 	u8 hsync_vsync_offset_pulse_width_hi;
10521016d27SAlgea Cao 	u8 width_mm_lo;
10621016d27SAlgea Cao 	u8 height_mm_lo;
10721016d27SAlgea Cao 	u8 width_height_mm_hi;
10821016d27SAlgea Cao 	u8 hborder;
10921016d27SAlgea Cao 	u8 vborder;
11021016d27SAlgea Cao 	u8 misc;
11121016d27SAlgea Cao } __packed;
11221016d27SAlgea Cao 
11321016d27SAlgea Cao /* If it's not pixel timing, it'll be one of the below */
11421016d27SAlgea Cao struct detailed_data_string {
11521016d27SAlgea Cao 	u8 str[13];
11621016d27SAlgea Cao } __packed;
11721016d27SAlgea Cao 
11821016d27SAlgea Cao struct detailed_data_monitor_range {
11921016d27SAlgea Cao 	u8 min_vfreq;
12021016d27SAlgea Cao 	u8 max_vfreq;
12121016d27SAlgea Cao 	u8 min_hfreq_khz;
12221016d27SAlgea Cao 	u8 max_hfreq_khz;
12321016d27SAlgea Cao 	u8 pixel_clock_mhz; /* need to multiply by 10 */
12421016d27SAlgea Cao 	u8 flags;
12521016d27SAlgea Cao 	union {
12621016d27SAlgea Cao 		struct {
12721016d27SAlgea Cao 			u8 reserved;
12821016d27SAlgea Cao 			u8 hfreq_start_khz; /* need to multiply by 2 */
12921016d27SAlgea Cao 			u8 c; /* need to divide by 2 */
13021016d27SAlgea Cao 			__le16 m;
13121016d27SAlgea Cao 			u8 k;
13221016d27SAlgea Cao 			u8 j; /* need to divide by 2 */
13321016d27SAlgea Cao 		} __packed gtf2;
13421016d27SAlgea Cao 		struct {
13521016d27SAlgea Cao 			u8 version;
13621016d27SAlgea Cao 			u8 data1; /* high 6 bits: extra clock resolution */
13721016d27SAlgea Cao 			u8 data2; /* plus low 2 of above: max hactive */
13821016d27SAlgea Cao 			u8 supported_aspects;
13921016d27SAlgea Cao 			u8 flags; /* preferred aspect and blanking support */
14021016d27SAlgea Cao 			u8 supported_scalings;
14121016d27SAlgea Cao 			u8 preferred_refresh;
14221016d27SAlgea Cao 		} __packed cvt;
14321016d27SAlgea Cao 	} formula;
14421016d27SAlgea Cao } __packed;
14521016d27SAlgea Cao 
14621016d27SAlgea Cao struct detailed_data_wpindex {
14721016d27SAlgea Cao 	u8 white_yx_lo; /* Lower 2 bits each */
14821016d27SAlgea Cao 	u8 white_x_hi;
14921016d27SAlgea Cao 	u8 white_y_hi;
15021016d27SAlgea Cao 	u8 gamma; /* need to divide by 100 then add 1 */
15121016d27SAlgea Cao } __packed;
15221016d27SAlgea Cao 
15321016d27SAlgea Cao struct detailed_data_color_point {
15421016d27SAlgea Cao 	u8 windex1;
15521016d27SAlgea Cao 	u8 wpindex1[3];
15621016d27SAlgea Cao 	u8 windex2;
15721016d27SAlgea Cao 	u8 wpindex2[3];
15821016d27SAlgea Cao } __packed;
15921016d27SAlgea Cao 
16021016d27SAlgea Cao struct cvt_timing {
16121016d27SAlgea Cao 	u8 code[3];
16221016d27SAlgea Cao } __packed;
16321016d27SAlgea Cao 
16421016d27SAlgea Cao struct detailed_non_pixel {
16521016d27SAlgea Cao 	u8 pad1;
16621016d27SAlgea Cao 	u8 type; /* ff=serial, fe=string, fd=monitor range, fc=monitor name
16721016d27SAlgea Cao 		  * fb=color point data, fa=standard timing data,
16821016d27SAlgea Cao 		  * f9=undefined, f8=mfg. reserved
16921016d27SAlgea Cao 		  */
17021016d27SAlgea Cao 	u8 pad2;
17121016d27SAlgea Cao 	union {
17221016d27SAlgea Cao 		struct detailed_data_string str;
17321016d27SAlgea Cao 		struct detailed_data_monitor_range range;
17421016d27SAlgea Cao 		struct detailed_data_wpindex color;
17521016d27SAlgea Cao 		struct std_timing timings[6];
17621016d27SAlgea Cao 		struct cvt_timing cvt[4];
17721016d27SAlgea Cao 	} data;
17821016d27SAlgea Cao } __packed;
17921016d27SAlgea Cao 
18021016d27SAlgea Cao #define EDID_DETAIL_EST_TIMINGS 0xf7
18121016d27SAlgea Cao #define EDID_DETAIL_CVT_3BYTE 0xf8
18221016d27SAlgea Cao #define EDID_DETAIL_COLOR_MGMT_DATA 0xf9
18321016d27SAlgea Cao #define EDID_DETAIL_STD_MODES 0xfa
18421016d27SAlgea Cao #define EDID_DETAIL_MONITOR_CPDATA 0xfb
18521016d27SAlgea Cao #define EDID_DETAIL_MONITOR_NAME 0xfc
18621016d27SAlgea Cao #define EDID_DETAIL_MONITOR_RANGE 0xfd
18721016d27SAlgea Cao #define EDID_DETAIL_MONITOR_STRING 0xfe
18821016d27SAlgea Cao #define EDID_DETAIL_MONITOR_SERIAL 0xff
18921016d27SAlgea Cao 
19021016d27SAlgea Cao struct detailed_timing {
19121016d27SAlgea Cao 	__le16 pixel_clock; /* need to multiply by 10 KHz */
19221016d27SAlgea Cao 	union {
19321016d27SAlgea Cao 		struct detailed_pixel_timing pixel_data;
19421016d27SAlgea Cao 		struct detailed_non_pixel other_data;
19521016d27SAlgea Cao 	} data;
19621016d27SAlgea Cao } __packed;
19721016d27SAlgea Cao 
198d46b5f7dSTom Wai-Hong Tam /* Detailed timing information used in EDID v1.x */
199d46b5f7dSTom Wai-Hong Tam struct edid_detailed_timing {
200d46b5f7dSTom Wai-Hong Tam 	unsigned char pixel_clock[2];
201d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_PIXEL_CLOCK(_x) \
202d46b5f7dSTom Wai-Hong Tam 	(((((uint32_t)(_x).pixel_clock[1]) << 8) + \
203d46b5f7dSTom Wai-Hong Tam 	 (_x).pixel_clock[0]) * 10000)
204d46b5f7dSTom Wai-Hong Tam 	unsigned char horizontal_active;
205d46b5f7dSTom Wai-Hong Tam 	unsigned char horizontal_blanking;
206d46b5f7dSTom Wai-Hong Tam 	unsigned char horizontal_active_blanking_hi;
207d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_HORIZONTAL_ACTIVE(_x) \
208d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).horizontal_active_blanking_hi, 7, 4) << 8) + \
209d46b5f7dSTom Wai-Hong Tam 	 (_x).horizontal_active)
210d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_HORIZONTAL_BLANKING(_x) \
211d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).horizontal_active_blanking_hi, 3, 0) << 8) + \
212d46b5f7dSTom Wai-Hong Tam 	 (_x).horizontal_blanking)
213d46b5f7dSTom Wai-Hong Tam 	unsigned char vertical_active;
214d46b5f7dSTom Wai-Hong Tam 	unsigned char vertical_blanking;
215d46b5f7dSTom Wai-Hong Tam 	unsigned char vertical_active_blanking_hi;
216d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_VERTICAL_ACTIVE(_x) \
217d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).vertical_active_blanking_hi, 7, 4) << 8) + \
218d46b5f7dSTom Wai-Hong Tam 	 (_x).vertical_active)
219d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_VERTICAL_BLANKING(_x) \
220d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).vertical_active_blanking_hi, 3, 0) << 8) + \
221d46b5f7dSTom Wai-Hong Tam 	 (_x).vertical_blanking)
222d46b5f7dSTom Wai-Hong Tam 	unsigned char hsync_offset;
223d46b5f7dSTom Wai-Hong Tam 	unsigned char hsync_pulse_width;
2241dc793ddSChristian Gmeiner 	unsigned char vsync_offset_pulse_width;
225d46b5f7dSTom Wai-Hong Tam 	unsigned char hsync_vsync_offset_pulse_width_hi;
226d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_HSYNC_OFFSET(_x) \
227d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).hsync_vsync_offset_pulse_width_hi, 7, 6) << 8) + \
228d46b5f7dSTom Wai-Hong Tam 	 (_x).hsync_offset)
229d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_HSYNC_PULSE_WIDTH(_x) \
230d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).hsync_vsync_offset_pulse_width_hi, 5, 4) << 8) + \
231d46b5f7dSTom Wai-Hong Tam 	 (_x).hsync_pulse_width)
232d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_VSYNC_OFFSET(_x) \
233d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).hsync_vsync_offset_pulse_width_hi, 3, 2) << 4) + \
234d46b5f7dSTom Wai-Hong Tam 	 GET_BITS((_x).vsync_offset_pulse_width, 7, 4))
235d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_VSYNC_PULSE_WIDTH(_x) \
236d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).hsync_vsync_offset_pulse_width_hi, 1, 0) << 4) + \
237d46b5f7dSTom Wai-Hong Tam 	 GET_BITS((_x).vsync_offset_pulse_width, 3, 0))
238d46b5f7dSTom Wai-Hong Tam 	unsigned char himage_size;
239d46b5f7dSTom Wai-Hong Tam 	unsigned char vimage_size;
240d46b5f7dSTom Wai-Hong Tam 	unsigned char himage_vimage_size_hi;
241d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_HIMAGE_SIZE(_x) \
242d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).himage_vimage_size_hi, 7, 4) << 8) + (_x).himage_size)
243d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_VIMAGE_SIZE(_x) \
244d46b5f7dSTom Wai-Hong Tam 	((GET_BITS((_x).himage_vimage_size_hi, 3, 0) << 8) + (_x).vimage_size)
245d46b5f7dSTom Wai-Hong Tam 	unsigned char hborder;
246d46b5f7dSTom Wai-Hong Tam 	unsigned char vborder;
247d46b5f7dSTom Wai-Hong Tam 	unsigned char flags;
248d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_FLAG_INTERLACED(_x) \
249d46b5f7dSTom Wai-Hong Tam 	GET_BIT((_x).flags, 7)
250d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_FLAG_STEREO(_x) \
251d46b5f7dSTom Wai-Hong Tam 	GET_BITS((_x).flags, 6, 5)
252d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_FLAG_DIGITAL_COMPOSITE(_x) \
253d46b5f7dSTom Wai-Hong Tam 	GET_BITS((_x).flags, 4, 3)
254d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_FLAG_POLARITY(_x) \
255d46b5f7dSTom Wai-Hong Tam 	GET_BITS((_x).flags, 2, 1)
256b7ce12ddSHans de Goede #define EDID_DETAILED_TIMING_FLAG_VSYNC_POLARITY(_x) \
257b7ce12ddSHans de Goede 	GET_BIT((_x).flags, 2)
258b7ce12ddSHans de Goede #define EDID_DETAILED_TIMING_FLAG_HSYNC_POLARITY(_x) \
259b7ce12ddSHans de Goede 	GET_BIT((_x).flags, 1)
260d46b5f7dSTom Wai-Hong Tam #define EDID_DETAILED_TIMING_FLAG_INTERLEAVED(_x) \
261d46b5f7dSTom Wai-Hong Tam 	GET_BIT((_x).flags, 0)
262d46b5f7dSTom Wai-Hong Tam } __attribute__ ((__packed__));
263d46b5f7dSTom Wai-Hong Tam 
264d46b5f7dSTom Wai-Hong Tam enum edid_monitor_descriptor_types {
265d46b5f7dSTom Wai-Hong Tam 	EDID_MONITOR_DESCRIPTOR_SERIAL = 0xff,
266d46b5f7dSTom Wai-Hong Tam 	EDID_MONITOR_DESCRIPTOR_ASCII = 0xfe,
267d46b5f7dSTom Wai-Hong Tam 	EDID_MONITOR_DESCRIPTOR_RANGE = 0xfd,
268d46b5f7dSTom Wai-Hong Tam 	EDID_MONITOR_DESCRIPTOR_NAME = 0xfc,
269d46b5f7dSTom Wai-Hong Tam };
270d46b5f7dSTom Wai-Hong Tam 
271d46b5f7dSTom Wai-Hong Tam struct edid_monitor_descriptor {
272d46b5f7dSTom Wai-Hong Tam 	uint16_t zero_flag_1;
273d46b5f7dSTom Wai-Hong Tam 	unsigned char zero_flag_2;
274d46b5f7dSTom Wai-Hong Tam 	unsigned char type;
275d46b5f7dSTom Wai-Hong Tam 	unsigned char zero_flag_3;
276d46b5f7dSTom Wai-Hong Tam 	union {
277d46b5f7dSTom Wai-Hong Tam 		char string[13];
278d46b5f7dSTom Wai-Hong Tam 		struct {
279d46b5f7dSTom Wai-Hong Tam 			unsigned char vertical_min;
280d46b5f7dSTom Wai-Hong Tam 			unsigned char vertical_max;
281d46b5f7dSTom Wai-Hong Tam 			unsigned char horizontal_min;
282d46b5f7dSTom Wai-Hong Tam 			unsigned char horizontal_max;
283d46b5f7dSTom Wai-Hong Tam 			unsigned char pixel_clock_max;
284d46b5f7dSTom Wai-Hong Tam 			unsigned char gtf_data[8];
285d46b5f7dSTom Wai-Hong Tam 		} range_data;
286d46b5f7dSTom Wai-Hong Tam 	} data;
287d46b5f7dSTom Wai-Hong Tam } __attribute__ ((__packed__));
288d46b5f7dSTom Wai-Hong Tam 
28921016d27SAlgea Cao #define DRM_EDID_INPUT_SERRATION_VSYNC (1 << 0)
29021016d27SAlgea Cao #define DRM_EDID_INPUT_SYNC_ON_GREEN   (1 << 1)
29121016d27SAlgea Cao #define DRM_EDID_INPUT_COMPOSITE_SYNC  (1 << 2)
29221016d27SAlgea Cao #define DRM_EDID_INPUT_SEPARATE_SYNCS  (1 << 3)
29321016d27SAlgea Cao #define DRM_EDID_INPUT_BLANK_TO_BLACK  (1 << 4)
29421016d27SAlgea Cao #define DRM_EDID_INPUT_VIDEO_LEVEL     (3 << 5)
29521016d27SAlgea Cao #define DRM_EDID_INPUT_DIGITAL         (1 << 7)
29621016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_MASK    (7 << 4)
29721016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_UNDEF   (0 << 4)
29821016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_6       (1 << 4)
29921016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_8       (2 << 4)
30021016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_10      (3 << 4)
30121016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_12      (4 << 4)
30221016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_14      (5 << 4)
30321016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_16      (6 << 4)
30421016d27SAlgea Cao #define DRM_EDID_DIGITAL_DEPTH_RSVD    (7 << 4)
30521016d27SAlgea Cao #define DRM_EDID_DIGITAL_TYPE_UNDEF    (0)
30621016d27SAlgea Cao #define DRM_EDID_DIGITAL_TYPE_DVI      (1)
30721016d27SAlgea Cao #define DRM_EDID_DIGITAL_TYPE_HDMI_A   (2)
30821016d27SAlgea Cao #define DRM_EDID_DIGITAL_TYPE_HDMI_B   (3)
30921016d27SAlgea Cao #define DRM_EDID_DIGITAL_TYPE_MDDI     (4)
31021016d27SAlgea Cao #define DRM_EDID_DIGITAL_TYPE_DP       (5)
31121016d27SAlgea Cao 
31221016d27SAlgea Cao #define DRM_EDID_FEATURE_DEFAULT_GTF      (1 << 0)
31321016d27SAlgea Cao #define DRM_EDID_FEATURE_PREFERRED_TIMING (1 << 1)
31421016d27SAlgea Cao #define DRM_EDID_FEATURE_STANDARD_COLOR   (1 << 2)
31521016d27SAlgea Cao /* If analog */
3168e2bab3fSAlgea Cao /* 00=mono, 01=rgb, 10=non-rgb, 11=unknown */
3178e2bab3fSAlgea Cao #define DRM_EDID_FEATURE_DISPLAY_TYPE     (3 << 3)
31821016d27SAlgea Cao /* If digital */
31921016d27SAlgea Cao #define DRM_EDID_FEATURE_COLOR_MASK	  (3 << 3)
32021016d27SAlgea Cao #define DRM_EDID_FEATURE_RGB		  (0 << 3)
32121016d27SAlgea Cao #define DRM_EDID_FEATURE_RGB_YCRCB444	  (1 << 3)
32221016d27SAlgea Cao #define DRM_EDID_FEATURE_RGB_YCRCB422	  (2 << 3)
3238e2bab3fSAlgea Cao /* both 4:4:4 and 4:2:2 */
3248e2bab3fSAlgea Cao #define DRM_EDID_FEATURE_RGB_YCRCB	  (3 << 3)
32521016d27SAlgea Cao 
32621016d27SAlgea Cao #define DRM_EDID_FEATURE_PM_ACTIVE_OFF    (1 << 5)
32721016d27SAlgea Cao #define DRM_EDID_FEATURE_PM_SUSPEND       (1 << 6)
32821016d27SAlgea Cao #define DRM_EDID_FEATURE_PM_STANDBY       (1 << 7)
32921016d27SAlgea Cao 
33021016d27SAlgea Cao #define DRM_EDID_HDMI_DC_48               (1 << 6)
33121016d27SAlgea Cao #define DRM_EDID_HDMI_DC_36               (1 << 5)
33221016d27SAlgea Cao #define DRM_EDID_HDMI_DC_30               (1 << 4)
33321016d27SAlgea Cao #define DRM_EDID_HDMI_DC_Y444             (1 << 3)
33421016d27SAlgea Cao 
33521016d27SAlgea Cao /* YCBCR 420 deep color modes */
33621016d27SAlgea Cao #define DRM_EDID_YCBCR420_DC_48		  (1 << 2)
33721016d27SAlgea Cao #define DRM_EDID_YCBCR420_DC_36		  (1 << 1)
33821016d27SAlgea Cao #define DRM_EDID_YCBCR420_DC_30		  (1 << 0)
33921016d27SAlgea Cao #define DRM_EDID_YCBCR420_DC_MASK (DRM_EDID_YCBCR420_DC_48 | \
34021016d27SAlgea Cao 				    DRM_EDID_YCBCR420_DC_36 | \
34121016d27SAlgea Cao 				    DRM_EDID_YCBCR420_DC_30)
34221016d27SAlgea Cao 
343916434d9SAlgea Cao /* HDMI 2.1 additional fields */
344916434d9SAlgea Cao #define DRM_EDID_MAX_FRL_RATE_MASK		0xf0
345916434d9SAlgea Cao #define DRM_EDID_FAPA_START_LOCATION		BIT(0)
346916434d9SAlgea Cao #define DRM_EDID_ALLM				BIT(1)
347916434d9SAlgea Cao #define DRM_EDID_FVA				BIT(2)
348916434d9SAlgea Cao 
349916434d9SAlgea Cao /* Deep Color specific */
350916434d9SAlgea Cao #define DRM_EDID_DC_30BIT_420			BIT(0)
351916434d9SAlgea Cao #define DRM_EDID_DC_36BIT_420			BIT(1)
352916434d9SAlgea Cao #define DRM_EDID_DC_48BIT_420			BIT(2)
353916434d9SAlgea Cao 
354916434d9SAlgea Cao /* VRR specific */
355916434d9SAlgea Cao #define DRM_EDID_CNMVRR				BIT(3)
356916434d9SAlgea Cao #define DRM_EDID_CINEMA_VRR			BIT(4)
357916434d9SAlgea Cao #define DRM_EDID_MDELTA				BIT(5)
358916434d9SAlgea Cao #define DRM_EDID_VRR_MAX_UPPER_MASK		0xc0
359916434d9SAlgea Cao #define DRM_EDID_VRR_MAX_LOWER_MASK		0xff
360916434d9SAlgea Cao #define DRM_EDID_VRR_MIN_MASK			0x3f
361916434d9SAlgea Cao 
362916434d9SAlgea Cao /* DSC specific */
363916434d9SAlgea Cao #define DRM_EDID_DSC_10BPC			BIT(0)
364916434d9SAlgea Cao #define DRM_EDID_DSC_12BPC			BIT(1)
365916434d9SAlgea Cao #define DRM_EDID_DSC_16BPC			BIT(2)
366916434d9SAlgea Cao #define DRM_EDID_DSC_ALL_BPP			BIT(3)
367916434d9SAlgea Cao #define DRM_EDID_DSC_NATIVE_420			BIT(6)
368916434d9SAlgea Cao #define DRM_EDID_DSC_1P2			BIT(7)
369916434d9SAlgea Cao #define DRM_EDID_DSC_MAX_FRL_RATE_MASK		0xf0
370916434d9SAlgea Cao #define DRM_EDID_DSC_MAX_SLICES			0xf
371916434d9SAlgea Cao #define DRM_EDID_DSC_TOTAL_CHUNK_KBYTES		0x3f
372916434d9SAlgea Cao 
373d46b5f7dSTom Wai-Hong Tam struct edid1_info {
374d46b5f7dSTom Wai-Hong Tam 	unsigned char header[8];
375d46b5f7dSTom Wai-Hong Tam 	unsigned char manufacturer_name[2];
376d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_MANUFACTURER_NAME_ZERO(_x) \
377d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).manufacturer_name[0]), 7)
378d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_MANUFACTURER_NAME_CHAR1(_x) \
379d46b5f7dSTom Wai-Hong Tam 	GET_BITS(((_x).manufacturer_name[0]), 6, 2)
380d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_MANUFACTURER_NAME_CHAR2(_x) \
381d46b5f7dSTom Wai-Hong Tam 	((GET_BITS(((_x).manufacturer_name[0]), 1, 0) << 3) + \
382d46b5f7dSTom Wai-Hong Tam 	 GET_BITS(((_x).manufacturer_name[1]), 7, 5))
383d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_MANUFACTURER_NAME_CHAR3(_x) \
384d46b5f7dSTom Wai-Hong Tam 	GET_BITS(((_x).manufacturer_name[1]), 4, 0)
385d46b5f7dSTom Wai-Hong Tam 	unsigned char product_code[2];
386d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_PRODUCT_CODE(_x) \
387d46b5f7dSTom Wai-Hong Tam 	(((uint16_t)(_x).product_code[1] << 8) + (_x).product_code[0])
388d46b5f7dSTom Wai-Hong Tam 	unsigned char serial_number[4];
389d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_SERIAL_NUMBER(_x) \
390d46b5f7dSTom Wai-Hong Tam 	(((uint32_t)(_x).serial_number[3] << 24) + \
391d46b5f7dSTom Wai-Hong Tam 	 ((_x).serial_number[2] << 16) + ((_x).serial_number[1] << 8) + \
392d46b5f7dSTom Wai-Hong Tam 	 (_x).serial_number[0])
393d46b5f7dSTom Wai-Hong Tam 	unsigned char week;
394d46b5f7dSTom Wai-Hong Tam 	unsigned char year;
395d46b5f7dSTom Wai-Hong Tam 	unsigned char version;
396d46b5f7dSTom Wai-Hong Tam 	unsigned char revision;
397d46b5f7dSTom Wai-Hong Tam 	unsigned char video_input_definition;
398d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_VIDEO_INPUT_DIGITAL(_x) \
399d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).video_input_definition), 7)
400d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_VIDEO_INPUT_VOLTAGE_LEVEL(_x) \
401d46b5f7dSTom Wai-Hong Tam 	GET_BITS(((_x).video_input_definition), 6, 5)
402d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_VIDEO_INPUT_BLANK_TO_BLACK(_x) \
403d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).video_input_definition), 4)
404d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_VIDEO_INPUT_SEPARATE_SYNC(_x) \
405d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).video_input_definition), 3)
406d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_VIDEO_INPUT_COMPOSITE_SYNC(_x) \
407d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).video_input_definition), 2)
408d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_VIDEO_INPUT_SYNC_ON_GREEN(_x) \
409d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).video_input_definition), 1)
410d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_VIDEO_INPUT_SERRATION_V(_x) \
411d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).video_input_definition), 0)
412d46b5f7dSTom Wai-Hong Tam 	unsigned char max_size_horizontal;
413d46b5f7dSTom Wai-Hong Tam 	unsigned char max_size_vertical;
414d46b5f7dSTom Wai-Hong Tam 	unsigned char gamma;
415d46b5f7dSTom Wai-Hong Tam 	unsigned char feature_support;
416d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_FEATURE_STANDBY(_x) \
417d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).feature_support), 7)
418d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_FEATURE_SUSPEND(_x) \
419d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).feature_support), 6)
420d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_FEATURE_ACTIVE_OFF(_x) \
421d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).feature_support), 5)
422d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_FEATURE_DISPLAY_TYPE(_x) \
423d46b5f7dSTom Wai-Hong Tam 	GET_BITS(((_x).feature_support), 4, 3)
424d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_FEATURE_RGB(_x) \
425d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).feature_support), 2)
426d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_FEATURE_PREFERRED_TIMING_MODE(_x) \
427d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).feature_support), 1)
428d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_FEATURE_DEFAULT_GTF_SUPPORT(_x) \
429d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).feature_support), 0)
430d46b5f7dSTom Wai-Hong Tam 	unsigned char color_characteristics[10];
431d46b5f7dSTom Wai-Hong Tam 	unsigned char established_timings[3];
432d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_720X400_70(_x) \
433d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[0]), 7)
434d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_720X400_88(_x) \
435d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[0]), 6)
436d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_640X480_60(_x) \
437d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[0]), 5)
438d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_640X480_67(_x) \
439d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[0]), 4)
440d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_640X480_72(_x) \
441d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[0]), 3)
442d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_640X480_75(_x) \
443d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[0]), 2)
444d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_800X600_56(_x) \
445d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[0]), 1)
446d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_800X600_60(_x) \
447d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[0]), 0)
448d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_800X600_72(_x) \
449d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[1]), 7)
450d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_800X600_75(_x) \
451d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[1]), 6)
452d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_832X624_75(_x) \
453d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[1]), 5)
454d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_1024X768_87I(_x) \
455d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[1]), 4)
456d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_1024X768_60(_x) \
457d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[1]), 3)
458d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_1024X768_70(_x) \
459d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[1]), 2)
460d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_1024X768_75(_x) \
461d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[1]), 1)
462d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_1280X1024_75(_x) \
463d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[1]), 0)
464d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_ESTABLISHED_TIMING_1152X870_75(_x) \
465d46b5f7dSTom Wai-Hong Tam 	GET_BIT(((_x).established_timings[2]), 7)
466d46b5f7dSTom Wai-Hong Tam 	struct {
467d46b5f7dSTom Wai-Hong Tam 		unsigned char xresolution;
468d46b5f7dSTom Wai-Hong Tam 		unsigned char aspect_vfreq;
469d46b5f7dSTom Wai-Hong Tam 	} __attribute__((__packed__)) standard_timings[8];
470d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_STANDARD_TIMING_XRESOLUTION(_x, _i) \
471d46b5f7dSTom Wai-Hong Tam 	(((_x).standard_timings[_i]).xresolution)
472d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_STANDARD_TIMING_ASPECT(_x, _i) \
473d46b5f7dSTom Wai-Hong Tam 	GET_BITS(((_x).standard_timings[_i].aspect_vfreq), 7, 6)
474d46b5f7dSTom Wai-Hong Tam #define EDID1_INFO_STANDARD_TIMING_VFREQ(_x, _i) \
475d46b5f7dSTom Wai-Hong Tam 	GET_BITS(((_x).standard_timings[_i].aspect_vfreq), 5, 0)
476d46b5f7dSTom Wai-Hong Tam 	union {
477d46b5f7dSTom Wai-Hong Tam 		unsigned char timing[72];
478d46b5f7dSTom Wai-Hong Tam 		struct edid_monitor_descriptor descriptor[4];
479d46b5f7dSTom Wai-Hong Tam 	} monitor_details;
480d46b5f7dSTom Wai-Hong Tam 	unsigned char extension_flag;
481d46b5f7dSTom Wai-Hong Tam 	unsigned char checksum;
482d46b5f7dSTom Wai-Hong Tam } __attribute__ ((__packed__));
483d46b5f7dSTom Wai-Hong Tam 
48443c6bdd0SJernej Skrabec enum edid_cea861_db_types {
48543c6bdd0SJernej Skrabec 	EDID_CEA861_DB_AUDIO = 0x01,
48643c6bdd0SJernej Skrabec 	EDID_CEA861_DB_VIDEO = 0x02,
48743c6bdd0SJernej Skrabec 	EDID_CEA861_DB_VENDOR = 0x03,
48843c6bdd0SJernej Skrabec 	EDID_CEA861_DB_SPEAKER = 0x04,
48921016d27SAlgea Cao 	EDID_CEA861_DB_USE_EXTENDED = 0x07,
49043c6bdd0SJernej Skrabec };
49143c6bdd0SJernej Skrabec 
49221016d27SAlgea Cao #define EXT_VIDEO_CAPABILITY_BLOCK 0x00
49321016d27SAlgea Cao #define EXT_VIDEO_DATA_BLOCK_420        0x0E
49421016d27SAlgea Cao #define EXT_VIDEO_CAP_BLOCK_Y420CMDB 0x0F
49521016d27SAlgea Cao #define EDID_BASIC_AUDIO        BIT(6)
49621016d27SAlgea Cao #define EDID_CEA_YCRCB444       BIT(5)
49721016d27SAlgea Cao #define EDID_CEA_YCRCB422       BIT(4)
49821016d27SAlgea Cao #define EDID_CEA_VCDB_QS        BIT(6)
49921016d27SAlgea Cao 
50021016d27SAlgea Cao #define EXT_VIDEO_DATA_BLOCK_420 0x0E
50121016d27SAlgea Cao 
502d2fabdc7SHans de Goede struct edid_cea861_info {
503d2fabdc7SHans de Goede 	unsigned char extension_tag;
504d2fabdc7SHans de Goede #define EDID_CEA861_EXTENSION_TAG	0x02
505d2fabdc7SHans de Goede 	unsigned char revision;
506d2fabdc7SHans de Goede 	unsigned char dtd_offset;
507d2fabdc7SHans de Goede 	unsigned char dtd_count;
508d2fabdc7SHans de Goede #define EDID_CEA861_SUPPORTS_UNDERSCAN(_x) \
509d2fabdc7SHans de Goede 	GET_BIT(((_x).dtd_count), 7)
510d2fabdc7SHans de Goede #define EDID_CEA861_SUPPORTS_BASIC_AUDIO(_x) \
511d2fabdc7SHans de Goede 	GET_BIT(((_x).dtd_count), 6)
512d2fabdc7SHans de Goede #define EDID_CEA861_SUPPORTS_YUV444(_x) \
513d2fabdc7SHans de Goede 	GET_BIT(((_x).dtd_count), 5)
514d2fabdc7SHans de Goede #define EDID_CEA861_SUPPORTS_YUV422(_x) \
515d2fabdc7SHans de Goede 	GET_BIT(((_x).dtd_count), 4)
516d2fabdc7SHans de Goede #define EDID_CEA861_DTD_COUNT(_x) \
517d2fabdc7SHans de Goede 	GET_BITS(((_x).dtd_count), 3, 0)
518d2fabdc7SHans de Goede 	unsigned char data[124];
51943c6bdd0SJernej Skrabec #define EDID_CEA861_DB_TYPE(_x, offset) \
52043c6bdd0SJernej Skrabec 	GET_BITS((_x).data[offset], 7, 5)
52143c6bdd0SJernej Skrabec #define EDID_CEA861_DB_LEN(_x, offset) \
52243c6bdd0SJernej Skrabec 	GET_BITS((_x).data[offset], 4, 0)
523d2fabdc7SHans de Goede } __attribute__ ((__packed__));
524d2fabdc7SHans de Goede 
52521016d27SAlgea Cao #define DATA_BLOCK_PRODUCT_ID 0x00
52621016d27SAlgea Cao #define DATA_BLOCK_DISPLAY_PARAMETERS 0x01
52721016d27SAlgea Cao #define DATA_BLOCK_COLOR_CHARACTERISTICS 0x02
52821016d27SAlgea Cao #define DATA_BLOCK_TYPE_1_DETAILED_TIMING 0x03
52921016d27SAlgea Cao #define DATA_BLOCK_TYPE_2_DETAILED_TIMING 0x04
53021016d27SAlgea Cao #define DATA_BLOCK_TYPE_3_SHORT_TIMING 0x05
53121016d27SAlgea Cao #define DATA_BLOCK_TYPE_4_DMT_TIMING 0x06
53221016d27SAlgea Cao #define DATA_BLOCK_VESA_TIMING 0x07
53321016d27SAlgea Cao #define DATA_BLOCK_CEA_TIMING 0x08
53421016d27SAlgea Cao #define DATA_BLOCK_VIDEO_TIMING_RANGE 0x09
53521016d27SAlgea Cao #define DATA_BLOCK_PRODUCT_SERIAL_NUMBER 0x0a
53621016d27SAlgea Cao #define DATA_BLOCK_GP_ASCII_STRING 0x0b
53721016d27SAlgea Cao #define DATA_BLOCK_DISPLAY_DEVICE_DATA 0x0c
53821016d27SAlgea Cao #define DATA_BLOCK_INTERFACE_POWER_SEQUENCING 0x0d
53921016d27SAlgea Cao #define DATA_BLOCK_TRANSFER_CHARACTERISTICS 0x0e
54021016d27SAlgea Cao #define DATA_BLOCK_DISPLAY_INTERFACE 0x0f
54121016d27SAlgea Cao #define DATA_BLOCK_STEREO_DISPLAY_INTERFACE 0x10
54221016d27SAlgea Cao #define DATA_BLOCK_TILED_DISPLAY 0x12
54321016d27SAlgea Cao 
54421016d27SAlgea Cao struct displayid_hdr {
54521016d27SAlgea Cao 	u8 rev;
54621016d27SAlgea Cao 	u8 bytes;
54721016d27SAlgea Cao 	u8 prod_id;
54821016d27SAlgea Cao 	u8 ext_count;
54921016d27SAlgea Cao } __packed;
55021016d27SAlgea Cao 
55121016d27SAlgea Cao struct displayid_block {
55221016d27SAlgea Cao 	u8 tag;
55321016d27SAlgea Cao 	u8 rev;
55421016d27SAlgea Cao 	u8 num_bytes;
55521016d27SAlgea Cao } __packed;
55621016d27SAlgea Cao 
55721016d27SAlgea Cao struct displayid_detailed_timings_1 {
55821016d27SAlgea Cao 	u8 pixel_clock[3];
55921016d27SAlgea Cao 	u8 flags;
56021016d27SAlgea Cao 	u8 hactive[2];
56121016d27SAlgea Cao 	u8 hblank[2];
56221016d27SAlgea Cao 	u8 hsync[2];
56321016d27SAlgea Cao 	u8 hsw[2];
56421016d27SAlgea Cao 	u8 vactive[2];
56521016d27SAlgea Cao 	u8 vblank[2];
56621016d27SAlgea Cao 	u8 vsync[2];
56721016d27SAlgea Cao 	u8 vsw[2];
56821016d27SAlgea Cao } __packed;
56921016d27SAlgea Cao 
57021016d27SAlgea Cao struct displayid_detailed_timing_block {
57121016d27SAlgea Cao 	struct displayid_block base;
57221016d27SAlgea Cao 	struct displayid_detailed_timings_1 timings[0];
57321016d27SAlgea Cao };
57421016d27SAlgea Cao 
57521016d27SAlgea Cao /**
57621016d27SAlgea Cao  * struct drm_scrambling: sink's scrambling support.
57721016d27SAlgea Cao  */
57821016d27SAlgea Cao struct drm_scrambling {
57921016d27SAlgea Cao 	/**
58021016d27SAlgea Cao 	 * @supported: scrambling supported for rates > 340 Mhz.
58121016d27SAlgea Cao 	 */
58221016d27SAlgea Cao 	bool supported;
58321016d27SAlgea Cao 	/**
58421016d27SAlgea Cao 	 * @low_rates: scrambling supported for rates <= 340 Mhz.
58521016d27SAlgea Cao 	 */
58621016d27SAlgea Cao 	bool low_rates;
58721016d27SAlgea Cao };
58821016d27SAlgea Cao 
58921016d27SAlgea Cao /**
59021016d27SAlgea Cao  * struct drm_scdc - Information about scdc capabilities of a HDMI 2.0 sink
59121016d27SAlgea Cao  *
59221016d27SAlgea Cao  * Provides SCDC register support and capabilities related information on a
59321016d27SAlgea Cao  * HDMI 2.0 sink. In case of a HDMI 1.4 sink, all parameter must be 0.
59421016d27SAlgea Cao  */
59521016d27SAlgea Cao 
59621016d27SAlgea Cao struct drm_scdc {
59721016d27SAlgea Cao 	/**
59821016d27SAlgea Cao 	 * @supported: status control & data channel present.
59921016d27SAlgea Cao 	 */
60021016d27SAlgea Cao 	bool supported;
60121016d27SAlgea Cao 	/**
60221016d27SAlgea Cao 	 * @read_request: sink is capable of generating scdc read request.
60321016d27SAlgea Cao 	 */
60421016d27SAlgea Cao 	bool read_request;
60521016d27SAlgea Cao 	/**
60621016d27SAlgea Cao 	 * @scrambling: sink's scrambling capabilities
60721016d27SAlgea Cao 	 */
60821016d27SAlgea Cao 	struct drm_scrambling scrambling;
60921016d27SAlgea Cao };
61021016d27SAlgea Cao 
61121016d27SAlgea Cao /**
612916434d9SAlgea Cao  * struct drm_hdmi_dsc_cap - DSC capabilities of HDMI sink
613916434d9SAlgea Cao  *
614916434d9SAlgea Cao  * Describes the DSC support provided by HDMI 2.1 sink.
615916434d9SAlgea Cao  * The information is fetched fom additional HFVSDB blocks defined
616916434d9SAlgea Cao  * for HDMI 2.1.
617916434d9SAlgea Cao  */
618916434d9SAlgea Cao struct drm_hdmi_dsc_cap {
619916434d9SAlgea Cao 	/** @v_1p2: flag for dsc1.2 version support by sink */
620916434d9SAlgea Cao 	bool v_1p2;
621916434d9SAlgea Cao 
622916434d9SAlgea Cao 	/** @native_420: Does sink support DSC with 4:2:0 compression */
623916434d9SAlgea Cao 	bool native_420;
624916434d9SAlgea Cao 
625916434d9SAlgea Cao 	/**
626916434d9SAlgea Cao 	 * @all_bpp: Does sink support all bpp with 4:4:4: or 4:2:2
627916434d9SAlgea Cao 	 * compressed formats
628916434d9SAlgea Cao 	 */
629916434d9SAlgea Cao 	bool all_bpp;
630916434d9SAlgea Cao 
631916434d9SAlgea Cao 	/**
632916434d9SAlgea Cao 	 * @bpc_supported: compressed bpc supported by sink : 10, 12 or 16 bpc
633916434d9SAlgea Cao 	 */
634916434d9SAlgea Cao 	u8 bpc_supported;
635916434d9SAlgea Cao 
636916434d9SAlgea Cao 	/** @max_slices: maximum number of Horizontal slices supported by */
637916434d9SAlgea Cao 	u8 max_slices;
638916434d9SAlgea Cao 
639916434d9SAlgea Cao 	/** @clk_per_slice : max pixel clock in MHz supported per slice */
640916434d9SAlgea Cao 	int clk_per_slice;
641916434d9SAlgea Cao 
642916434d9SAlgea Cao 	/** @max_lanes : dsc max lanes supported for Fixed rate Link training */
643916434d9SAlgea Cao 	u8 max_lanes;
644916434d9SAlgea Cao 
645916434d9SAlgea Cao 	/** @max_frl_rate_per_lane : maximum frl rate with DSC per lane */
646916434d9SAlgea Cao 	u8 max_frl_rate_per_lane;
647916434d9SAlgea Cao 
648916434d9SAlgea Cao 	/** @total_chunk_kbytes: max size of chunks in KBs supported per line*/
649916434d9SAlgea Cao 	u8 total_chunk_kbytes;
650916434d9SAlgea Cao };
651916434d9SAlgea Cao 
652916434d9SAlgea Cao /**
65321016d27SAlgea Cao  * struct drm_hdmi_info - runtime information about the connected HDMI sink
65421016d27SAlgea Cao  *
65521016d27SAlgea Cao  * Describes if a given display supports advanced HDMI 2.0 features.
65621016d27SAlgea Cao  * This information is available in CEA-861-F extension blocks (like HF-VSDB).
65721016d27SAlgea Cao  */
65821016d27SAlgea Cao struct drm_hdmi_info {
65921016d27SAlgea Cao 	struct drm_scdc scdc;
66021016d27SAlgea Cao 
66121016d27SAlgea Cao 	/**
66221016d27SAlgea Cao 	 * @y420_vdb_modes: bitmap of modes which can support ycbcr420
66321016d27SAlgea Cao 	 * output only (not normal RGB/YCBCR444/422 outputs). There are total
66421016d27SAlgea Cao 	 * 107 VICs defined by CEA-861-F spec, so the size is 128 bits to map
66521016d27SAlgea Cao 	 * upto 128 VICs;
66621016d27SAlgea Cao 	 */
66721016d27SAlgea Cao 	unsigned long y420_vdb_modes[BITS_TO_LONGS(128)];
66821016d27SAlgea Cao 
66921016d27SAlgea Cao 	/**
67021016d27SAlgea Cao 	 * @y420_cmdb_modes: bitmap of modes which can support ycbcr420
67121016d27SAlgea Cao 	 * output also, along with normal HDMI outputs. There are total 107
67221016d27SAlgea Cao 	 * VICs defined by CEA-861-F spec, so the size is 128 bits to map upto
67321016d27SAlgea Cao 	 * 128 VICs;
67421016d27SAlgea Cao 	 */
67521016d27SAlgea Cao 	unsigned long y420_cmdb_modes[BITS_TO_LONGS(128)];
67621016d27SAlgea Cao 
67721016d27SAlgea Cao 	/** @y420_cmdb_map: bitmap of SVD index, to extraxt vcb modes */
67821016d27SAlgea Cao 	u64 y420_cmdb_map;
67921016d27SAlgea Cao 
68021016d27SAlgea Cao 	/** @y420_dc_modes: bitmap of deep color support index */
68121016d27SAlgea Cao 	u8 y420_dc_modes;
682916434d9SAlgea Cao 
683916434d9SAlgea Cao 	/** @max_frl_rate_per_lane: support fixed rate link */
684916434d9SAlgea Cao 	u8 max_frl_rate_per_lane;
685916434d9SAlgea Cao 
686916434d9SAlgea Cao 	/** @max_lanes: supported by sink */
687916434d9SAlgea Cao 	u8 max_lanes;
688916434d9SAlgea Cao 
6892760efa8SAlgea Cao 	/* @add_func: support hdmi2.1 function */
6902760efa8SAlgea Cao 	u8 add_func;
6912760efa8SAlgea Cao 
692916434d9SAlgea Cao 	/** @dsc_cap: DSC capabilities of the sink */
693916434d9SAlgea Cao 	struct drm_hdmi_dsc_cap dsc_cap;
69421016d27SAlgea Cao };
69521016d27SAlgea Cao 
69621016d27SAlgea Cao enum subpixel_order {
69721016d27SAlgea Cao 	subpixelunknown = 0,
69821016d27SAlgea Cao 	subpixelhorizontalrgb,
69921016d27SAlgea Cao 	subpixelhorizontalbgr,
70021016d27SAlgea Cao 	subpixelverticalrgb,
70121016d27SAlgea Cao 	subpixelverticalbgr,
70221016d27SAlgea Cao 	subpixelnone,
70321016d27SAlgea Cao };
70421016d27SAlgea Cao 
70521016d27SAlgea Cao #define DRM_COLOR_FORMAT_RGB444         BIT(0)
70621016d27SAlgea Cao #define DRM_COLOR_FORMAT_YCRCB444       BIT(1)
70721016d27SAlgea Cao #define DRM_COLOR_FORMAT_YCRCB422       BIT(2)
70821016d27SAlgea Cao #define DRM_COLOR_FORMAT_YCRCB420       BIT(3)
70921016d27SAlgea Cao 
71021016d27SAlgea Cao /*
71121016d27SAlgea Cao  * Describes a given display (e.g. CRT or flat panel) and its limitations.
71221016d27SAlgea Cao  */
71321016d27SAlgea Cao struct drm_display_info {
71421016d27SAlgea Cao 	char name[32];
71521016d27SAlgea Cao 
71621016d27SAlgea Cao 	/* Physical size */
71721016d27SAlgea Cao 	unsigned int width_mm;
71821016d27SAlgea Cao 	unsigned int height_mm;
71921016d27SAlgea Cao 
72021016d27SAlgea Cao 	/* Clock limits FIXME: storage format */
72121016d27SAlgea Cao 	unsigned int min_vfreq, max_vfreq;
72221016d27SAlgea Cao 	unsigned int min_hfreq, max_hfreq;
72321016d27SAlgea Cao 	unsigned int pixel_clock;
72421016d27SAlgea Cao 	unsigned int bpc;
72521016d27SAlgea Cao 
72621016d27SAlgea Cao 	enum subpixel_order subpixel_order;
72721016d27SAlgea Cao 	u32 color_formats;
72821016d27SAlgea Cao 
72921016d27SAlgea Cao 	const u32 *bus_formats;
73021016d27SAlgea Cao 	unsigned int num_bus_formats;
73121016d27SAlgea Cao 
73221016d27SAlgea Cao 	/**
73321016d27SAlgea Cao 	 * @max_tmds_clock: Maximum TMDS clock rate supported by the
73421016d27SAlgea Cao 	 * sink in kHz. 0 means undefined.
73521016d27SAlgea Cao 	 */
73621016d27SAlgea Cao 	int max_tmds_clock;
73721016d27SAlgea Cao 
73821016d27SAlgea Cao 	/**
73921016d27SAlgea Cao 	 * @dvi_dual: Dual-link DVI sink?
74021016d27SAlgea Cao 	 */
74121016d27SAlgea Cao 	bool dvi_dual;
74221016d27SAlgea Cao 
74321016d27SAlgea Cao 	/* Mask of supported hdmi deep color modes */
74421016d27SAlgea Cao 	u8 edid_hdmi_dc_modes;
74521016d27SAlgea Cao 
74621016d27SAlgea Cao 	u8 cea_rev;
74721016d27SAlgea Cao 
74821016d27SAlgea Cao 	/**
74921016d27SAlgea Cao 	 * @hdmi: advance features of a HDMI sink.
75021016d27SAlgea Cao 	 */
75121016d27SAlgea Cao 	struct drm_hdmi_info hdmi;
75221016d27SAlgea Cao };
75321016d27SAlgea Cao 
75421016d27SAlgea Cao struct edid {
75521016d27SAlgea Cao 	u8 header[8];
75621016d27SAlgea Cao 	/* Vendor & product info */
75721016d27SAlgea Cao 	u8 mfg_id[2];
75821016d27SAlgea Cao 	u8 prod_code[2];
75921016d27SAlgea Cao 	u32 serial; /* FIXME: byte order */
76021016d27SAlgea Cao 	u8 mfg_week;
76121016d27SAlgea Cao 	u8 mfg_year;
76221016d27SAlgea Cao 	/* EDID version */
76321016d27SAlgea Cao 	u8 version;
76421016d27SAlgea Cao 	u8 revision;
76521016d27SAlgea Cao 	/* Display info: */
76621016d27SAlgea Cao 	u8 input;
76721016d27SAlgea Cao 	u8 width_cm;
76821016d27SAlgea Cao 	u8 height_cm;
76921016d27SAlgea Cao 	u8 gamma;
77021016d27SAlgea Cao 	u8 features;
77121016d27SAlgea Cao 	/* Color characteristics */
77221016d27SAlgea Cao 	u8 red_green_lo;
77321016d27SAlgea Cao 	u8 black_white_lo;
77421016d27SAlgea Cao 	u8 red_x;
77521016d27SAlgea Cao 	u8 red_y;
77621016d27SAlgea Cao 	u8 green_x;
77721016d27SAlgea Cao 	u8 green_y;
77821016d27SAlgea Cao 	u8 blue_x;
77921016d27SAlgea Cao 	u8 blue_y;
78021016d27SAlgea Cao 	u8 white_x;
78121016d27SAlgea Cao 	u8 white_y;
78221016d27SAlgea Cao 	/* Est. timings and mfg rsvd timings*/
78321016d27SAlgea Cao 	struct est_timings established_timings;
78421016d27SAlgea Cao 	/* Standard timings 1-8*/
78521016d27SAlgea Cao 	struct std_timing standard_timings[8];
78621016d27SAlgea Cao 	/* Detailing timings 1-4 */
78721016d27SAlgea Cao 	struct detailed_timing detailed_timings[4];
78821016d27SAlgea Cao 	/* Number of 128 byte ext. blocks */
78921016d27SAlgea Cao 	u8 extensions;
79021016d27SAlgea Cao 	/* Checksum */
79121016d27SAlgea Cao 	u8 checksum;
79221016d27SAlgea Cao } __packed;
79321016d27SAlgea Cao 
7948e2bab3fSAlgea Cao enum base_output_format {
7958e2bab3fSAlgea Cao 	DRM_HDMI_OUTPUT_DEFAULT_RGB, /* default RGB */
7968e2bab3fSAlgea Cao 	DRM_HDMI_OUTPUT_YCBCR444, /* YCBCR 444 */
7978e2bab3fSAlgea Cao 	DRM_HDMI_OUTPUT_YCBCR422, /* YCBCR 422 */
7988e2bab3fSAlgea Cao 	DRM_HDMI_OUTPUT_YCBCR420, /* YCBCR 420 */
7998e2bab3fSAlgea Cao 	/* (YCbCr444 > YCbCr422 > YCbCr420 > RGB) */
8008e2bab3fSAlgea Cao 	DRM_HDMI_OUTPUT_YCBCR_HQ,
8018e2bab3fSAlgea Cao 	/* (YCbCr420 > YCbCr422 > YCbCr444 > RGB) */
8028e2bab3fSAlgea Cao 	DRM_HDMI_OUTPUT_YCBCR_LQ,
8038e2bab3fSAlgea Cao 	DRM_HDMI_OUTPUT_INVALID, /* Guess what ? */
8048e2bab3fSAlgea Cao };
8058e2bab3fSAlgea Cao 
8068e2bab3fSAlgea Cao enum  base_output_depth {
8078e2bab3fSAlgea Cao 	AUTOMATIC = 0,
8088e2bab3fSAlgea Cao 	DEPTH_24BIT = 8,
8098e2bab3fSAlgea Cao 	DEPTH_30BIT = 10,
8108e2bab3fSAlgea Cao };
8118e2bab3fSAlgea Cao 
81250a9508eSSandy Huang struct base_bcsh_info {
81350a9508eSSandy Huang 	unsigned short brightness;
81450a9508eSSandy Huang 	unsigned short contrast;
81550a9508eSSandy Huang 	unsigned short saturation;
81650a9508eSSandy Huang 	unsigned short hue;
81750a9508eSSandy Huang };
81850a9508eSSandy Huang 
8198e2bab3fSAlgea Cao struct base_overscan {
8208e2bab3fSAlgea Cao 	unsigned int maxvalue;
8218e2bab3fSAlgea Cao 	unsigned short leftscale;
8228e2bab3fSAlgea Cao 	unsigned short rightscale;
8238e2bab3fSAlgea Cao 	unsigned short topscale;
8248e2bab3fSAlgea Cao 	unsigned short bottomscale;
8258e2bab3fSAlgea Cao };
8268e2bab3fSAlgea Cao 
8278e2bab3fSAlgea Cao struct base_drm_display_mode {
8288e2bab3fSAlgea Cao 	int clock;		/* in kHz */
8298e2bab3fSAlgea Cao 	int hdisplay;
8308e2bab3fSAlgea Cao 	int hsync_start;
8318e2bab3fSAlgea Cao 	int hsync_end;
8328e2bab3fSAlgea Cao 	int htotal;
8338e2bab3fSAlgea Cao 	int vdisplay;
8348e2bab3fSAlgea Cao 	int vsync_start;
8358e2bab3fSAlgea Cao 	int vsync_end;
8368e2bab3fSAlgea Cao 	int vtotal;
8378e2bab3fSAlgea Cao 	int vrefresh;
8388e2bab3fSAlgea Cao 	int vscan;
8398e2bab3fSAlgea Cao 	unsigned int flags;
8408e2bab3fSAlgea Cao 	int picture_aspect_ratio;
8418e2bab3fSAlgea Cao };
8428e2bab3fSAlgea Cao 
8438e2bab3fSAlgea Cao struct base_screen_info {
8448e2bab3fSAlgea Cao 	int type;
8458e2bab3fSAlgea Cao 	struct base_drm_display_mode mode;	/* 52 bytes */
8468e2bab3fSAlgea Cao 	enum base_output_format  format;	/* 4 bytes */
8478e2bab3fSAlgea Cao 	enum base_output_depth depth;		/* 4 bytes */
8488e2bab3fSAlgea Cao 	unsigned int feature;			/* 4 bytes */
8498e2bab3fSAlgea Cao };
8508e2bab3fSAlgea Cao 
8518e2bab3fSAlgea Cao struct base_disp_info {
8528e2bab3fSAlgea Cao 	struct base_screen_info screen_list[5];
8538e2bab3fSAlgea Cao 	struct base_overscan scan;		/* 12 bytes */
8548e2bab3fSAlgea Cao };
8558e2bab3fSAlgea Cao 
85650a9508eSSandy Huang struct base2_cubic_lut_data {
85750a9508eSSandy Huang 	u16 size;
85850a9508eSSandy Huang 	u16 lred[4913];
85950a9508eSSandy Huang 	u16 lgreen[4913];
86050a9508eSSandy Huang 	u16 lblue[4913];
86150a9508eSSandy Huang };
86250a9508eSSandy Huang 
86350a9508eSSandy Huang struct base2_screen_info {
86450a9508eSSandy Huang 	u32 type;
86550a9508eSSandy Huang 	u32 id;
86650a9508eSSandy Huang 	struct base_drm_display_mode resolution;
86750a9508eSSandy Huang 	enum base_output_format  format;
86850a9508eSSandy Huang 	enum base_output_depth depthc;
86950a9508eSSandy Huang 	u32 feature;
87050a9508eSSandy Huang };
87150a9508eSSandy Huang 
87250a9508eSSandy Huang struct base2_gamma_lut_data {
87350a9508eSSandy Huang 	u16 size;
87450a9508eSSandy Huang 	u16 lred[1024];
87550a9508eSSandy Huang 	u16 lgreen[1024];
87650a9508eSSandy Huang 	u16 lblue[1024];
87750a9508eSSandy Huang };
87850a9508eSSandy Huang 
87908c402d4SSandy Huang struct framebuffer_info {
88008c402d4SSandy Huang 	u32 framebuffer_width;
88108c402d4SSandy Huang 	u32 framebuffer_height;
88208c402d4SSandy Huang 	u32 fps;
88308c402d4SSandy Huang };
88408c402d4SSandy Huang 
8856027c871SZhang Yubing struct csc_info {
8866027c871SZhang Yubing 	u16 hue;
8876027c871SZhang Yubing 	u16 saturation;
8886027c871SZhang Yubing 	u16 contrast;
8896027c871SZhang Yubing 	u16 brightness;
8906027c871SZhang Yubing 	u16 r_gain;
8916027c871SZhang Yubing 	u16 g_gain;
8926027c871SZhang Yubing 	u16 b_gain;
8936027c871SZhang Yubing 	u16 r_offset;
8946027c871SZhang Yubing 	u16 g_offset;
8956027c871SZhang Yubing 	u16 b_offset;
8966027c871SZhang Yubing 	u16 csc_enable;
8976027c871SZhang Yubing };
8986027c871SZhang Yubing 
8996027c871SZhang Yubing 
9006027c871SZhang Yubing #define ACM_GAIN_LUT_HY_LENGTH		(9*17)
9016027c871SZhang Yubing #define ACM_GAIN_LUT_HY_TOTAL_LENGTH	(ACM_GAIN_LUT_HY_LENGTH * 3)
9026027c871SZhang Yubing #define ACM_GAIN_LUT_HS_LENGTH		(13*17)
9036027c871SZhang Yubing #define ACM_GAIN_LUT_HS_TOTAL_LENGTH (ACM_GAIN_LUT_HS_LENGTH * 3)
9046027c871SZhang Yubing #define ACM_DELTA_LUT_H_LENGTH		65
9056027c871SZhang Yubing #define ACM_DELTA_LUT_H_TOTAL_LENGTH	(ACM_DELTA_LUT_H_LENGTH * 3)
9066027c871SZhang Yubing 
9076027c871SZhang Yubing struct acm_data {
9086027c871SZhang Yubing 	s16 delta_lut_h[ACM_DELTA_LUT_H_TOTAL_LENGTH];
9096027c871SZhang Yubing 	s16 gain_lut_hy[ACM_GAIN_LUT_HY_TOTAL_LENGTH];
9106027c871SZhang Yubing 	s16 gain_lut_hs[ACM_GAIN_LUT_HS_TOTAL_LENGTH];
9116027c871SZhang Yubing 	u16 y_gain;
9126027c871SZhang Yubing 	u16 h_gain;
9136027c871SZhang Yubing 	u16 s_gain;
9146027c871SZhang Yubing 	u16 acm_enable;
9156027c871SZhang Yubing };
9166027c871SZhang Yubing 
91750a9508eSSandy Huang struct base2_disp_info {
91850a9508eSSandy Huang 	char disp_head_flag[6];
91950a9508eSSandy Huang 	struct base2_screen_info screen_info[4];
92050a9508eSSandy Huang 	struct base_bcsh_info bcsh_info;
92150a9508eSSandy Huang 	struct base_overscan overscan_info;
92250a9508eSSandy Huang 	struct base2_gamma_lut_data gamma_lut_data;
92350a9508eSSandy Huang 	struct base2_cubic_lut_data cubic_lut_data;
92408c402d4SSandy Huang 	struct framebuffer_info framebuffer_info;
9256027c871SZhang Yubing 	u32 cacm_header;
9266027c871SZhang Yubing 	u32 reserved[243];
92750a9508eSSandy Huang 	u32 crc;
9286027c871SZhang Yubing 	/* baseparameter version 3.0 add */
9296027c871SZhang Yubing 	struct csc_info csc_info;
9306027c871SZhang Yubing 	struct acm_data acm_data;
9316027c871SZhang Yubing 	u8 resv2[10*1024]; /* */
9326027c871SZhang Yubing 	u32 crc2;
9336027c871SZhang Yubing 	/* baseparameter version 3.0 add */
93450a9508eSSandy Huang };
93550a9508eSSandy Huang 
93650a9508eSSandy Huang struct base2_disp_header {
93750a9508eSSandy Huang 	u32 connector_type;
93850a9508eSSandy Huang 	u32 connector_id;
93950a9508eSSandy Huang 	u32 offset;
94050a9508eSSandy Huang };
94150a9508eSSandy Huang 
94250a9508eSSandy Huang struct base2_info {
94350a9508eSSandy Huang 	char head_flag[4];
94450a9508eSSandy Huang 	u16 major_version;
94550a9508eSSandy Huang 	u16 minor_version;
94650a9508eSSandy Huang 	struct base2_disp_header disp_header[8];
94750a9508eSSandy Huang 	struct base2_disp_info disp_info[8];
94850a9508eSSandy Huang };
94950a9508eSSandy Huang 
950d46b5f7dSTom Wai-Hong Tam /**
951d46b5f7dSTom Wai-Hong Tam  * Print the EDID info.
952d46b5f7dSTom Wai-Hong Tam  *
953d46b5f7dSTom Wai-Hong Tam  * @param edid_info	The EDID info to be printed
954d46b5f7dSTom Wai-Hong Tam  */
955d46b5f7dSTom Wai-Hong Tam void edid_print_info(struct edid1_info *edid_info);
956d46b5f7dSTom Wai-Hong Tam 
957d46b5f7dSTom Wai-Hong Tam /**
958d46b5f7dSTom Wai-Hong Tam  * Check the EDID info.
959d46b5f7dSTom Wai-Hong Tam  *
960d46b5f7dSTom Wai-Hong Tam  * @param info  The EDID info to be checked
961d46b5f7dSTom Wai-Hong Tam  * @return 0 on valid, or -1 on invalid
962d46b5f7dSTom Wai-Hong Tam  */
963d46b5f7dSTom Wai-Hong Tam int edid_check_info(struct edid1_info *info);
964d46b5f7dSTom Wai-Hong Tam 
965d46b5f7dSTom Wai-Hong Tam /**
966e745d064SHans de Goede  * Check checksum of a 128 bytes EDID data block
967e745d064SHans de Goede  *
968e745d064SHans de Goede  * @param edid_block	EDID block data
969e745d064SHans de Goede  *
970e745d064SHans de Goede  * @return 0 on success, or a negative errno on error
971e745d064SHans de Goede  */
972e745d064SHans de Goede int edid_check_checksum(u8 *edid_block);
973e745d064SHans de Goede 
974e745d064SHans de Goede /**
975d46b5f7dSTom Wai-Hong Tam  * Get the horizontal and vertical rate ranges of the monitor.
976d46b5f7dSTom Wai-Hong Tam  *
977d46b5f7dSTom Wai-Hong Tam  * @param edid	The EDID info
978d46b5f7dSTom Wai-Hong Tam  * @param hmin	Returns the minimum horizontal rate
97921016d27SAlgea Cao  * @param hmax	Returns the maximum horizontal rate
980d46b5f7dSTom Wai-Hong Tam  * @param vmin	Returns the minimum vertical rate
98121016d27SAlgea Cao  * @param vmax	Returns the maximum vertical rate
982d46b5f7dSTom Wai-Hong Tam  * @return 0 on success, or -1 on error
983d46b5f7dSTom Wai-Hong Tam  */
984d46b5f7dSTom Wai-Hong Tam int edid_get_ranges(struct edid1_info *edid, unsigned int *hmin,
985d46b5f7dSTom Wai-Hong Tam 		    unsigned int *hmax, unsigned int *vmin,
986d46b5f7dSTom Wai-Hong Tam 		    unsigned int *vmax);
987d46b5f7dSTom Wai-Hong Tam 
988b9e63a96SMark Yao struct drm_display_mode;
98900cf1167SSimon Glass struct display_timing;
99000cf1167SSimon Glass 
99121016d27SAlgea Cao struct hdmi_edid_data {
99221016d27SAlgea Cao 	struct drm_display_mode *preferred_mode;
99321016d27SAlgea Cao 	int modes;
99421016d27SAlgea Cao 	struct drm_display_mode *mode_buf;
99521016d27SAlgea Cao 	struct drm_display_info display_info;
99621016d27SAlgea Cao };
99721016d27SAlgea Cao 
9988e2bab3fSAlgea Cao struct ddc_adapter {
9998e2bab3fSAlgea Cao 	int (*ddc_xfer)(struct ddc_adapter *adap, struct i2c_msg *msgs,
10008e2bab3fSAlgea Cao 			int num);
10013186eac9SShunqing Chen 	struct udevice *i2c_bus;
10023186eac9SShunqing Chen 	struct dm_i2c_ops *ops;
10038e2bab3fSAlgea Cao };
10048e2bab3fSAlgea Cao 
100500cf1167SSimon Glass /**
100600cf1167SSimon Glass  * edid_get_timing() - Get basic digital display parameters
100700cf1167SSimon Glass  *
100800cf1167SSimon Glass  * @param buf		Buffer containing EDID data
100900cf1167SSimon Glass  * @param buf_size	Size of buffer in bytes
101000cf1167SSimon Glass  * @param timing	Place to put preferring timing information
101100cf1167SSimon Glass  * @param panel_bits_per_colourp	Place to put the number of bits per
101200cf1167SSimon Glass  *			colour supported by the panel. This will be set to
101300cf1167SSimon Glass  *			-1 if not available
101400cf1167SSimon Glass  * @return 0 if timings are OK, -ve on error
101500cf1167SSimon Glass  */
101600cf1167SSimon Glass int edid_get_timing(u8 *buf, int buf_size, struct display_timing *timing,
101700cf1167SSimon Glass 		    int *panel_bits_per_colourp);
1018b9e63a96SMark Yao int edid_get_drm_mode(u8 *buf, int buf_size, struct drm_display_mode *mode,
1019b9e63a96SMark Yao 		      int *panel_bits_per_colourp);
102021016d27SAlgea Cao int drm_add_edid_modes(struct hdmi_edid_data *data, u8 *edid);
10212d575f5bSChen Shunqing void drm_add_hdmi_modes(struct hdmi_edid_data *data,
10222d575f5bSChen Shunqing 			const struct drm_display_mode *mode);
102321016d27SAlgea Cao bool drm_detect_hdmi_monitor(struct edid *edid);
102421016d27SAlgea Cao bool drm_detect_monitor_audio(struct edid *edid);
10258e2bab3fSAlgea Cao int do_cea_modes(struct hdmi_edid_data *data, const u8 *db, u8 len);
1026*9c170041SAlgea Cao u8 *drm_do_get_edid(struct ddc_adapter *adap);
1027b5016cf2SAlgea Cao enum hdmi_quantization_range
1028b5016cf2SAlgea Cao drm_default_rgb_quant_range(struct drm_display_mode *mode);
10298e2bab3fSAlgea Cao u8 drm_scdc_readb(struct ddc_adapter *adap, u8 offset,
10308e2bab3fSAlgea Cao 		  u8 *value);
10318e2bab3fSAlgea Cao u8 drm_scdc_writeb(struct ddc_adapter *adap, u8 offset,
10328e2bab3fSAlgea Cao 		   u8 value);
103300997ff1SAlgea Cao void drm_mode_sort(struct hdmi_edid_data *edid_data);
103400997ff1SAlgea Cao int drm_mode_prune_invalid(struct hdmi_edid_data *edid_data);
103500997ff1SAlgea Cao void drm_rk_filter_whitelist(struct hdmi_edid_data *edid_data);
103600997ff1SAlgea Cao void drm_rk_select_mode(struct hdmi_edid_data *edid_data,
103700997ff1SAlgea Cao 			struct base_screen_info *screen_info);
103800cf1167SSimon Glass 
1039d46b5f7dSTom Wai-Hong Tam #endif /* __EDID_H_ */
1040