当前位置:首页 >> 机械/仪表 >>

hex和bin文件格式的区别


Intel HEX 文件是记录文本行的 ASCII 文本文件,在 Intel HEX 文件中,每一行是一个 HEX 记录,由十六进制数组成的机器码或者数据常量。Intel HEX 文件经常被用于将程序或数据 传输存储到 ROM、EPROM,大多数编程器和模拟器使用 Intel HEX 文件。 很多编译器的支持生成 HEX 格式的烧录文件,尤其是 Keil c。但是编程器能够下载的

往 往是 BIN 格式,因此 HEX 转 BIN 是每个编程器都必须支持的功能。 HEX 格式文件以行为 单位,每行由“:(0x3a)开始,以回车键结束(0x0d,0x0a)。行内的数据都是由两个字符表 ” 示一个 16 进制字节,比如”01”就表示数 0x01; ”0a” ,就表示 0x0a。对于 16 位的地址,则 高位在前低位在后,比如地址 0x010a,在 HEX 格式文件中就表示为字符串”010a” 。下面为 HEX 文件中的一行::10000000FF0462FF051EFF0A93FF0572FF0A93FFBC “: ”表示一行的 开始。 “: ”后的第 1,2 个字符“10”表示本行包含的数据的长度,这里就是 0x10 即 16 个。 第 3,4,5,6 个字符“0000”表示数据存储的起始地址,这里表示从 0x0000 地 址开始存储 16 个数据,其中高位地址在前,低位地址在后。 第 7,8 个字符“00”表示 数据的类型。该类型总共有以下几种: 00 ----数据记录 01 ----文件结束记录 02 ----扩展段地址记录 04 ----扩展线性地址记录这里就是 0x00 即为普通数据记录。 自后的 32 个字符就是本行包含 的数据,每两个字符表示一个字节数据,总共有 16 个字节数据跟行首的记录的长度相一致。 最后两个字符表示校验码。 每个 HEX 格式的最后一行都是固定为: :00000001FF 以上的信 息其实就足够进行 HEX 转 BIN 格式的程序的编写。首先我们只处理数据类型为 0x00 及 0x01 的情况。0x02 表示对应的存储地址超过了 64K,由于我的编程器只针对 64K 以下的单片机, 因此在次不处理,0x04 也是如此 什么是 Intel HEX 格式? 回答: Intel HEX 文件是记录文本行的 ASCII 文本文件,在 Intel HEX 文件中,每一行是一个 HEX 记 录 由十六进制数组成的机器码或者数据常量,Intel HEX 文件经常被用于将程序或数据传输 存储到 ROM.EPROM,大多数编程器和模拟器使用 Intel HEX 文件. 记录格式 一个 Intel HEX 文件可以包含任意多的十六进制记录,每条记录有五个域,下面是一个记录的 格式. :llaaaatt[dd...]cc 每一组字母是独立的一域,每一个字母是一个十六进制数字,每一域至少由两个十六进制数字 组成,下面是字节的描述. :冒号 是每一条 Intel HEX 记录的开始

ll 是这条记录的长度域,他表示数据(dd)的字节数目. aaaa 是地址域,他表示数据的起始地址 <如果是数据记录,这表示将要烧录的这条记录中的数据在 EPROM 中的偏移地址, 对于不支持扩展段地址和扩展线性地址的,如 89C51,这就是此条记录的起始地址> tt 00 01 02 04 这个域表示这条 HEX 记录的类型,他有可能是下面这几种类型 ----数据记录 ----文件结束记录 ----扩展段地址记录 ----扩展线性地址记录

dd 是数据域,表示一个字节的数据,一个记录可能有多个数据字节,字节数目可以 查看 ll 域的说明 cc 是效验和域,表示记录的效验和,计算方法是将本条记录冒号开始的所有字母对 <不包括本效验字和冒号> 所表示的十六进制数字 <一对字母表示一个十六进制数,这样的一个十六进制数为一个字节> 都加起来然后模除 256 得到的余数最后求出余数的补码即是本效验字节 cc. <例如: :0300000002005E9D cc=0x01+NOT((0x03+0x00+0x00+0x00+0x02+0x00+0x5E)%0x100)=0x01+0x9C=0x9D C 语言描述: UCHAR cc; cc=(UCHAR)~(0x03+0x00+0x00+0x00+0x02+0x00+0x5E); cc++; > 数据记录 Intel HEX 文件由若干个数据记录组成,一个数据记录以一个回车和一个换行结束 <回车为 0x0d 换行为 0x0a> 比如下面的一条数据记录 :10246200464C5549442050524F46494C4500464C33 10 是此行记录数据的字节数目 2462 是数据在内存<将要烧写的 eprom 地址>中的起始地址 00 是记录类型 00(是一个数据记录) 464C 到 464C 是数据 33 是此行记录的效验和

扩展线性地址记录(HEX386) 扩展线性地址记录也可称为 32 位地址记录 和 HEX386 记录,这个纪录包含高 16(16-31 位) 位数据地址,这种扩展的线性记录总是有两个字节数据,像下面这样: :02000004FFFFFC 02 是记录的数据字节数目 0000 是地址域这在扩展地址记录中总是 0000 04 是记录类型 04(扩展地址记录) FFFF 是高 16 位地址 FC 是记录效验和,计算方法如下: 01h + NOT(02h + 00h + 00h + 04h + FFh + FFh) 当一个扩展线性地址记录被读到后,扩展线性地址记录的数据区域将被保存 并应用到后面从 Intel HEX 文件中读出的记录,这个扩展线性记录一直有效, 直到读到下一个扩展线性记录.

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

下面举例说明这个过程 从数据记录的地址域得到地址 2462 从扩展线性地址记录的地址域得到地址 FFFF 绝对内存地址 FFFF2462 扩展段地址记录 (HEX86) 扩展段地址记录也被称为 HEX86 记录, 包含 4-19 位的数据地址段, 这个扩展段地址记录总是有两字节数据,如下: :020000021200EA 02 是 记录中的数据字节数目 0000 是地址域,在扩展段地址记录中,这个域总是 0000 02 是记录类型 02(扩展段地址的标示) 1200 是该段的地址 EA 是效验和 计算如下: 01h + NOT(02h + 00h + 00h + 02h + 12h + 00h). 当扩展段地址记录被读后,扩展段地址将被存储并应用到以后从 Intel HEX 文件读出的记录, 这个段地址一直有效直到读到下一个扩展段地址记录

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

数据记录中的地址域 移位后扩展段地址记录中的地址域 下面举例说明这个过程 从数据记录的地址域得到地址 2 4 6 2 从扩展段地址记录的地址域得到地址 1 2 0 0 绝对内存地址 0 0 0 1 4 4 6 2 文件结束记录(EOF) 一个 Intel HEX 文件必须有一个文件结束记录,这个记录的类型域必须是 01, 一个 EOF 记录总是这样: :00000001FF 00 是记录中数据字节的数目 0000 这个地址对于 EOF 记录来说无任何意义 01 记录类型是 01(文件结束记录标示) FF 是效验和计算如下 01h + NOT(00h + 00h + 00h + 01h). ======================== 总结

形如 :BBAAAATTHHHH...HHHHCC BB: Byte AAAA:数据记录的开始地址,高位在前,地位在后 因为这个格式只支持 8bits,地址被倍乘 所以,为了得到实际的 PIC 的地址,需要将 地址除以 2 TT: Type 00 数据记录 01 记录结束 04 扩展地址记录(表示 32 位地址的前缀,当然这种只能在 INHX32) HHHH:一个字(Word)的数据记录,高 Byte 在前,低 Byte 在后 TT 之后,总共有 BB/2 个字 的数据 CC: 一个 Byte 的 CheckSum

因为 PIC16F873A 只有 4K 的程序空间 所以,不会有 TT=04 的 Linear Address Record

hex 和 bin 文件格式 2008 年 10 月 23 日 星期四 04:23 P.M. Hex 文件,这里指的是 Intel 标准的十六进制文件,也就是机器代码的十六进制形式,并且是用 一定文件格式的 ASCII 码来表示.具体格式介绍如下: Intel hex 文件格式 Intel hex 文件常用来保存单片机或其他处理器的目标程序代码。它保存物理程序存储区中 的目标代码映象。一般的编程器都支持这种格式。 Intel hex 文件全部由可打印的 ASCII 字符组成,如下例所示: :2000000012014c75a800e4f508f509780a7a78e4f608dafcd283fcfded240af9a7050dbd81 :2000200000010ced2488ec34ff50edc283e4fcfded240af9e76d7013ed33e43c700d0dbd2a :2000400000010ced2488ec34ff50e50509e50970020508e50924a8e50834fd50aee4f50874 Intel hex 由一条或多条记录组成,每条记录都由一个冒号“:”打头,其格式如下: :CCAAAARR...ZZ 其中: CC 本条记录中的数据字节数 AAAA 本条记录中的数据在存储区中的起始地址 RR 记录类型: 00 数据记录 (data record) 01 结束记录 (end record) 02 段记录 (paragraph record) 03 转移地址记录 (transfer address record) ... 数据域 ZZ 数据域校验和 校验值:每一行的最后一个值为此行数据的校验和。例如: :1000000018F09FE518F09FE518F09FE518F09FE5C0 这行中的 0xC0

:1000100018F09FE5805F20B9F0FF1FE518F09FE51D 这行中的 0x1D

校验和的算法为:计算从 0x3A 以后(不包括 0x3A)的所有各字节的和模 256 的余。即各字 节二进制算术和,不计超过 256 的溢出值,然后用 0x100 减去这个算数累加和,得出得值就 是此行得校验和。

Intel hex 文件记录中的数字都是 16 进制格式,两个 16 进制数字代表一个字节。CC 域是数 据域中的实际字节数,地址、记录类型和校验和域没有计算在内。校验和是取记录中从数据 字节计数域(CC)到数据域(...)最后一个字节的所有字节总和的 2 的补码。

而 Bin 文件是最纯粹的二进制机器代码,没有格式,或者说是"顺序格式"按 assembly code 顺 序翻译成 binary machine code.由于分析出来 Hex 文件中的数据域 ASCII 码表示的十六进制 与二进制一一对应,而且我公司 DSP 又是 16 位的,以一个 word 为最小单位,所以四个十六进制 ASCII 码代表一条机器指令单位或者地址.借于上面分析,编写了工具代码.大体原理是用 fscanf 函数在每行的数据域读入四个 ASCII 码,以短整形(short int 16bit)形式储存,在把 这个短整形变量顺序 fwrite 到文件流中去即可. 举一例说明: 表1 ORG 0000H LJMP START ORG 040H START: MOV SP,#5FH ;设堆栈 LOOP: NOP LJMP LOOP ;循环 END ;结束 表2 :03000000020040BB :0700400075815F000200431F 表3 02 00 40 FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF 75 81 5F 00 02 00 43 表 1 为源程序,表 2 是汇编后得到的 HEX 文件,表 3 是由 HEX 文件转换成的目标文件,也就 是最终写入 EPROM 的文件,它由编程器转换得到,也可以由 HEXBIN 一类的程序转换得到。 学过手工汇编者应当不难找出表 3 与表 1 的一一对应关系,值得注意的是从 02 00 40 后开始 的一长串‘FF’ ,直到 75 81,这是由于伪指令:ORG 040H 造成的结果。 copy from:http://tieba.baidu.com/f?kz=271526661

/* 使用方法 : bin2hex -b adress filename -b : 指示 hex 文件起始地址 address : hex 文件的起始地址(FIXME:当前版本只支持 k 字节边界) filename : 待转换的文件名 示例 : bin2hex -b 32k rom.bin */ #include <stdio.h> #include <stdlib.h> #include <string.h> FILE *fp_read; FILE *fp_write; /* 待读取文件句柄 */ /* 待写入文件句柄 */

unsigned long start_adr; unsigned short cur_base; unsigned short cur_offset; unsigned char read_buf[16]; unsigned char write_buf[48]; void calc_start_adr (char *buf) { unsigned int len; len = strlen(buf);

/* 转换成 Hex 格式的起始地址 */ /* 转换成 Hex 格式的当前地址高 16 位 */ /* 转换成 Hex 格式的当前地址低 16 位 */

if ((buf[len-1] != 'k') && (buf[len-1] != 'K')) { printf ("Invalid argument.\n"); exit (-1); } buf[len-1] = 0; start_adr = atoi (buf); start_adr = start_adr * 1024; cur_base = start_adr >> 16; cur_offset = (unsigned short)start_adr; }

void start_convert (void) { unsigned char cnt; unsigned char read_num; unsigned char cksum, highc, lowc; /* 设置当前地址高 16 位 */ highc = cur_base >> 8; lowc = (unsigned char)cur_base; cksum = 2 + 4 + highc + lowc; cksum = 0xFF - cksum; cksum = cksum + 1; sprintf (write_buf, ":02000004%04x%02x", cur_base, cksum); write_buf[15] = 0x0D; write_buf[16] = 0x0A; fwrite (write_buf, 1, 17, fp_write); read_num = fread (read_buf, 1, 16, fp_read); while (read_num == 16) { /* 写入读取的 16 字节 */ highc = cur_offset >> 8; lowc = (unsigned char)cur_offset; cksum = 0x10 + highc + lowc; for (cnt=0; cnt<16; cnt++) { cksum += read_buf[cnt]; } cksum = 0xFF - cksum; cksum = cksum + 1; sprintf (write_buf, ":10%02x%02x00%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%0 2x", highc, lowc, read_buf[0], read_buf[1], read_buf[2], read_buf[3], read_buf[4], read_buf[5], read_buf[6], read_buf[7], read_buf[8], read_buf[9], read_buf[10], read_buf[11], read_buf[12], read_buf[13], read_buf[14], read_buf[15], cksum); write_buf[43] = 0x0D; write_buf[44] = 0x0A; fwrite (write_buf, 1, 45, fp_write); /* 计算当前地址低 16 位,当越限时写入当前地址高 16 位 */ if (cur_offset == 65520) {

cur_offset = 0; cur_base ++; highc = cur_base >> 8; lowc = (unsigned char)cur_base; cksum = 2 + 4 + highc + lowc; cksum = 0xFF - cksum; cksum = cksum + 1; sprintf (write_buf, ":02000004%04x%02x", cur_base, cksum); write_buf[15] = 0x0D; write_buf[16] = 0x0A; fwrite (write_buf, 1, 17, fp_write); } else { cur_offset += 16; } read_num = fread (read_buf,1,16,fp_read); } /* 写入剩余的字节 */ if (read_num) { highc = cur_offset >> 8; lowc = (unsigned char)cur_offset; cksum = read_num + highc + lowc; for (cnt=0; cnt<read_num; cnt++) { cksum += read_buf[cnt]; } cksum = 0xFF - cksum; cksum = cksum + 1; sprintf (write_buf, ":%02x%02x%02x00", read_num, highc, lowc); for (cnt=0; cnt<read_num; cnt++) { sprintf (&write_buf[9 + cnt * 2], "%02x", read_buf[cnt]); } sprintf (&write_buf[9 + cnt * 2], "%02x", cksum); write_buf[11 + read_num * 2] = 0x0D; write_buf[12 + read_num * 2] = 0x0A; fwrite (write_buf, 1, 13 + read_num * 2, fp_write); } /* 写入终止序列 */ sprintf (write_buf, ":00000001FF"); write_buf[11] = 0x0D; write_buf[12] = 0x0A; fwrite (write_buf, 1, 13, fp_write); }

int main (int argc, char *argv[]) { if (argc != 4) { printf ("Usage : %s -b address filename.xxx\n", argv[0]); printf ("-b : indicate the starting address convert to.\n"); printf ("address : starting address.\n"); printf ("filename.xxx : file to be converted.\n"); printf ("output : filename.hex\n"); printf ("example : %s -b 64k rom.bin\n", argv[0]); return -1; } if (strcmp (argv[1], "-b")) { printf ("Invalid argument.\n"); return -1; }; fp_read = fopen (argv[3], "rb"); if (fp_read == NULL) { printf ("Can't open file %s", argv[3]); return -1; } fp_write = fopen ("rom.hex", "w"); if (fp_write == NULL) { printf ("Can't create file rom.hex"); return -1; } calc_start_adr (argv[2]); start_convert (); fclose (fp_read); fclose (fp_write); printf("Convert Seccessfully!\n"); return 0; }

简单介绍一下这 2 种文件格式的区别:

1 - HEX 文件是包括地址信息的,而 BIN 文件格式只包括了数据本身 在烧写或下载 HEX 文件的时候,一般都不需要用户指定地址,因为 HEX 文件内部 的信息已经包括了地址。而烧写 BIN 文件的时候,用户是一定需要指定地址信息的。

3 - BIN 文件格式 对二进制文件而言,其实没有”格式” 。文件只是包括了纯粹的二进制数据。

4 - HEX 文件格式 HEX 文件都是由记录(RECORD)组成的。在 HEX 文件里面,每一行代表一个记录。 记录的基本格式为: +---------------------------------------------------------------+ | RECORD | RECLEN | LOAD | RECTYPE | INFO or DATA | CHKSUM | | MARK ':' | | OFFSET | | | | +---------------------------------------------------------------+ | 1-byte | 1-byte | 2-byte | 1-byte | n-byte | 1-byte | +---------------------------------------------------------------+ 记录类型包括: '00' Data Rrecord:用来记录数据,HEX 文件的大部分记录都是数据记录 '01' End of File Record: 用来标识文件结束,放在文件的最后,标识 HEX 文件 的结尾 '04' Extended Linear Address Record: 用来标识扩展线性地址的记录 '02' Extended Segment Address Record: 用来标识扩展段地址的记录 在上面的后 2 种记录,都是用来提供地址信息的。每次碰到这 2 个记录的时候, 都可以根据记录计算出一个“基”地址。 对于后面的数据记录,计算地址的时候,都是以这些“基”地址为基础的。 数据记录的具体格式: +---------------------------------------------------------------+ | RECORD | RECLEN | LOAD | RECTYPE | INFO or DATA | CHKSUM | | MARK ':' | | OFFSET | '00' | | | +---------------------------------------------------------------+ | 1-byte | 1-byte | 2-byte | 1-byte | n-byte | 1-byte |

+---------------------------------------------------------------+ 看个例子: :020000040000FA :10000400FF00A0E314209FE5001092E5011092E5A3 :00000001FF 对上面的 HEX 文件进行分析: 第 1 条记录的长度为 02,LOAD OFFSET 为 0000,RECTYPE 为 04,说明该记录为扩 展段地址记录。数据为 0000,校验和为 FA。从这个记录的长度和数据,我们可以计算出一个基地址,这个地址为 0X0000。 后面的数据记录都以这个地址为基 地址。 第 2 条记录的长度为 10(16) ,LOAD OFFSET 为 0004,RECTYPE 为 00,说明该记录 为数据记录。 数据为 FF00A0E314209FE5001092E5011092E5, 16 个 BYTE。 共 这个记录的校验和为 A3。此时的基地址为 0X0000,加上 OFFSET, 这个记录里的 16BYTE 的数据的起始地址就是 0x0000 + 0x0004 = 0x0004. 第 3 条记录的长度为 00,LOAD OFFSET 为 0000,TYPE = 01,校验和为 FF。说明 这个是一个 END OF FILE RECORD,标识 文件的结尾。 在 上 面 这 个 例 子 里 , 实 际 的 数 据 只 有 FF00A0E314209FE5001092E5011092E5,其起始地址为 0x4 16 个 BYTE :

4 - HEX 文件和 BIN 文件大小有区别 HEX 文件是用 ASCII 来表示二进制的数值。 例如一般 8-BIT 的二进制数值 0x3F, ASCII 用 来表示就需要分别表示字符'3' 和字符'F',每个字符需要一个 BYTE,所以 HEX 文件需要 > 2 倍的空间。 对一个 BIN 文件而言,你查看文件的大小就可以知道文件包括的数据的实际大小。而 对 HEX 文件而言,你看到的文件 大小并不是实际的数据的大小。一是因为 HEX 文件是用 ASCII 来表示数据,二是因为 HEX 文件本身还包括别的附加信息。

本 文 来 自 CSDN 博 客 , 转 载 请 标 明 http://blog.csdn.net/studyvcmfc/archive/2009/05/30/4225282.aspx








相关文章:
HEX和BIN
HEX和BIN_计算机软件及应用_IT/计算机_专业资料。HEX和BIN文件 HEX 文件和 BIN 文件格式的区别 HEX 文件和 BIN 文件是我们经常碰到的 2 种文件格式。下面简单...
Hex文件格式详解
Hex文件格式详解_计算机软件及应用_IT/计算机_专业资料。对于学习mcu下载有帮助,...HEX文件和BIN文件格式的... 2页 1下载券 HEX文件格式 11页 免费 HEX文件...
hex格式介绍及转bin格式的源程序
hex格式介绍及转bin格式的源程序_IT/计算机_专业资料。如标题所示hex...HEX格式介绍及分析程序 3页 免费喜欢此文档的还喜欢 hex和bin文件格式的区别 7...
二进制文件和十六进制文件的区别
F00EFF88DF0A4FFEDC5F0CEA42EFEEC88F016 :04003F00A42EFE22CB :00000001FF HEX 文件和 BIN 文件格式区别 HEX 文件和 BIN 文件是我们经常碰到的两种文件格式...
HEX文件格式说明
HEX文件格式说明_计算机软件及应用_IT/计算机_专业资料。Intel HEX 文件是记录文本...1/2 相关文档推荐 HEX文件格式 11页 免费 hex和bin文件格式的区别 7页 免费...
BIN HEX文件介绍
BIN HEX文件介绍_计算机软件及应用_IT/计算机_专业资料。BIN 文件 HEX 文件介绍...HEX和BIN文件区别 1页 免费 hex和bin文件格式的区别 7页 免费 HEX文件和BIN...
hex、bin、elf、axf文件区别
hex,bin,axf,elf 的区别 一、HEX 和 BIN Hex 文件,这里指的是 Intel 标准的十六进制文件,也就是机器代码的十六进 制形式,并且是用一定文件格式的 ASCII 码...
HEX_BIN介绍
在单片机的学习中,我们常常接触到 hex 文件和 bin 文件,那么这两者之间到底有什么养的区别呢? HEX 文件和 BIN 文件是我们经常碰到的 2 种文件格式。下面简单...
HEX文件格式
Intel HEX 文件是记录文本行的 ASCII 文本文件,在 Intel HEX 文件中,每一行是...hex和bin文件格式的区别 7页 免费 Hex文件格式 10页 免费 Hex与HIN文件...
Hex文件格式
Intel HEX 文件是记录文本行的 ASCII 文本文件,下面是 Intel HEX 文件格式,在...HEX文件和BIN文件格式的... 2页 1下载券 hex和bin文件格式的区别 7页 免费...
更多相关标签:
hex和bin文件的区别 | hex文件和bin文件区别 | hex格式怎么转换bin | hex文件转换成bin文件 | bin文件转换为hex文件 | hex bin 区别 | hex文件转bin文件工具 | hex2bin文件转换器 |