HEX文件格式分析

日常开发工作中hex文件是经常用到的一种文件格式,例如生产部门进行量产程序烧录,那么往往使用的是HEX文件。

下面以stm32生成的hex为例,分析hex的文件格式:
官方定义:
<0x3a>[数据长度1Byte][数据地址2Byte][数据类型1Byte][数据nByte][校验1Byte]<0x0d><0x0a>

打开一个stm32生成的hex文件:

1)结合格式分析第一行(指定基地址)
:020000040800F2(:02 0000 04 0800 F2)

解析:
“:” --对应格式中的<0x3a>,0x3a就是冒号的ASCII码

“02”–对应数据长度,即长度为2字节

“0000”–对应数据地址,长度为2个字节。Stm32一个32位的芯片两个字节肯定不足以表示地址(要四个),所以这里地址的具体用法要结合后面的数据类型分析。这里为4指定基地址,所以这两个字节并没有什么用。

“04”–对应数据类型,具体的含义见【注释1】,这里的4是指定基地址。

“0800”–对应数据,长度是浮动的,这里是2个字节,和前面的长度相呼应。这里指定的是基地址。当然指定的是高16的地址,如常见的0x0800 0000 ,所以这个基地址<<16使用。

“F2”–对应的是校验结果,result = 256 - (date[0] + … +date[n])% 256 ,0xF2 = 0x100 - (0x02 +0x00 + 0x00 + 0x04 + 0x08 + 0x00)%0x100。
校验范围是从长度到数据结束字节。

“”–对应<0x0d><0x0a>,就是回车和换行。

2)结合格式分析第二行(数据)
第二行开始到文件快结束的绝大部分内容都是对应的数据,即bin文件中所携带的内容,其他例如基地址,文件起始,文件结束等内容是hex文件才有的附加信息。
:10000000600700200D0C0008050400080704000824
(:10 0000 00 60 07 00 20 0D 0C 00 08 05 04 00 08 07 04 00 08 24)

“10”–对应数据长度16,即60 07 00 20 0D 0C 00 08 05 04 00 08 07 04 00 08这16个字节。

“0000”–对应地址,这里类型是数据,准确的说是低16位,高十六位由第一行的04基地址类型指定,上面指定的是0800 这里指定的是0000,那么后面的16个字节的目标位置就是addr = 0x800 << 16 + 0x0000, 即0x0800 0000。
在这里插入图片描述
在这里插入图片描述
“600700200D0C00080504000807040008”–对应的是数据,这里的数据也就是我们实实在在要写入到产品flash中的东西,下面对HEX与BIN文件做简单对比。
在这里插入图片描述
在这里插入图片描述
3)分析最后两行(入口地址和文件结束)
在这里插入图片描述
“:0400000508000189”–对应函数入口地址,可以参考 .map 文件中可以看到以下信息
在这里插入图片描述
“:00000001FF”–对应文件结束。

【20190407补充】
每行数据的地址是两个字节,可以携带64K的数据,但是如果生成的hex准确的说bin数据大于64k,这时候hex会有如何的变化呢,我用内联函数扩大了生成文件的大小,让生成hex远大于64K,结果hex文件的处理如下图所示:

我们看到了,是重新的指定了基地址,新开辟了64K字节的空间,00类型中的数据的<地址>又开始由0000开始累加了,当我们日常自己要处理hex文件,例如自己写离线下载上位机程序,或是IAP目标板程序,这一点要明确,基地址不仅是只会有一条。

【注释1】
‘00’ Data Record 数据
‘01’ End of File Record 文件结束标志
‘02’ Extended Segment Address Record 延伸段地址
‘03’ Start Segment Address Record 起始延伸地址
‘04’ Extended Linear Address Record 扩展线性地址 也就是基地址
‘05’ Start Linear Address Record 程序起始地址也就是程序入口地址(main)
————————————————
参考文章:
【1】https://blog.csdn.net/qq_38646260/article/details/89047473
【2】https://blog.csdn.net/weixin_39752827/article/details/81477686

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: VC Hex文件格式解析是指对VC(Version Control)系统中的Hex文件进行解析和分析的过程。 首先,VC是一种用于版本控制和代码管理的工具,它采用二进制格式的Hex文件来存储源码、修改记录和版本信息等。Hex文件是一种十六进制形式的文本文件,可以通过特定的解析算法将其转换为可读的源代码或其他文件。 在解析VC Hex文件时,我们需要了解其基本结构和格式。Hex文件通常由多个记录(Record)组成,每个记录包含了不同的类型和数据内容。常见的记录类型包括:数据记录、扩展段地址记录、起始段地址记录和结束记录等。 数据记录包含了实际的源代码或其他数据信息,其格式包括起始地址、数据长度、数据内容和校验和等。扩展段地址记录用于扩展程序的地址空间,起始段地址记录指定程序的入口地址,结束记录表示文件结束。 在解析过程中,我们需要按照记录的格式和顺序读取Hex文件,并根据记录类型对数据进行处理。例如,对于数据记录,我们可以根据起始地址和数据长度将数据写入相应的内存空间或文件中。 解析VC Hex文件的目的是为了能够获取其中的源代码、版本信息或其他相关数据,以便进行版本对比、回滚或其他操作。通过解析Hex文件,我们可以还原出之前的代码状态或版本,并根据需要进行相应的操作。 总而言之,VC Hex文件格式解析是一项对VC系统中的Hex文件进行结构分析和数据提取的过程,通过解析该文件,我们可以获取其中的源代码和版本信息,并进行相应的版本管理和控制。 ### 回答2: VC Hex文件格式是一种常见的存储二进制数据的文件格式。它通常被用于将机器语言代码、固件、软件等以十六进制的形式存储在计算机中。 VC Hex文件格式解析的过程主要包括以下几个方面: 1. 文件结构:VC Hex文件由多行文本组成,每行包含一条记录。每条记录通常由一个冒号开始,后面跟着一系列十六进制数值,用于表示数据。记录的具体格式按照规定的标准进行编码。 2. 记录类型:VC Hex文件的记录有多种类型,包括数据记录、扩展段地址记录、起始段地址记录、起始线性地址记录等。根据记录类型的不同,记录中的数据和含义也会有所差异。 3. 数据内容:VC Hex文件中的数据记录包含机器语言指令、数据、校验和等。数据记录的具体内容由记录类型和记录长度决定,它们被以十六进制的形式表示。 4. 校验和:每条记录都包含一个校验和字段,用于验证记录的完整性和准确性。校验和一般为记录中所有数据的和的补码。 解析VC Hex文件时,可以通过逐行读取文件内容,并根据每行的格式和记录类型,提取出需要的数据和信息。根据记录类型的不同,可以按照规定的格式解析出相应的数据,如地址、校验和等。对于数据记录,可以将每个记录中的数据转换为二进制形式,并根据需要进行后续处理或使用。 总之,解析VC Hex文件格式需要了解文件结构、记录类型、数据内容和校验和等方面的知识。通过逐行解析文件内容,可以获得其中存储的数据和相关信息,进而进行后续处理和使用。 ### 回答3: VC Hex文件格式是一种用来描述微控制器程序存储的十六进制文件格式。它将程序的机器码以十六进制形式进行编码,并且以特定的格式进行排列和存储。 在VC Hex文件中,每一行都包含了一定数量的数据。这些数据通常表示机器指令、数据或其他相关信息。每一行的开头通常包含了该行的地址信息,用于标记数据所在的内存地址。而紧接着的数据则是该地址处的值。 VC Hex文件的地址通常是以16位或32位的形式表示的,这取决于所使用的微控制器架构。地址信息的具体格式也可能会有所不同,但通常都会包含一个地址字节数和一个地址校验和。 除了地址和数据之外,VC Hex文件还可能包含一些其他的特定指令,例如起始地址指令和结束地址指令。这些指令用于标记程序执行的起始地址和结束地址,以便于加载和执行程序。 解析一个VC Hex文件的过程通常涉及以下几个步骤: 1. 读取文件并逐行解析每个数据记录。 2. 提取地址信息和数据值,并进行必要的校验。 3. 根据地址信息将数据值存储到对应的内存地址中。 4. 根据特定指令解析起始地址和结束地址,以确定程序的入口点和结束点。 总的来说,VC Hex文件格式解析是将这些十六进制数据按照特定规则进行解析和存储的过程,以便于加载和执行微控制器的程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值