赞
踩
目录
2.1 创建一个名为test1的新工程
3.1 本文采用STM32F103ZE
3.2 CMSIS
下选择CORE
;
3.3 Device
下Startup
,其中包含了启动文件;
3.4 为工程添加源文件.s文件,取名为test1
3.5 工程设置可由魔法棒进入,也可以由快捷键Alt+F7
- 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.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 |
0000 | LOAD OFFSET为0000 |
01 | TYPE = 01 |
FF | 校验和为FF |
这个是一个 END OF FILE RECORD,标识文件的结尾
第一次使用汇编语言只能说非常的陌生,熟悉了对keil5的安装与stm32包的下载,掌握了其中仿真器的设置。在未接硬件下可跳过驱动设置直接进行对软件的仿真。还需在此课上更花时间与心思。
ARM汇编基础之基于MDK创建纯汇编语言的STM32工程_GREYWALL-CSDN博客
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。