搭建并配置Keil嵌入式开发环境,完成一个基于STM32汇编程序的编写
一、新建项目
按以下步骤新建项目即可:
- project——New
- 保存位置及项目名称
- 选择芯片
- 按以下勾选即可
- 添加源文件
二、代码编写及配置
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. 配置环境
为防止动态debug无法进入汇编程序
①点击魔法棒
②在“Debug”选项卡中选择“Use Simulator”,表示使用软件仿真; 选择“Run to main()”则表示跳过汇编代码,直接跳转到main函数开始仿真; 设置下面的“Dialog DLL”项为“DARMSTM.DLL”; parameter项为“-pSTM32F103C8”,用于设置支持STM32F103C8的软硬件仿真。
- 若要输出hex文件,即按下图勾选:Output——Create HEX File
三、编译调试
-
编译——仿真调试 -
run
- 观察结果:与代码设置的一致
四、了解Hex文件
了解Hex文件格式及其前8个字节内容含义
1.打开.hex 文件
在对应目录下找到.hex 文件,用记事本打开,即为以下图片的显示
2. 解释含义
①具体释义举例: 第一行的:020000040800F2,可以看作是 0x02,0x00,0x00,0x04,0x08,0x00,0xF2。
0x02:该行数据中有两个数据 0x00 0x00:本行数据的起始地址位 0x04:用来标识扩展线性地址的记录 该字节还可以是其他值,下面是其他值的含义 00:用来记录数据,HEX文件的大部分记录都是数据记录 01:用来标识文件结束,放在文件的最后,标识HEX文件的结尾 02:用来标识扩展段地址的记录 03:开始段地址记录 05:开始线性地址记录 0x08 0x00:该行两个字节的数据 数据类型是 04 ,即该行记录的是一个拓展地址(0x08 0x00 是地址信息,用法是将该地址(0x0800<<16) 后作为基地址 0xF2:校验和,校验和= 0x100 - 累加和
②文件格式:
Intel HEX 由任意数量的十六进制记录组成。每个记录包含 5 个域,它们按一定格式排列::llaaaatt[dd…]cc 每一组字母对应一个不同的域,每一个字母对应一个十六进制编码的数字 每一个域由至少两个十六进制编码数字组成,它们构成一个字节,就像以下描述的那样: :llaaaatt[dd…]cc
内容 | 描述 |
---|
: | 每个Intel HEX记录都由冒号开头 | ll | 数据长度域,它代表记录当中数据字节(dd)的数量 | aaaa | 地址域,它代表记录当中数据的起始地址 | tt | 代表HEX记录类型的域,它可能是以下数据当中的一个:00(数据记录)、01(文件结束记录)、02(扩展段地址记录)、04(扩展线性地址记录) | dd | 数据域,它代表一个字节的数据。一个记录可以有许多数据字节.记录当中数据字节的数量必须和数据长度域(ll)中指定的数字相符 | cc | 表示这个记录的校验和(校验和的计算是通过将记录当中所有十六进制编码数字对的值相加,以256为模进行以下补足) |
小小的总结
此次实验这是一个小小的仿真调试,十分方便迅速的完成了仿真调试; 实验按照大佬做过的步骤一步步去做,以及老师的提示,很容易就能解决问题,实验过程中也会遇到一些不明就里的问题,在遇到问题的时候也要学会自己去查阅资料,对照找出错误,学会去解决问题。
参考文献
- 基于MDK创建纯汇编语言的STM32工程——汇编实现LED闪烁
- ARM汇编基础之基于MDK创建纯汇编语言的STM32工程
- MDK基于STM32汇编程序并编写软件程序
- KEIL环境下创建STM32汇编语言工程分析Hex文件内容
|