上位机操纵座Flash(3) hex文件格式
那么想通过hex文件去操作flash 那么就需要知道hex文件格式。
参考https://baike.baidu.com/item/hex%E6%96%87%E4%BB%B6%E6%A0%BC%E5%BC%8F/1025048?fr=aladdin
https://blog.csdn.net/weixin_39752827/article/details/81477686
重复的轮子很多那么下边带大家分析一下。参考百度的结果随便打开一个工程的HEX文件
建议使用notepad++打开 真的省眼睛。
:020000040800F2
:1000000098070020D501000859640008C3160008AD
:1000100055640008C1050008816800080000000060
我的工程的前三行hex
:02 0000 04 0800 F2
02 表述数据长度2
0x0000 表示地址
04 代表扩展线性地址记录(我个人理解就是标记一个起始地址)
0x0800 数据内容
F2 校验和
也就是说我们后边的数据基地址是0x0800 +偏移地址构成。
紧接着第一行数据
:10 0000 00 98070020D501000859640008C3160008AD
10 代表数据长度16
0000地址
00表述数据记录 也就是数据
98070020D501000859640008C3160008 为数据
AD为校验和
也就代表着0x0800 0000 的数据为98070020D501000859640008C3160008
紧接着下一行
:1000100055640008C1050008816800080000000060
只是地址不同
分析方法相同
地址为
0010 地址 因为刚才的数据是16个所以现在地址要加上0x10
也就代表着 0x0800 0010的数据是55640008C10500088168000800000000
紧接着看最后两行
:0400000508000131BD
:00000001FF
首先读懂这两行 需要知道什么是map文件
简单来说map文件是通过编译器编译之后,集程序、数据及IO空间的一种映射文件。
:0400000508000131BD
数据内容四个字节
地址0000 (不重要)
05 开始线性地址记录 应该指的的是程序开始执行的地址。(这里不是很确定 ,但是分析来就是程序的入口地址)
参考.map文件
__Vectors 0x08000000 Data 4 startup_stm32f10x_hd.o(RESET)
__Vectors_End 0x08000130 Data 0 startup_stm32f10x_hd.o(RESET)
__main 0x08000131 Thumb Code 8 __main.o(!!!main)
可以看出 08000131 就是main函数 前边是中断向量表。
:00000001FF 文件结束
这样我们做一个试验来验证所学。
我们通过STM32 ST-LINK Utility 查看hex文件。然后修改我们想要的内容。
:020000040800F2
:100000006007002009070008110200081302000819
:10001000FFFFFFFFFFFFFFFF0000000000000000E8
:0400000508000131BD
:00000001FF
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dvkSgb36-1628991036500)(C:\Users\bruce\Desktop\上位机操作Flash\屏幕截图 2021-08-15 092502.png)]
至此我们距离成功已经进了很大一步
拓展
Reset_Handler PROC
EXPORT Reset_Handler [WEAK]
IMPORT __main
IMPORT SystemInit
LDR R0, =SystemInit
BLX R0
LDR R0, =__main
BX R0
ENDP
可以看一下复位中断向量 到这里应该明白为什么我们一定要要复位电路,为什么要复位。主要就是要产生这个中断然后执行一些初始化 跳转到主函数。
_main
BX R0
ENDP
可以看一下复位中断向量 到这里应该明白为什么我们一定要要复位电路,为什么要复位。主要就是要产生这个中断然后执行一些初始化 跳转到主函数。