Keil环境下用STM32汇编语言工程分析HEX文件内容

系列文章目录

提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加
例如:第一章 Python 机器学习入门之pandas的使用


提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

搭建并配置Keil嵌入式开发环境,完成一个基于STM32汇编程序的编写。

1)记录build生成的 hex文件各段的大小,了解Hex文件格式及其前8个字节内容含义;

2)学习在没有硬件条件下进行仿真调试的方法,观察ARM寄存器变化状况。


提示:以下是本篇文章正文内容,下面案例可供参考

一、实验平台的建立

一:点击 Project ——> New uVision Project 创建新项目

     

 二:将自己的文件放入提前建立的工程文件中

三:选择 stm32f10ve芯片,点击ok

四:选择如下设置,点击ok。

 四:源文件的添加

 

二、代码及其调试

1.代码

 AREA MYDATA, DATA
	
 AREA MYCODE, CODE
	ENTRY
	EXPORT __main
 
__main
	MOV R0, #10
	MOV R1, #11
	MOV R2, #12
	MOV R3, #13
	;LDR R0, =func01
 
	BL	func01
	;LDR R1, =func02
	BL	func02
	
	BL 	func03
	LDR LR, =func01
	LDR PC, =func03
	B .
		
func01
	MOV R5, #05
	BX LR
	
func02
	MOV R6, #06
	BX LR
	
func03
	MOV R7, #07
	MOV R8, #08	
	BX LR

2.初始设置

 1.点击 Options for Target...。在Output中勾选create HEX File

 2.在Debug中改写设置如下

 3.随后编译即可

3.程序调试

1.点击如图所示图标,并运行程序

2.调试出结果如图


四、hex文件的解析

1.记事本打开hex文

 

2)扩展线性地址记录

扩展线性地址记录(hex 文件的第一排十六进制)也叫作 32 位地址记录或 HEX386 记录
这些记录包含数据地址的高 16 位
扩展线性地址记录总是有两个数据字节,外观如下(这里我通过标记方便对应原始数据):
内容    描述
:020000040800F2    
02    这个记录当中数据字节的数量
0000    地址域,对于扩展线性地址记录,这个域总是 0000
04    记录类型 04 (扩展线性地址记录)
0800    是地址的高 16 位
F2    是这个记录的校验和,计算方法:01h + NOT(02h + 00h + 00h + 04h + 08h + 00h)
当一个扩展线性地址记录被读取,存储于数据域的扩展线性地址被保存,它被应用于从 Intel HEX 文件读取来的随后的记录
线性地址保持有效,直到它被另外一个扩展地址记录所改变
通过把记录当中的地址域与被移位的来自扩展线性地址记录的地址数据相加获得数据记录的绝对存储器地址
3)数据部分

Intel HEX 由任意数量的十六进制记录组成。每个记录包含 5 个域,它们按一定格式排列::llaaaatt[dd...]cc
每一组字母对应一个不同的域,每一个字母对应一个十六进制编码的数字
每一个域由至少两个十六进制编码数字组成,它们构成一个字节,就像以下描述的那样:
内容    描述
:llaaaatt[dd…]cc    
:    每个Intel HEX记录都由冒号开头
ll    数据长度域,它代表记录当中数据字节(dd)的数量
aaaa    地址域,它代表记录当中数据的起始地址
tt    代表HEX记录类型的域,它可能是以下数据当中的一个:00(数据记录)、01(文件结束记录)、02(扩展段地址记录)、04(扩展线性地址记录)
dd    数据域,它代表一个字节的数据。一个记录可以有许多数据字节.记录当中数据字节的数量必须和数据长度域(ll)中指定的数字相符
cc    校验和域,它表示这个记录的校验和(校验和的计算是通过将记录当中所有十六进制编码数字对的值相加,以256为模进行以下补足)
Intel HEX文件由任意数量以回车换行符结束的数据记录组成
这里我们随便拿一条数据记录分析,比如第二条吧
内容    描述
:100000001806002031010008390100083B010008F2    
10    这个记录当中数据字节的数量
0000    数据将被下载到存储器当中的地址
00    记录类型(数据记录)
1806…0008    数据
F2    这个记录的校验和
4)文件尾

在文件的最后一排,是一个文件的结束标志::00000001FF
内容    描述
:00000001FF    
00    记录的长度为 0
0000    LOAD OFFSET为0000
01    TYPE = 01
FF    校验和为FF
这个是一个 END OF FILE RECORD,标识文件的结尾

原文链接:https://blog.csdn.net/ssj925319/article/details/111868500

data = pd.read_csv( 'https://labfile.oss.aliyuncs.com/courses/1283/adult.data.csv') print(data.head()) 

该处使用的url网络请求的数据。

五、参考资料

(6条消息) 基于 MDK 创建 STM32 汇编语言工程并分析 HEX 文件内容_ssj925319的博客-CSDN博客

(6条消息) Keil环境下创建STM32汇编语言工程并分析HEX文件内容_m0_58414679的博客-CSDN博客


总结

本人小白一名,如有错误请各位大佬指出

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值