目录
一、新建项目
二、编写汇编语言源代码并编译
三、分析生成的hex文件
四、总结
(1)新建工程
点击Project,选择New uVision Project创建新项目
输入工程名,保存
选择芯片,这里我选择的是STM32F103C8芯片,点击OK
CMIS下勾选CORE;Device下勾选Startup
点击OK,即可完成工程的创建
(2)添加源文件
(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)设置仿真器
点击魔法棒,选择output选项,在此界面下勾选 Create HEX File,生成hex文件
继续选择Debug选项,“Debug”选项卡中选择“Use Simulator”,表示使用软件仿真;选择“Run to main()”则表示跳过汇编代码,直接跳转到main函数开始仿真。设置下面的“Dialog DLL”项为“DARMSTM.DLL”和“TARMSTM.DLL”;parameter项为“-pSTM32F103C8”,用于设置支持STM32F103C8的软硬件仿真。
设置完成后点击OK,即可进行软件仿真
(3)编译与调试
编译所新建的工程
显示无错误,警告可以省略
编译成功后点击调试按钮,结果如下
(1)扩展线性地址记录
扩展线性地址记录 (hex文件的第一排十六进制也叫做32位地址记录或HEX386记录
这些记录包含数据地址的高16位
扩展线性地址记录总是有2个数据字节,外观如下
内容 | 描述 |
---|---|
:020000040800F2 | |
02 | 这个记录当中数据字节的数量 |
0000 | 地址域,对于扩展线性地址记录,这个域总是0000 |
04 | 记录类型04(扩展X线性地址记录) |
0800 | 是地址的高16位 |
F2 | 是这个记录的校验和,计算方法:01h+NOT(02h+00h+00h+04h+08h+00h) |
(2)数据部分
llaaaatt[dd…]
内容 | 描述 |
---|---|
: | 每个Intel HEX记录都由冒号开始 |
ll | 数据长度域,它代表记录当中数据字节(dd)的数量 |
aaaa | 地址域,它代表记录当中数据起始地址 |
tt | 代表HEX记录类型的域,它可能是以下数据当中的一个:00(记录)、01(文件结束记录)、02(扩展段地址记录)、04(扩展线性地址记录) |
dd | 数据域,它代表一个字节的数据。一个记录可以有许多数据字节,记录当中数据字节的数量必须和数据长度域(ll)中指定的数字相符 |
cc | 校验和域,它代表这个记录的校验和(校验和的计算是通过将记录当中所有十六进制编码数字对的值相加,以256为模进行以下补足) |
(3)文件尾
在文件的最后一排,是一个文件的结束标志:
:00000001FF
内容 | 描述 |
---|---|
00 | 记录的长度为0 |
0000 | LOAD OFFSET为0000 |
01 | TYPE=01 |
FF | 校验和为FF |
整体来说,在keil下创建汇编语言的STM32工程,步骤相对还是容易明白的,对于程序的调试阶段按照老师的说明也可以成功调试出来。所谓前人栽树,后人乘凉。有了前面博主的博客,我的工程才能成功创建出来。