共计 884 个字符,预计需要花费 3 分钟才能阅读完成。
导读 | 我们在编译生成固件的时候,有时候生成 Hex 文件有时候生成 Bin 文件,这两种文件有什么关系呢,它们存在的价值又是什么呢? |
Hex 文件是以 ASCII 文本形式保存编译后的二进制文件信息。Hex 文件使用 ASCII 文本的形式保存 Bin 文件的内容和 Bin 文件的一些配置信息。Hex 文件可以由下载器(比如 jlink)烧写到 MCU 的 ROM 中。
Bin 文件是 MCU 固件烧写的最终形式,也就是说 MCU 的 ROM 中烧写的内容完全就是 Bin 文件的内容。
Hex 文件可以说是 MCU 固件的中间形式,由下载器的软件根据 Hex 文件生成 Bin 文件再烧写到 MCU 的 ROM 中。既然 Bin 文件是最终我们想要的,那么 Hex 文件有什么存在价值?我们为什么不直接生成 Bin 文件,却要生成 Hex 文件呢?这就要从 Hex 文件的内容格式说起来了。
从上面我们知道 Hex 文件不只是保存 Bin 文件的内容,还有一些配置信息。我们以一个例子大概说下 Hex 文件的结构,见下图:
上图的 Hex 文件总共 6 行的内容。每行都是以 ’:’ 开始,之后是地址域、数据类型、数据域和校验和。
最后一行的数据类型是 0x01, 代表文件结束了。
从上面的介绍中,我们发现 Hex 文件中每行的内容,就像我们发送串口数据的数据帧,并且最后一行还指示出文件结束了。我们得出 hex 文件的两个优点:
- 1. 使用 ASCII 文本保存固件信息,方便查看一些固件内容;
- 2. 通过文件每行的校验和与最后一行的文件结束标志,在文件的传输与保存过程中能够发现固件是否完整。
Hex 文件有更好的可读性,最重要的是 hex 文件能够保证固件在保存与传输时的完整性。因此 hex 文件更适用于保存与传输。而 Bin 文件是纯二进制文件,内部只包含程序编译后的机器码和变量数据。当文件损坏时,我们也无法知道文件已损坏。不过 Bin 文件作为固件的最终形式,在使用串口下载程序或者远程升级时,是不可替代的。