hex是什么文件格式

hex是什么文件格式,第1张

hex文件格式是可以烧写到单片机中,被单片机执行的一种文件格式。

生成Hex文件的方式有很多种,可以通过不同的编译器将C程序或者汇编程序编译生成hex。Hex文件如果用特殊的程序来查看(一般记事本就可以实现)。打开后可发现,整个文件以行为单位,每行以冒号开头,内容全部为16进制码(以ASCII码形式显示)。

Intel HEX文件由一行行符合Intel HEX文件格式的文本所构成的ASCII文本文件。在Intel HEX文件中,每一行包含一个HEX记录。这些记录由对应机器语言码和常量数据的十六进制编码数字组成。

扩展资料:

一个Intel HEX文件必须有一个文件结束记录,这个记录的类型域必须是01,Intel hex 文件常用来保存单片机或其他处理器的目标程序代码。它保存物理程序存储区中的目标代码映象。一般的编程器都支持这种格式。

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

参考资料来源:百度百科——hex文件格式

keil生成hex文件可以在软件中设置后导出,具体办法如下:

1、打开已写好的工程项目,可通过双击工程项目打开,也可以在keil中,菜单栏的Project-OpenProject...找到项目后进行打开。

2、点击菜单Project--OptionstoFile,进入到选择对话框中。

3、在Optionsfortarget对话框中,切换到target栏中,输入与自己实际使用晶振的频率。

4、切换到output栏中,点击SecletFolderObjects,可以设置生成HEX文件的目录,如果不设置默认为与源代码同一目录下。

5、切换到output栏中,勾选CreateHEXfile选项,并点击确定。

6、依次点击工具栏中的编译、构建,重构建,提示无警告错误后,就可以在提示中看到。creatinghexfilefrom".\obj\****"...代表已生成HEX文件。

7、最后在目录下的obj文件夹中就能看到生成的HEX文件。

HEX 文件是可以烧录到 MCU 中,被 MCU 执行的一种文件格式。如果用记事本打开可发现,整个文件以行为单位,每行以冒号开头,内容全部为 16 进制码(以 ASCII 码形式显示)。

HEX 文件都是由记录(RECORD)组成的。在 HEX 文件里面,每一行代表一个记录。记录的基本格式为:

RECORD MARK":"(1) + LENGTH(1) + LOAD OFFSET(2) + RECTYPE(1) + INFO or DATA(n) + CHKSUM(1)

例如 “:1000080080318B1E0828092820280B1D0C280D2854” 可以被看作 “0x10 0x00 0x08 0x00 0x80 0x31 0x8B 0x1E 0x08 0x28 0x09 0x28 0x20 0x28 0x0B 0x1D 0x0C 0x28 0x0D 0x28 0x54”

第一个字节 0x10 表示本行数据的长度;

第二、三字节 0x00 0x08 表示本行数据的起始地址;

第四字节 0x00 表示数据类型,数据类型有:

0x00: Data Rrecord,用来记录数据,HEX 文件的大部分记录都是数据记录

0x01: End of File Record,用来标识文件结束,放在文件的最后,标识 HEX 文件的结尾

0x02: Extended Segment Address Record,用来标识扩展段地址的记录

0x03: Start Segment Address Record,开始段地址记录

0x04: Extended Linear Address Record,用来标识扩展线性地址的记录

0x05: Start Linear Address Record,开始线性地址记录

第五字节开始是数据;

最后一个字节 0x54 为校验和,计算本行前面所有 16 进制码的累加和(不计进位),校验和 = 0x100 - 累加和。

在上面的后两种记录,都是用来提供地址信息的。每次碰到这两个记录的时候,都可以根据记录计算出一个“基”地址。对于后面的数据记录,计算地址的时候,都是以这些“基”地址为基础的。

再看个例子:

:020000040008F2

:10000400FF00A0E314209FE5001092E5011092E5A3

:00000001FF      

对上面的 HEX 文件进行分析:

第 1 条记录的长度为 0x02,LOAD OFFSET为 0x0000,RECTYPE 为 0x04,说明该记录为扩展段地址记录。数据为 0x00 0x08,校验和为 0xF2。从这个记录的长度和数据,我们可以计算出一个基地址,这个地址为 (0x0008 <<16),后面的数据记录都以这个地址为基地址。

第 2 条记录的长度为 0x10(16),LOAD OFFSET为 0x0004,RECTYPE为 0x00,说明该记录为数据记录。数据为 0xFF 0x00 0xA0 0xE3 0x14 0x20 0x9F 0xE5 0x00 0x10 0x92 0xE5 0x01 0x10 0x92 0xE5,共 16 字节。这个记录的校验和为0xA3。此时的基地址为 0x80000,加上 OFFSET,这个记录里的 16 字节数据的起始地址就是 0x80000 + 0x0004 = 0x80004.

第 3 条记录的长度为 0x00,LOAD OFFSET 为 0x0000,RECTYPE 位 0x01,校验和为 0xFF。说明这个是一个 END OF FILE RECORD,标识文件的结尾。

在上面这个例子里,实际的数据只有 16 字节:FF00A0E314209FE5001092E5011092E5,其起始地址为 0x0004


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/8071373.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-13
下一篇 2023-04-13

发表评论

登录后才能评论

评论列表(0条)

保存