基于MDK下的stm32练习

目录

利用Keil完成汇编语言编写

最终生成 hex文件的各段的大小 

观察ARM寄存器变化状况

总结 

 参考资料


利用Keil完成汇编语言编写

1、新建工程,点击上方的的Project->New μVision Project… 选择工程存放位置及工程名。

2、选择芯片

3、 添加启动文件并点击OK

4、在左侧Source Group 1文件上右键,选择Add new item…,选择Asm File,然后点击Add,加入后缀为.s的汇编文件

 

 

5、 添加代码

 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
	END

 注:为了能在MDK中进行仿真,需要进行一些设置,点击魔法棒,选择Debug,Use Simulator,将下方的Dialog.DLL修改成DARMSTM.DLL,Parameter修改成-pSTM32F103C8(根据你选的芯片来写),如果这里不进行修改,仿真调试的时候就会一直循环。

6、选择仿真设备(电脑仿真无外部设备)

7、开始仿真及仿真结果

最终生成 hex文件的各段的大小 

1、 Hex文件格式及其前8个字节内容含义

如图,其中第一行020000040800F2中,可以看做是0x02 0x00 0x00 0x04 0x08 0x00 0xf2,其前四个字节和最后一个字节有特殊含义。中间为数据

第一个0×02表示该行数据中有两个数据

第二个,第三个0x00 0x00表示本行数据的起始地址位

第四个字节有0x00 0x01 0x02 0x03 0x04 0x05,分别有以下含义

'00’Data Rrecord:用来记录数据,HEX文件的大部分记录都是数据记录

'01’文件结束记录:用来标识文件结束,放在文件的最后,标识HEX文件的结尾**

'02’扩展段地址记录:用来标识扩展段地址的记录

'03’开始段地址记录:开始段地址记录

'04’扩展线性地址记录:用来标识扩展线性地址的记录

'05’开始线性地址记录:开始线性地址记录

最后一个字节0xf2为校验和。
校验和的算法为:
计算0xf2前所有16进制码的累加和(不计进位),检验和 = 0x100 - 累加和


观察ARM寄存器变化状况

通过对两图的对比,明显发现寄存器由原来的误值转变为有值

                 

总结 

经过本次stm32仿真练习,在学习了keil软件的基本操作方法上,通过与51单片机的仿真对比,发现二者存在些许差距,不过总的来说类似。其次,通过本次实验,对于stm32芯片有着进一步的了解,同时,如果有条件的话可以将硬件连入电脑,相比仿真而言,会让你对stm32芯片的工作方式有着进一步的了解。

 参考资料

1、HEX文件格式详解:HEX文件格式详解_海角天涯的博客-CSDN博客_hex和0x

2、基于MDK下的STM32F103纯汇编语言练习_Bazinga223333的博客-CSDN博客

浅谈STM32汇编(Wizard).pdf

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值