Intel HEX文件格式

来源:互联网 发布:磐厚资本知乎 编辑:程序博客网 时间:2024/05/21 07:48
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 160x600, 创建于 08-4-23MSDN */google_ad_slot = "4367022601";google_ad_width = 160;google_ad_height = 600;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>

本文由AthlonxpX86(桃源村)翻译<>中的内容为译者加入的内容

问题:

什么是Intel HEX格式?

回答:

Intel HEX文件是记录文本行的ASCII文本文件,下面是Intel HEX文件格式,在Intel HEX文件中,每一行是一个HEX记录由十六进制数组成的机器码或者静态数据,Intel HEX文件经常被用于将程序或数据传输存储到ROM.EPROM,大多数编程器和模拟器使用Intel HEX文件.

记录格式:

一个Intel HEX文件可以包含任意多的十六进制记录,每条记录有五个域,下面是一个记录的格式.

:llaaaatt[dd...]cc

每一组字母是独立的一域,每一个字母是一个十六进制数字,每一域至少由两个十六进制数字组成,下面是字节的描述.

:?冒号是每一条Intel HEX记录的开始

ll?是这条记录的长度域,他表示数据(dd)的字节数目.

aaaa?是地址域,他表示数据的起始地址<如果是数据记录这表示将要烧录的这条记录中的数据在EPROM中的偏移地址,对于不支持扩展段地址和扩展线性地址的如89C51,这就是此条记录的起始地址>tt?这个域表示这条HEX记录的类型,他有可能是下面这几种类型00 ----数据记录<要分清楚这几种记录类型,后面会经常出现,不要搞混了>01 ----文件结束记录<HEX文件的最后一条记录这个域是01>02 ----扩展段地址记录04 ----扩展线性地址记录

dd?是数据域,表示一个字节的数据,一个记录可能有多个数据字节,字节数目可以查看ll域的说明

cc?是效验和域,表示记录的效验和,计算方法是将本条记录冒号开始的所有对字母<不包括本效验字和冒号>所表示的十六进制数字<一对字母表示一个十六进制数,这样的一个十六进制数为一个字节>都加起来然后模除256得到的余数最后求出余数的补码即是本效验字节cc.<例如::0300000002005E9Dcc=0x01+NOT((0x03+0x00+0x00+0x00+0x02+0x00+0x5E)%0x100)=0x01+0x9C=0x9DC语言描述:UCHAR cc;cc=(UCHAR)~(0x03+0x00+0x00+0x00+0x02+0x00+0x5E);cc++;>

一数据记录

Intel HEX文件由若干个数据记录组成,一个数据记录以一个回车和一个换行结束<回车为0x0d换行为0x0a>

比如下面的一条数据记录:10246200464C5549442050524F46494C4500464C3310是此行记录数据的字节数目2462是数据在内存<将要烧写的eprom地址>中的起始地址00是记录类型00(是一个数据记录)464C到464C是数据33是此行记录的效验和

二扩展线性地址记录(HEX386)扩展线性地址记录也可以认为是32为地址记录和HEX386记录,这个纪录包含高16(16-31位)位数据地址,这种扩展的线性记录总是有两个字节数据,像下面这样:

:02000004FFFFFC02是记录的数据字节数目0000是地址域这在扩展地址记录中总是000004是记录类型04(扩展地址记录)FFFF是高16位地址FC是记录效验和,计算方法如下:01h + NOT(02h + 00h + 00h + 04h + FFh + FFh)

当一个扩展线性地址记录被读到后,扩展线性地址记录的数据区域将被保存并应用到后面从Intel HEX文件中读出的记录,这个扩展线性记录一直有效,直到读到下一个扩展线性记录.

绝对内存地址 = 数据记录中的地址? +? 移位后的扩展线性地址

????????????????????? |???????????????????? |

??????? 数据记录中的地址域?? 移位后扩展线性地址记录中的地址域

下面举例说明这个过程

从数据记录的地址域得到地址????? ?????????? 2462从扩展线性地址记录的地址域得到地址??????????? FFFF????????????????????????????????????????????? --------绝对内存地址?????????????????????? ?????? FFFF2462

?三扩展段地址记录 (HEX86)

扩展段地址记录也可以认为是包含地址中4-19位的数据地址段,这个扩展段地址记录总是有两字节数据,如下::020000021200EA02是记录中的数据字节数目0000是地址域,在扩展段地址记录中,这个域总是000002是记录类型02(扩展段地址的标示)1200是该段的地址EA是效验和计算如下:01h + NOT(02h + 00h + 00h + 02h + 12h + 00h).

当扩展段地址记录被读后,扩展段地址将被存储并应用到以后从Intel HEX文件读出的记录,这个段地址一直有效直到读到下一个扩展段地址记录

绝对内存地址 = 数据记录中的地址? +? 移位后的扩展段地址

????????????????????? |???????????????????? |

??????? 数据记录中的地址域?? 移位后扩展段地址记录中的地址域

下面举例说明这个过程

从数据记录的地址域得到地址????? ?????????? 2462从扩展段地址记录的地址域得到地址???????????????? 1200????????????????????????????????????????????? --------绝对内存地址?????????????????????? ?????? 00014462

四文件结束记录(EOF)一个Intel HEX文件必须有一个文件结束记录,这个记录的类型域必须是01,一个EOF记录总是这样::00000001FF00是记录中数据字节的数目0000这个地址对于EOF记录来说无任何意义01记录类型是01(文件结束记录标示)FF是效验和计算如下01h + NOT(00h + 00h + 00h + 01h).

?

<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 160x600, 创建于 08-4-23MSDN */google_ad_slot = "4367022601";google_ad_width = 160;google_ad_height = 600;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
原创粉丝点击