去年对EDID做了一个解析,下面是学习EDID过程中整理的资料。
一、EDID简介
EDID: Extended Display Identification Data (外部显示设备标识数据)----指DDC通讯中传输的显示设备数据。
Q1:EDID是什么?
A1:EDID的全称是Extended Display Identification Data(扩展显示标识数据),VGA、DVI的EDID由主块128字节组成,HDMI的EDID增加扩展块(128字节),扩展块的内容主要是和音频属性相关的,DVI和VGA没有音频,HDMI自带音频,扩展块数据规范按照CEA-861x标准定义,未来可能增加到512或256的整数倍。
其中包含有关显示器及其性能的参数,包括供应商信息、最大图像大小、颜色设置、厂商预设置、频率范围的限制以及显示器名和序列号的字符串等等。形象地说,EDID就是显示器的身份证、户口本、技能证书等证件的集合,目的就是告诉别人我是谁,我从哪来,我能干什么。
Q2:为什么要使用EDID?
A2:为了能让PC或其他的图像输出设备更好的识别显示器属性
EDID并非古而有之,在古老的CRT时期是没有EDID这个概念的,那为什么后来会有呢?因为随着显示设备的发展,显示器的种类越来越多,模拟的、数字的、普屏的、宽屏的、17寸、19寸、22寸……这让PC傻了眼,分辨率和时序的种类太多了,而每种显示器又不可能支持所有的分辨率,那怎么知道该给显示器一个什么样的分辨率啊?显示出的效果是最佳效果吗?不仅如此,随便输出一个分辨率还有损坏显示器硬件的可能,这可太危险了。于是,EDID临危受命,担当起显示器和PC之前的传话筒。“PC你好,我是A显示器,我能显示N种分辨率,最佳分辨率是XXX”。“显示器你好,收到你的信息,现在就按最佳分辨率给你输出”。这下大家明白了吧,EDID就是为了能让PC或其他的图像输出设备更好的识别显示器属性而出现的。
Q3:经常听到有同志一会说“EDID信息”,一会说“DDC信息”。那么哪种说法更准确?EDID和DDC的关系又是什么?
A3: DDC的全称是Display Data Channel(显示数据通道),顾名思义,它是一个通道。我们可以说DDC是用来传送EDID信息的,也可以说EDID信息是通过DDC传送的,所以,“DDC信息”的说法并不准确。
Q4:每个显示器只有一个EDID吗?
A4:不一定。
现在的显示器功能很强大,通常都提供多种视频接口,常见的有DVI、VGA、HDMI、Display Port等,由于每种接口的特性和带宽不同,使得不同接口的EDID也不同。使用哪个接口,PC读到的就是哪个接口的EDID。我们的设备主要使用DVI、VGA、HDMI几种接口。由于VIDEO接口的几种制式如PAL、NTSC等,其分辨率场频都是固定的,没有使用EDID的必要,故不在讨论之列。
Q5:EDID对我们到底有什么用?
A5:要回答这个问题,首先要弄清我们设备的应用场景,请看下图
这是一个典型的应用场景,PC将视频信号发送到我们的设备上,经过一系列的传输或切换,设备将视频信号发送到显示器或投影机上,也就是说,我们的设备位于PC和显示器之间。首先,在输入端,设备需要让PC知道自己是能够输入视频信号的,换句话说,设备要“欺骗”PC,让PC认为自己是一台显示器。如果不这样的话,PC可能会拒绝输出任何视频信号的(VGA接口不需要EDID也能输出)。除此之外,设备还要告诉PC自己支持的显示时序。而在输出端,当设备需要自建输出时序(如大屏控制器的输出卡)而不是简单的复制输入时序(如各种矩阵设备)的时候,就需要知道显示器支持的显示时序,从而让自己输出的信号能在显示器上正常显示。在这些地方,EDID就发挥作用了。在输入端PC通过读取设备上的EDID来获悉设备支持的显示时序,而同样,在输出端设备需要读取显示器的EDID来确定自己的输出时序。
二、EDID主块详解
1. EDID主块结构
2. Header:
在EDID的开头八个字节为EDID的开始标志,简称头,固定为:
00H | 01H | 02H | 03H | 04H | 05H | 06H | 07H |
00 | FF | FF | FF | FF | FF | FF | 00 |
3. Vendor / Product Identification
这十个字节表示产品ID和制造商信息。详细如下:
08H | 09H | 0AH | 0BH | 0CH | 0DH | 0EH | 0FH | 10H | 11H |
制造商名称 | 产品代码 | 产品序列号 | 制造周 | 制造年份 |
制造商名称:3个字母组成,基于压缩的ASCII码见下表,例如“00001=A”… …”11010=Z”。这两字节排列如下:
地址 | 位 | |||||||
bit1 | bit2 | bit3 | bit4 | bit5 | bit6 | bit7 | bit8 | |
08H | - | (4 | 3 | 2 | 1 | 0) | (4 | 3 |
字符1 | 字符2 | |||||||
09H | 2 | 1 | 0) | (4 | 3 | 2 | 1 | 0) |
字符2 | 字符3 |
A | B | C | D | E | F | G | H | I | J | K | L | M |
00001 | 00010 | 00011 | 00100 | 00101 | 00110 | 00111 | 01000 | 01001 | 01010 | 01011 | 01100 | 01101 |
N | O | P | Q | R | S | T | U | V | W | X | Y | Z |
01110 | 01111 | 10000 | 10001 | 10010 | 10011 | 10100 | 10101 | 10110 | 10111 | 11000 | 11001 | 11010 |
产品代码:固定为4位16进制数,即两个字节,为客户提供,直接填写。
产品序列号:即产品的流水号(数值型),直接转成16进制或以ASCII格式转换。序列号也可用字符型,在后面DTD部分定义。
生产周:即在当年中的生产周,范围1~52,注意0为无效值。
生产年份:规定1990开始计算,即1990年为0,然后递增计算。
4. EDID Structure Version / Revision
字节 | EDID版本及修改 | 备注 |
1(12H) | 版本号 | |
1(13H) | 修改号 |
5. Basic Display Parameters / Features
5 | 字节 | 基本的显示参数/特征 | |
14H | 1 | 视频信号定义 | 见下表 |
15H | 1 | 最大水平图像尺寸 | cm |
16H | 1 | 最大垂直图像尺寸 | cm |
17H | 1 | 显示传输特性(Gamma) | (gamma x 100)-100,[1.00→3.55] |
18H | 1 | 电源管理标准(DPMS) | 见下表 |
字节 | 位 | 类型 | 详细描述 |
14H | 7 | 模拟/数字信号 | 模拟= 0,数字= 1 |
如bit7=0,即模拟信号,bit6~0定义如下: | |||
6 | 信号电平[6:5] | 参阅下列定义。 Bit6 Bit5 Operation 0 0 0.700,0.300(1.000Vp-p) 0 1 0.714,0.286(1.000Vp-p) 1 0 1.000,0.400(1.400Vp-p) 1 1 0.700,0.000(0.700Vp-p) | |
5 | |||
4 | setup | 一般为0 | |
3 | 同步输入支持[3] | 如果设置1, 支持同步分离信号; | |
2 | 同步输入支持[2] | 如果设置1, 支持同步复合信号(在水平同步行信号上); | |
1 | 同步输入支持[1] | 如果设置1, 支持同步SOG信号; | |
0 | 同步输入支持[0] | 如果设置1, 场同步扫描起点,脉冲须在复合同步信号或同步SOG信号被使用; | |
如bit7=1,即模拟信号,bit6~0定义如下: | |||
6-1 | 保留 | ||
0 | DFP 1.x | If set = 1, Interface is signal compatible with VESA DFP 1.x TMDS CRGB, 1 pixel / clock, up to 8 bits / color MSB aligned,DE active high |
字节 | 位 | 特点支持 | 详细描述 |
18H | 7 | Standby待机 | 是否支持Standby功能 |
6 | Suspend挂起 | 是否支持Suspend功能 | |
5 | Active Off/Very Low Power | 是否支持Off Mode功能 | |
[4:3] | 显示类型[4:3] | Bit4 Bit3 解释 0 0 黑白/灰度显示 0 1 RGB颜色显示 1 0 非RGB多彩色显示,如RGY 1 1 没有定义 | |
2 | 标准默认颜色空间sRGB | 如果置1,显示将使用默认的颜色空间sRGB作为基色 | |
1 | 推荐分辨率模式 | 如果置1,推荐分辨率为第一个详细描述的时序(DTD) | |
0 | 支持GTF | 如果置1,支持GTF标准分辨率 |
6. Color Characteristics
字节 | 颜色特征 | 基于CIE出版15.2测定空间 |
19H | Red / Green Low Bits 红绿场xy坐标低2位值 | Rx1 Rx0 Ry1 Ry0 Gx1 Gx0 Gy1 Gy0 |
1AH | Blue / White Low Bits 蓝白场xy坐标低2位值 | Bx1 Bx0 By1 By0 Wx1 Wx0 Wy1 Wy0 |
1BH | Red_x红场画面x坐标 | Red_x bits 9 →2 |
1CH | Red_y红场画面y坐标 | Red_y bits 9 →2 |
1DH | Green_x绿场画面x坐标 | Green_x bits 9 →2 |
1EH | Green_y绿场画面y坐标 | Green_y bits 9 →2 |
1FH | Blue_x蓝场画面x坐标 | Blue_x bits 9 →2 |
20H | Blue_y蓝场画面y坐标 | Blue_y bits 9 →2 |
21H | White_x白场画面x坐标 | White_x bits 9 →2 |
22H | White_y白场画面y坐标 | White_y bits 9 →2 |
7. Established Timings
提供一些基本固定的VESA, Apple, Mac, IBM VGA等输出的Timing
字节 | 位 | 描述 | 信源 |
23H | 7 | 720 x 400 @ 70Hz | IBM, VGA |
6 | 720 x 400 @ 88Hz | IBM, XGA2 | |
5 | 640 x 480 @ 60Hz | IBM, VGA | |
4 | 640 x 480 @ 67Hz | Apple, Mac II | |
3 | 640 x 480 @ 72Hz | VESA | |
2 | 640 x 480 @ 75Hz | VESA | |
1 | 800 x 600 @ 56Hz | VESA | |
0 | 800 x 600 @ 60Hz | VESA | |
24H | 7 | 800 x 600 @ 72Hz | VESA |
6 | 800 x 600 @ 75Hz | VESA | |
5 | 832 x 624 @ 75H z | Apple, Mac II | |
4 | 1024 x 768 @ 87Hz(I) | IBM | |
3 | 1024 x 768 @ 60Hz | VESA | |
2 | 1024 x 768 @ 70Hz | VESA | |
1 | 1024 x 768 @ 75Hz | VESA | |
0 | 1280 x 1024 @ 75Hz | VESA | |
25H | 7 | 1152 x 870 @ 75Hz | Apple, Mac II |
6-0 | 保留 |
8. Standard Timing Identification
这16个字节提供最多8种分辨率的识别,每一种分辨率都是由2个字节的模式格式和刷新率得到的。这些分辨率都没有包含Established Timings中。备注:这2个字节的识别码都是由VESA标准分辨率来定义的,它们都是VESA分辨率的一部分,未使用的字节应该设为01H. 详细设定见表12。
字节 | 位 | 描述 | 源 |
标准分辨率定义1 | 注释 | ||
26H | (水平活动像素 /8)-31 | 一个字节能够的水平活动像范围是 256-2以 8 个像素为增加 | |
27H | 7,6 5-0 | 画面比 Bit7 Bit6 生效 0 0 1 : 1 画面比 0 1 4 : 3 画面比 1 0 5 : 4 画面比 1 1 16 :9 画面 比 刷新率( Hz ) -60 | 画面比 = 水平像素 / 垂直活动 范围是 60-123Hz |
28H-29H | 同上 | 同上 | |
2AH-2BH | 同上 | 同上 | |
2CH-2DH | 同上 | 同上 | |
2EH-2FH | 同上 | 同上 | |
30H-21H | 同上 | 同上 | |
32H-33H | 同上 | 同上 | |
34H-35H | 同上 | 同上 |
9. Detailed Timing Descriptions(DTD)
共72个字节分为四个详细时序描述块(DTD),每部分18个字节,故最多可以对四个TIMING进行详细描述。
Detailed Timing Descriptions(DTD)还可以用来描述显示器的其他特性,如机型名、最大频率范围,字符型序列号SN,字符串描述信息等,如下结构:
10. Extension Flag
扩展标志:除主块128字节外,如果有扩展块则该字节置1,VGA和DVI的值为0,HDMI的值为1
11. Checksum
校验和:使前127字节加上此字节等于0。
三、EDID扩展块(CEA-861D)详解
1. CEA-861D(HDMI)结构
地址 (+80H) | 值 | 描述 | 格式 |
00H | 02H | Tag(02H) | |
01H | 03H | 版本号 | |
02H | DTD开始地址,暂用d表示 | d为扩展块中详细时序描述(DTD)开始地址 | |
03H | Native DTD数量及YCbCr444/422,过扫描支持设置 | Bit7:是否支持过扫描 Bit6:是否支持basic audio Bit5:是否支持YCbCr 4:4:4 Bit4:是否支持YCbCr4:2:2 低4bits:Native DTD个数 | |
<d | 各功能块参数设置 | 各功能块包括: Video Data Block Audio Data Block Speaker Allocation Data Block Vendor Specific Data Block 等等.... 大部分功能块长度可变 | |
d | DTD开始地址,根据剩下空间情况,可定义n个DTD(每个18字节),所以DTD占用空间为n*18 | Detailed Timing Descriptor(DTD 详细时序描述),每一个DTD包括18字节,具体结构EDID主块中已有定义。 | |
d+(n*18) | 00H | 剩下的保留字节(Padding) | 00H填充 |
7FH | Checksum | 使前127字节加上此字节等于0 |
2. Tag
固定数值02H,EDID标准分配给CEA-861x标准的扩展标识。
3. Revision
CEA扩展块版本号,目前使用03版本
4. 数字信号特性
此字节各位定义如下:
Bit7:是否支持过扫描
Bit6:是否支持basic audio
Bit5:是否支持YCbCr 4:4:4
Bit4:是否支持YCbCr4:2:2
低4bits:Native DTD个数
Data
5. Data Blocks(各功能块参数设置)
各Data Block结构如下:
注:L表是length,即长度,表中有说明
其中各Data Block的Tag Code值定义如下:
1.Video Data Block
根据Data Block结构,首字节的bit7~5为Video Data Block = 2,bit4~0为Video Data Block长度,后面跟的字节为多个CEA short Video Descriptor,结构如下:
Video Identification Code见CEA-861D标准定义,如下:
2.Audio Data Block
根据Data Block结构,首字节的bit7~5为Audio Data Block = 1,bit4~0为Video Data Block长度,后面跟的字节为1个或多个CEA short Audio Descriptor,每个CEA short Audio Descripto由三个字节组级,分为LPCM,AC3,MPEG2等各种Audio Format Code, Audio Format Code及CEA short Audio DZescriptor结构如下:
3.Speaker Allocation Data Block
根据Data Block结构,首字节的bit7~5为Speaker Allocation Data Block = 4,bit4~0为Speaker Allocation Data Block长度(固定为3),后面跟的3字节,结构如下:
注:F为前置,L为左置,R为右置,C为中置,Fxx=0表示预留位
4.Vendor Specific Data Block(VSDB)
厂商定义块,根据Data Block结构,首字节的bit7~5为Vendor Specific Data Block= 3,bit4~0为Vendor Specific Data Block长度,后面结构参照HDMI标准中的VSDB规范,如下是HDMI1.4a(HDMI1.4a使用CEA-861D)中的VSDB结构:
6. Detailed Timing Descriptions(DTD)
Detailed Timing Descriptions(DTD),每块18字节,详细结构见EDID主块对此部分的解释。
7. Padding(保留字节)
保留字节,用00填充。
8. Checksum
校验和:使前127字节加上此字节等于0。
参考资料:
1.EDID_V3标准规范
2.CEA-861-F 规范