基于MDK创建纯汇编语言的STM32工程

目录

1、打开keil5

2、新建工程

​3、配置环境

4、源代码

5、仿真器设置

6、总结

7、参考文献


1、打开keil5

2、新建工程

2.1  创建一个名为test1的新工程

3、配置环境

 

 

3.1  本文采用STM32F103ZE 

3.2  CMSIS下选择CORE

3.3  DeviceStartup,其中包含了启动文件;

 

 3.4  为工程添加源文件.s文件,取名为test1

 3.5  工程设置可由魔法棒进入,也可以由快捷键Alt+F7

4、源代码

 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

错误点:汇编语言不能顶格写必须要有空格,否则会编译出错。

5、仿真器设置

 

 5.1  在“Debug”选项卡中选择“Use Simulator”,表示使用软件仿真;选择“Run to main()”则表示跳过汇编代码,直接跳转到main函数开始仿真。不勾选的话无法进行仿真。设置下面的“Dialog DLL”项为“DARMSTM.DLL”;parameter项为“-pSTM32F103C8”,用于设置支持STM32F103C8的软硬件仿真。

 5.2  创建.hex文件。

 

 5.3  进行汇编语言代码编译,可以看出该软件占用内存大小。

 5.4  对汇编代码进行调试,观察相应寄存器的值。

5.5 打开hex文件观察十六进制字符

 

5.5.1扩展线性地址记录

扩展线性地址记录(hex 文件的第一排十六进制)也叫作 32 位地址记录或 HEX386 记录
这些记录包含数据地址的高 16 位
扩展线性地址记录总是有两个数据字节,外观如下(这里我通过标记方便对应原始数据):

内容描述
:020000040800F2
02这个记录当中数据字节的数量
0000地址域,对于扩展线性地址记录,这个域总是 0000
04记录类型 04 (扩展线性地址记录)
0800是地址的高 16 位
F2是这个记录的校验和,计算方法:01h + NOT(02h + 00h + 00h + 04h + 08h + 00h)


当一个扩展线性地址记录被读取,存储于数据域的扩展线性地址被保存,它被应用于从 Intel HEX 文件读取来的随后的记录
线性地址保持有效,直到它被另外一个扩展地址记录所改变
通过把记录当中的地址域与被移位的来自扩展线性地址记录的地址数据相加获得数据记录的绝对存储器地址
5.5.2 数据部分

Intel HEX 由任意数量的十六进制记录组成。每个记录包含 5 个域,它们按一定格式排列::llaaaatt[dd...]cc
每一组字母对应一个不同的域,每一个字母对应一个十六进制编码的数字
每一个域由至少两个十六进制编码数字组成,它们构成一个字节,就像以下描述的那样:

内容描述
:llaaaatt[dd...]cc
每个Intel HEX记录都由冒号开头
||数据长度域,它代表记录当中数据字节(dd)的数量
aaaa地址域,它代表记录当中数据的起始地址
tt代表HEX记录类型的域,它可能是以下数据当中的一个:00(数据记录)01(文件结束记录)02(扩展段地址记录)04(扩展线性地址记录)
dd数据域,它代表一个字节的数据。一个记录可以有许多数据字节.记录当中数据字节的数量必须和数据长度域(ll)中指定的数字相符
cc校验和域,它表示这个记录的校验和(校验和的计算是通过将记录当中所有十六进制编码数字对的值相加,以256为模进行以下补足)


Intel HEX文件由任意数量以回车换行符结束的数据记录组成
这里我们随便拿一条数据记录分析,比如第二条吧

内容描述
:100000000006002031010008390100083B0100080A
10这个记录当中数据字节的数量
0000数据将被下载到存储器当中的地址
00记录类型(数据记录)
0006...0008数据
0A这个记录的校验和


5.5.3 文件尾

在文件的最后一排,是一个文件的结束标志::00000001FF

内容描述
:00000001FF
00记录的长度为 0
0000LOAD OFFSET为0000
01TYPE = 01
FF校验和为FF


这个是一个 END OF FILE RECORD,标识文件的结尾

6、总结

    第一次使用汇编语言只能说非常的陌生,熟悉了对keil5的安装与stm32包的下载,掌握了其中仿真器的设置。在未接硬件下可跳过驱动设置直接进行对软件的仿真。还需在此课上更花时间与心思。

7、参考文献

                      ARM汇编基础之基于MDK创建纯汇编语言的STM32工程_GREYWALL-CSDN博客

                      STM32基于汇编方式创建工程文件和闪烁LED灯_xwmrcj的博客-CSDN博客

              基于MDK创建纯汇编语言的STM32工程——汇编实现LED闪烁_Harriet的博客-CSDN博客

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值