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