现在的位置: 首页 > 综合 > 正文

Intel HEX格式文件说明

2013年05月13日 ⁄ 综合 ⁄ 共 2397字 ⁄ 字号 评论关闭
  1. Intel HEX文件是记录文本行的ASCII文本文件。
  2. 在Intel HEX文件中, 每一行是一个HEX记录 由十六进制数组成的机器码或者数据常量。
  3. Intel HEX文件经常被用于将程序或数据传输存储到ROM、EPROM , 大多数编程器和模拟器使用Intel HEX文件。
  4.   
  5. 记录格式:
  6. 一个Intel HEX文件可以包含任意多的十六进制记录,每条记录 有五个域
  7. 下面是一个记录的格式. :llaaaatt[dd...]cc
  8.     每一组字母是独立的一域, 每一个字母是一个十六进制数字;
  9.     每一域至少由两个十六进制数字组成;
  10. 下面是字节的描述:
  11. 」 冒号 是每一条Intel HEX记录的开始;
  12. ll 」 是这条记录的长度域,他表示数据(dd)的字节数目;
  13. aaaa 」 是地址域,他表示数据的起始地址
  14.     <※如果是数据记录,这表示将要烧录的这条记录中的数据在EPROM中的偏移地址,
  15.       对于不支持扩展段地址和扩展线性地址的,如89C51,这就是此条记录的起始地址>
  16. tt 」 这个域表示这条HEX记录的类型, 他有可能是下面这几种类型
  17.     00 ----数据记录
  18.     01 ----文件结束记录
  19.     02 ----扩展段地址记录
  20.     04 ----扩展线性地址记录
  21. dd 」 是数据域,表示一个字节的数据,一个记录可能有多个数据字节,字节数目可以查看ll域的说明
  22. cc 」 是效验和域,表示记录的效验和,计算方法是将本条记录冒号开始的所有字母对 <※不包括本效验字和冒号>
  23.     所表示的十六进制数字 <一对字母表示一个十六进制数,这样的一个十六进制数为一个字节>
  24.     都加起来然后模除256得到的余数最后求出余数的补码即是本效验字节cc.
  25.     <
  26.     例如: :0300000002005E9D   
  27.     cc=0x01+NOT((0x03+0x00+0x00+0x00+0x02+0x00+0x5E)%0x100)=0x01+0x9C=0x9D
  28.     C语言描述:
  29.     UCHAR cc;
  30.     cc=(UCHAR)~(0x03+0x00+0x00+0x00+0x02+0x00+0x5E);
  31.     cc++;
  32.     >
  33.   
  34. 数据记录 Intel HEX文件由若干个数据记录组成,一个数据记录以一个回车和一个换行结束 <回车为0x0d换行为0x0a>
  35. 比如下面的一条数据记录 :
  36. 10246200464C5549442050524F46494C4500464C33
  37.    10 是此行记录数据的字节数目
  38.     2462 是数据在内存<将要烧写的eprom地址>中的起始地址
  39.     00 是记录类型00(是一个数据记录)
  40.     464C 到 464C 是数据
  41.     33 是此行记录的效验和
  42.   
  43. 扩展线性地址记录(HEX386)
  44.     扩展线性地址记录也可称为 32位地址记录 和 HEX386记录,
  45. 这个纪录包含高16(16-31位)位数据地址,这种扩展的线性记录总是有两个字节数据,
  46. 像下面这样: :02000004FFFFFC
  47.     02 是记录的数据字节数目
  48.     0000 是地址域这在扩展地址记录中总是0000
  49.     04 是记录类型04(扩展地址记录)
  50.     FFFF 是高16位地址
  51.     FC 是记录效验和,
  52. 计算方法如下: 01h + NOT(02h + 00h + 00h + 04h + FFh + FFh)
  53. 当一个扩展线性地址记录被读到后,扩展线性地址记录的数据区域将被保存
  54. 并应用到后面从Intel HEX文件中读出的记录,这个扩展线性记录一直有效, 直到读到下一个扩展线性记录.
  55.   
  56. 绝对内存地址 = 数据记录中的地址 + 移位后的扩展线性地址
  57. 下面举例说明这个过程从数据记录的地址域得到地址
  58. 2462 从扩展线性地址记录的地址域得到地址
  59. FFFF 绝对内存地址 FFFF2462 扩展段地址记录 (HEX86) 扩展段地址记录也被称为 HEX86记录,
  60. 包含 4-19位的数据地址段, 这个扩展段地址记录总是有两字节数据,
  61. 如下: :020000021200EA
  62. 02 是 记录中的数据字节数目
  63. 0000 是地址域,在扩展段地址记录中,这个域总是0000
  64. 02 是记录类型02(扩展段地址的标示)
  65. 1200 是该段的地址
  66. EA 是效验和
  67. 计算如下: 01h + NOT(02h + 00h + 00h + 02h + 12h + 00h).
  68. 当扩展段地址记录被读后,扩展段地址将被存储并应用到以后从Intel HEX文件读出的记录,
  69. 这个段地址一直有效直到读到下一个扩展段地址记录
  70.   
  71. 绝对内存地址 = 数据记录中的地址 + 移位后的扩展段地址
  72. 数据记录中的地址域 移位后扩展段地址记录中的地址域
  73. 下面举例说明这个过程
  74. 从数据记录的地址域得到地址 2 4 6 2
  75. 从扩展段地址记录的地址域得到地址 1 2 0 0
  76. 绝对内存地址 0 0 0 1 4 4 6 2 文件结束记录(EOF)
  77. 一个Intel HEX文件必须有一个文件结束记录,这个记录的类型域必须是01,
  78. 一个EOF记录总是这样: :00000001FF
  79. 00是记录中数据字节的数目
  80. 0000这个地址对于EOF记录来说无任何意义
  81. 01记录类型是01(文件结束记录标示)
  82. FF是效验和计算如下 01h + NOT(00h + 00h + 00h + 01h).
  83.   
  84. ========================
  85. 总结
  86. 形如 : BB AAAATTHHHH...HHHHCC
  87. BB: Byte
  88. AAAA:数据记录的开始地址,高位在前,地位在后 因为这个格式只支持8bits,地址被倍乘
  89.     所以,为了得到实际的PIC的地址,需要将 地址除以2
  90.     TT: Type 00 数据记录 01 记录结束 04 扩展地址记录(表示32位地址的前缀,当然这种只能在 INHX32)
  91. HHHH:一个字(Word)的数据记录,高Byte在前,低Byte在后 TT之后,总共有 BB/2 个字 的数据
  92. CC: 一个Byte的CheckSum 因为PIC16F873A只有4K的程序空间
  93. 所以,不会有 TT=04的 Linear Address Record
  94. 原文地址 http://www.upsdn.net/html/2004-12/95.html

抱歉!评论已关闭.