(转)HEX文件详解

原文来自:http://blog.csdn.net/yx_l128125/article/details/13624947

我们先来详细分析“方法一”的操作:

1.我们设置编译 程序的编译器(如图),这个设置意思是把程序下载到flash 的 0x0800 0000开头的位置,然后编译程序

2.编译完程序后,在工程目录的output文件夹中找到编译后生产的.hex文件;

用 notepad++  或者 UltraEdit 打开 程序 的.hex文件   

hex文件格式:

(1)以行为单位,每行以冒号开头,内容全部为16进制码(以ASCII码形式显示)

 

(2)在HEX文件里面,每一行代表一个记录。记录的基本格式为:

冒号本行数据长度本行数据起始地址数据类型数据校验值
 1BYTE2BYTE1BYTE 1Byte
      
      

 

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

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

第四字节表示数据类型,数据类型有:0x00、0x01、0x02、0x03、0x04、0x05。

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

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

'02' Extended Segment Address Record:用来标识扩展段地址的记录

'03' Start Segment Address Record:开始段地址记录

'04' Extended Linear Address Record:用来标识扩展线性地址的记录

'05' Start Linear Address Record:开始线性地址记录

然后是数据,最后一个字节 为校验和。

校验和的算法为:计算校验和前所有16进制码的累加和(不计进位),检验和 = 0x100 - 累加和

打开.hex内容如下:(中间部分数据略去)

    <strong>:020000040800F2  
    :10000000B80B00207D250008850300088703000841</strong>  
    :100010009B0300089F030008A303000800000000E2  
    :10002000000000000000000000000000A70300081E  
    :10003000A903000800000000AB030008AD0300089E  
    。  
    。  
    。  
    :102B40000400000000000000000000000000000081  
    :102B50000000000000000000000000000000000075  
    :102B6000010203040102030406070809020406081F  
    :102B700000366E01000000000000000001020304A6  
    :042B80000607080933  
    <strong>:0400000508000121CD  
    :00000001FF</strong>  

先分析第一条语句---- “:02 0000  04 0800  F2”

冒号本行数据长度本行数据起始地址(偏移地址)数据类型数据校验值
      

在上面的数据类型后2种记录(04,05)都是用来提供地址信息的每次碰到这2个记录的时候,都可以根据记录计算出一个地址。对于后面的数据记录,计算地址的时候,都是以这些地址为基础的。以我们的语句为例:

 

 

1条记录的长度为02LOAD OFFSET0000RECTYPE04,说明该记录为扩展段地址记录。数据为0800,校验和为F2。从这个记录的长度和数据,我们可以计算出一个基地址,这个地址为(0x0800 << 16) = 0x0800 0000 ,后面的数据记录都以这个地址为基地址。(这里的地址左移2的四次方,可以参考转载的上篇文章,应该是将将段地址转换为物理地址)

 

第二条语句----“ :10000000B80B00207D250008850300088703000841”

2条记录的长度为10(0x10=16字节)LOAD OFFSET0000RECTYPE00('00' Data Rrecord:用来记录数据,HEX文件的大部分记录都是数据记录),数据为B80B00207D2500088503000887030008  校验码为41;此时基地址为:0x0800 0000  加上偏移地址:0x0000   这条记录的16个字节的数据的起始地址为:0x0800000 + 0x0000 =0x0800 0000

 

 

第3条语句----“:0400000508000121CD”

记录的长度为04LOAD OFFSET0000RECTYPE05 ,此时,EIP寄存器里存放的地址:0x0800 0121; 即IP指向下一个要执行的指令所在地址,我们来看一下IAP工程list目录下的.map文件,其中第393行处如图:(看到没?0x0800 0121值main函数的入口地址)害羞

EIP是32位机的指令寄存器IP是指令寄存器,存放当前指令的下一条指令的地址。CPU该执行哪条指令就是通过IP来指示的

上图参考hex数据文档:http://pages.interlog.com/~speff/usefulinfo/Hexfrmt.pdf 或 http://microsym.com/editor/assets/intelhex.pdf

 

第4条语句---“:00000001FF”  (每一个.hex文件的最后一行都是固定为这个内容)

 (每一个.hex文件的最后一行都是固定为这个内容)
记录的长度为00LOAD OFFSET0000RECTYPE01  01' End of File Record:用来标识文件结束,放在文件的最后,标识HEX文件的结尾)

 

 

 

 

 

转载于:https://www.cnblogs.com/shell1028/p/4152836.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值