完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我用CCS6.1 的 ARM HEX Utility 生成 HEX文件 (intel hex )
:08 0000 00 05FEFEFEAEDBB0B0 10 :20 0020 00 0800081E08BC0600 B40001FBA4000102 01ED408C00020202 E6396809005C0000 C5 :20 00A0 00 034C0000FBF400040203D427DC00FF010104CCBC0400B80400F40200A40500D462 第二行 数据起始地址 0020 数据长度 为 20 第三行 数据起始地址 00A0 数据长度 为 20 按hex 格式的解释。第二行 应该只使用了 0020 ~003F 从0040 ~ 009F 这部分没有用吗? :20 0120 00 0F00C8000003B80000FBB000020202AF02940200080800A30A009F000097000141 :20 01A0 00 FBA30500081E080000D80100D0D000CC1A00C4000000000020050001000020F90C :20 0220 00 900A00310800140C0400000850000C000C000334000100300400000808200508AE :20 02A0 00 01080820F9FC0A000C14000E00000004800000A70500A30500A70A009701009F20 :20 0320 00 010000000040050001000040F90C0300AC1000A402009C53009475008C93008431 :20 03A0 00 75007CD3007475006C6C006875006060005C7500545400507500F00000E8010004 |
|
相关推荐
4 个讨论
|
|
Hex文件是可以烧录到MCU中,被MCU执行的一种文件格式。如果用记事本打开可发现,整个文件以行为单位,每行以冒号开头,内容全部为16进制码(以ASCII码形式显示)。Hex文件可以按照如下的方式进行拆分来分析其中的内容:
例如 “: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、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:开始线性地址记录 然后是数据,最后一个字节 0x54为校验和。 校验和的算法为:计算0x54前所有16进制码的累加和(不计进位),检验和 = 0x100 - 累加和 在上面的后2种记录,都是用来提供地址信息的。每次碰到这2个记录的时候,都可以根据记录计算出一个“基”地址。对于后面的数据记录,计算地址的时候,都是以这些“基”地址为基础的。 HEX文件都是由记录(RECORD)组成的。在HEX文件里面,每一行代表一个记录。记录的基本格式为: Record mark ‘:’ Length Load offset Record type INFO or DATA CHKSUM 1 byte 1 byte 2 bytes 1 byte n bytes 1 byte 看个例子: :020000040008F2 :10000400FF00A0E314209FE5001092E5011092E5A3 :00000001FF 对上面的HEX文件进行分析: 第1条记录的长度为02,LOAD OFFSET为0000,RECTYPE为04,说明该记录为扩展段地址记录。数据为0008,校验和为F2。从这个记录的长度和数据,我们可以计算出一个基地址,这个地址为(0x0008 << 16)。后面的数据记录都以这个地址为基地址。 第2条记录的长度为10(16),LOAD OFFSET为0004,RECTYPE为00,说明该记录为数据记录。数据为FF00A0E314209FE5001092E5011092E5,共16个BYTE。这个记录的校验和为A3。此时的基地址为0X80000,加上OFFSET,这个记录里的16BYTE的数据的起始地址就是0x80000 + 0x0004 = 0x80004. 第3条记录的长度为00,LOAD OFFSET为0000,TYPE = 01,校验和为FF。说明这个是一个END OF FILE RECORD,标识文件的结尾。 在上面这个例子里,实际的数据只有16个BYTE:FF00A0E314209FE5001092E5011092E5,其起始地址为0x0004. |
|
|
|
|
|
潘涛12345 发表于 2018-8-13 07:51 我可以看明白你贴的这篇文章。 能不能帮忙解释一下,下面这个问题? 按hex 格式的解释。第二行 应该只使用了 0020 ~003F 从0040 ~ 009F 这部分没有用吗? |
|
|
|
|
|
只有小组成员才能发言,加入小组>>
344 浏览 1 评论
539 浏览 2 评论
NA555DR VCC最低电压需要在5V供电,为什么用3.3V供电搭了个单稳态触发器也使用正常?
783 浏览 3 评论
MSP430F249TPMR出现高温存储后失效了的情况,怎么解决?
655 浏览 1 评论
对于多级放大电路板,在PCB布局中,电源摆放的位置应该注意什么?
1138 浏览 1 评论
AT32F407在USART2 DMA发送数据时,接包接到了要发送的数据,程序还是处于等待传输完成的标识判断中,为什么?
70浏览 29评论
223浏览 23评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
257浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
205浏览 14评论
两个TMP117传感器一个可以正常读取温度值,一个读取的值一直是0,为什么?
65浏览 13评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-25 17:00 , Processed in 1.495520 second(s), Total 70, Slave 57 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号