xref: /openbmc/linux/drivers/video/fbdev/edid.h (revision e5451c8f8330e03ad3cfa16048b4daf961af434f)
1*f7018c21STomi Valkeinen /*
2*f7018c21STomi Valkeinen  * drivers/video/edid.h - EDID/DDC Header
3*f7018c21STomi Valkeinen  *
4*f7018c21STomi Valkeinen  * Based on:
5*f7018c21STomi Valkeinen  *   1. XFree86 4.3.0, edid.h
6*f7018c21STomi Valkeinen  *      Copyright 1998 by Egbert Eich <Egbert.Eich@Physik.TU-Darmstadt.DE>
7*f7018c21STomi Valkeinen  *
8*f7018c21STomi Valkeinen  *   2. John Fremlin <vii@users.sourceforge.net> and
9*f7018c21STomi Valkeinen  *      Ani Joshi <ajoshi@unixbox.com>
10*f7018c21STomi Valkeinen  *
11*f7018c21STomi Valkeinen  * DDC is a Trademark of VESA (Video Electronics Standard Association).
12*f7018c21STomi Valkeinen  *
13*f7018c21STomi Valkeinen  * This file is subject to the terms and conditions of the GNU General Public
14*f7018c21STomi Valkeinen  * License.  See the file COPYING in the main directory of this archive
15*f7018c21STomi Valkeinen  * for more details.
16*f7018c21STomi Valkeinen */
17*f7018c21STomi Valkeinen 
18*f7018c21STomi Valkeinen #ifndef __EDID_H__
19*f7018c21STomi Valkeinen #define __EDID_H__
20*f7018c21STomi Valkeinen 
21*f7018c21STomi Valkeinen #define EDID_LENGTH				0x80
22*f7018c21STomi Valkeinen #define EDID_HEADER				0x00
23*f7018c21STomi Valkeinen #define EDID_HEADER_END				0x07
24*f7018c21STomi Valkeinen 
25*f7018c21STomi Valkeinen #define ID_MANUFACTURER_NAME			0x08
26*f7018c21STomi Valkeinen #define ID_MANUFACTURER_NAME_END		0x09
27*f7018c21STomi Valkeinen #define ID_MODEL				0x0a
28*f7018c21STomi Valkeinen 
29*f7018c21STomi Valkeinen #define ID_SERIAL_NUMBER			0x0c
30*f7018c21STomi Valkeinen 
31*f7018c21STomi Valkeinen #define MANUFACTURE_WEEK			0x10
32*f7018c21STomi Valkeinen #define MANUFACTURE_YEAR			0x11
33*f7018c21STomi Valkeinen 
34*f7018c21STomi Valkeinen #define EDID_STRUCT_VERSION			0x12
35*f7018c21STomi Valkeinen #define EDID_STRUCT_REVISION			0x13
36*f7018c21STomi Valkeinen 
37*f7018c21STomi Valkeinen #define EDID_STRUCT_DISPLAY                     0x14
38*f7018c21STomi Valkeinen 
39*f7018c21STomi Valkeinen #define DPMS_FLAGS				0x18
40*f7018c21STomi Valkeinen #define ESTABLISHED_TIMING_1			0x23
41*f7018c21STomi Valkeinen #define ESTABLISHED_TIMING_2			0x24
42*f7018c21STomi Valkeinen #define MANUFACTURERS_TIMINGS			0x25
43*f7018c21STomi Valkeinen 
44*f7018c21STomi Valkeinen /* standard timings supported */
45*f7018c21STomi Valkeinen #define STD_TIMING                              8
46*f7018c21STomi Valkeinen #define STD_TIMING_DESCRIPTION_SIZE             2
47*f7018c21STomi Valkeinen #define STD_TIMING_DESCRIPTIONS_START           0x26
48*f7018c21STomi Valkeinen 
49*f7018c21STomi Valkeinen #define DETAILED_TIMING_DESCRIPTIONS_START	0x36
50*f7018c21STomi Valkeinen #define DETAILED_TIMING_DESCRIPTION_SIZE	18
51*f7018c21STomi Valkeinen #define NO_DETAILED_TIMING_DESCRIPTIONS		4
52*f7018c21STomi Valkeinen 
53*f7018c21STomi Valkeinen #define DETAILED_TIMING_DESCRIPTION_1		0x36
54*f7018c21STomi Valkeinen #define DETAILED_TIMING_DESCRIPTION_2		0x48
55*f7018c21STomi Valkeinen #define DETAILED_TIMING_DESCRIPTION_3		0x5a
56*f7018c21STomi Valkeinen #define DETAILED_TIMING_DESCRIPTION_4		0x6c
57*f7018c21STomi Valkeinen 
58*f7018c21STomi Valkeinen #define DESCRIPTOR_DATA				5
59*f7018c21STomi Valkeinen 
60*f7018c21STomi Valkeinen #define UPPER_NIBBLE( x ) \
61*f7018c21STomi Valkeinen         (((128|64|32|16) & (x)) >> 4)
62*f7018c21STomi Valkeinen 
63*f7018c21STomi Valkeinen #define LOWER_NIBBLE( x ) \
64*f7018c21STomi Valkeinen         ((1|2|4|8) & (x))
65*f7018c21STomi Valkeinen 
66*f7018c21STomi Valkeinen #define COMBINE_HI_8LO( hi, lo ) \
67*f7018c21STomi Valkeinen         ( (((unsigned)hi) << 8) | (unsigned)lo )
68*f7018c21STomi Valkeinen 
69*f7018c21STomi Valkeinen #define COMBINE_HI_4LO( hi, lo ) \
70*f7018c21STomi Valkeinen         ( (((unsigned)hi) << 4) | (unsigned)lo )
71*f7018c21STomi Valkeinen 
72*f7018c21STomi Valkeinen #define PIXEL_CLOCK_LO     (unsigned)block[ 0 ]
73*f7018c21STomi Valkeinen #define PIXEL_CLOCK_HI     (unsigned)block[ 1 ]
74*f7018c21STomi Valkeinen #define PIXEL_CLOCK	   (COMBINE_HI_8LO( PIXEL_CLOCK_HI,PIXEL_CLOCK_LO )*10000)
75*f7018c21STomi Valkeinen #define H_ACTIVE_LO        (unsigned)block[ 2 ]
76*f7018c21STomi Valkeinen #define H_BLANKING_LO      (unsigned)block[ 3 ]
77*f7018c21STomi Valkeinen #define H_ACTIVE_HI        UPPER_NIBBLE( (unsigned)block[ 4 ] )
78*f7018c21STomi Valkeinen #define H_ACTIVE           COMBINE_HI_8LO( H_ACTIVE_HI, H_ACTIVE_LO )
79*f7018c21STomi Valkeinen #define H_BLANKING_HI      LOWER_NIBBLE( (unsigned)block[ 4 ] )
80*f7018c21STomi Valkeinen #define H_BLANKING         COMBINE_HI_8LO( H_BLANKING_HI, H_BLANKING_LO )
81*f7018c21STomi Valkeinen 
82*f7018c21STomi Valkeinen #define V_ACTIVE_LO        (unsigned)block[ 5 ]
83*f7018c21STomi Valkeinen #define V_BLANKING_LO      (unsigned)block[ 6 ]
84*f7018c21STomi Valkeinen #define V_ACTIVE_HI        UPPER_NIBBLE( (unsigned)block[ 7 ] )
85*f7018c21STomi Valkeinen #define V_ACTIVE           COMBINE_HI_8LO( V_ACTIVE_HI, V_ACTIVE_LO )
86*f7018c21STomi Valkeinen #define V_BLANKING_HI      LOWER_NIBBLE( (unsigned)block[ 7 ] )
87*f7018c21STomi Valkeinen #define V_BLANKING         COMBINE_HI_8LO( V_BLANKING_HI, V_BLANKING_LO )
88*f7018c21STomi Valkeinen 
89*f7018c21STomi Valkeinen #define H_SYNC_OFFSET_LO   (unsigned)block[ 8 ]
90*f7018c21STomi Valkeinen #define H_SYNC_WIDTH_LO    (unsigned)block[ 9 ]
91*f7018c21STomi Valkeinen 
92*f7018c21STomi Valkeinen #define V_SYNC_OFFSET_LO   UPPER_NIBBLE( (unsigned)block[ 10 ] )
93*f7018c21STomi Valkeinen #define V_SYNC_WIDTH_LO    LOWER_NIBBLE( (unsigned)block[ 10 ] )
94*f7018c21STomi Valkeinen 
95*f7018c21STomi Valkeinen #define V_SYNC_WIDTH_HI    ((unsigned)block[ 11 ] & (1|2))
96*f7018c21STomi Valkeinen #define V_SYNC_OFFSET_HI   (((unsigned)block[ 11 ] & (4|8)) >> 2)
97*f7018c21STomi Valkeinen 
98*f7018c21STomi Valkeinen #define H_SYNC_WIDTH_HI    (((unsigned)block[ 11 ] & (16|32)) >> 4)
99*f7018c21STomi Valkeinen #define H_SYNC_OFFSET_HI   (((unsigned)block[ 11 ] & (64|128)) >> 6)
100*f7018c21STomi Valkeinen 
101*f7018c21STomi Valkeinen #define V_SYNC_WIDTH       COMBINE_HI_4LO( V_SYNC_WIDTH_HI, V_SYNC_WIDTH_LO )
102*f7018c21STomi Valkeinen #define V_SYNC_OFFSET      COMBINE_HI_4LO( V_SYNC_OFFSET_HI, V_SYNC_OFFSET_LO )
103*f7018c21STomi Valkeinen 
104*f7018c21STomi Valkeinen #define H_SYNC_WIDTH       COMBINE_HI_8LO( H_SYNC_WIDTH_HI, H_SYNC_WIDTH_LO )
105*f7018c21STomi Valkeinen #define H_SYNC_OFFSET      COMBINE_HI_8LO( H_SYNC_OFFSET_HI, H_SYNC_OFFSET_LO )
106*f7018c21STomi Valkeinen 
107*f7018c21STomi Valkeinen #define H_SIZE_LO          (unsigned)block[ 12 ]
108*f7018c21STomi Valkeinen #define V_SIZE_LO          (unsigned)block[ 13 ]
109*f7018c21STomi Valkeinen 
110*f7018c21STomi Valkeinen #define H_SIZE_HI          UPPER_NIBBLE( (unsigned)block[ 14 ] )
111*f7018c21STomi Valkeinen #define V_SIZE_HI          LOWER_NIBBLE( (unsigned)block[ 14 ] )
112*f7018c21STomi Valkeinen 
113*f7018c21STomi Valkeinen #define H_SIZE             COMBINE_HI_8LO( H_SIZE_HI, H_SIZE_LO )
114*f7018c21STomi Valkeinen #define V_SIZE             COMBINE_HI_8LO( V_SIZE_HI, V_SIZE_LO )
115*f7018c21STomi Valkeinen 
116*f7018c21STomi Valkeinen #define H_BORDER           (unsigned)block[ 15 ]
117*f7018c21STomi Valkeinen #define V_BORDER           (unsigned)block[ 16 ]
118*f7018c21STomi Valkeinen 
119*f7018c21STomi Valkeinen #define FLAGS              (unsigned)block[ 17 ]
120*f7018c21STomi Valkeinen 
121*f7018c21STomi Valkeinen #define INTERLACED         (FLAGS&128)
122*f7018c21STomi Valkeinen #define SYNC_TYPE          (FLAGS&3<<3)	/* bits 4,3 */
123*f7018c21STomi Valkeinen #define SYNC_SEPARATE      (3<<3)
124*f7018c21STomi Valkeinen #define HSYNC_POSITIVE     (FLAGS & 4)
125*f7018c21STomi Valkeinen #define VSYNC_POSITIVE     (FLAGS & 2)
126*f7018c21STomi Valkeinen 
127*f7018c21STomi Valkeinen #define V_MIN_RATE              block[ 5 ]
128*f7018c21STomi Valkeinen #define V_MAX_RATE              block[ 6 ]
129*f7018c21STomi Valkeinen #define H_MIN_RATE              block[ 7 ]
130*f7018c21STomi Valkeinen #define H_MAX_RATE              block[ 8 ]
131*f7018c21STomi Valkeinen #define MAX_PIXEL_CLOCK         (((int)block[ 9 ]) * 10)
132*f7018c21STomi Valkeinen #define GTF_SUPPORT		block[10]
133*f7018c21STomi Valkeinen 
134*f7018c21STomi Valkeinen #define DPMS_ACTIVE_OFF		(1 << 5)
135*f7018c21STomi Valkeinen #define DPMS_SUSPEND		(1 << 6)
136*f7018c21STomi Valkeinen #define DPMS_STANDBY		(1 << 7)
137*f7018c21STomi Valkeinen 
138*f7018c21STomi Valkeinen #endif /* __EDID_H__ */
139