我是靠谱客的博主 现代汉堡,最近开发中收集的这篇文章主要介绍在keil下创建汇编语言的STM32工程一、新建项目二、编写汇编语言源代码并编译三、分析生成的hex文件四、总结,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

目录
一、新建项目
二、编写汇编语言源代码并编译
三、分析生成的hex文件
四、总结

一、新建项目

(1)新建工程

  • 点击Project,选择New uVision Project创建新项目在这里插入图片描述

  • 输入工程名,保存

  • 选择芯片,这里我选择的是STM32F103C8芯片,点击OK在这里插入图片描述

  • CMIS下勾选CORE;Device下勾选Startup
    在这里插入图片描述

  • 点击OK,即可完成工程的创建

(2)添加源文件

  • 右击 Source Group 1,点击 Add New Item to Group ‘Source Group 1’在这里插入图片描述
  • 点击 Asm Files添加汇编文件,输入文件名后点击Add在这里插入图片描述
  • 此时源文件添加完成

二、编写汇编语言源代码并编译

(1)编写代码

  • 在Test1.c编辑页面编写汇编代码,代码如下:
 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)编译与调试

  • 编译所新建的工程
    在这里插入图片描述

  • 显示无错误,警告可以省略

  • 编译成功后点击调试按钮,结果如下在这里插入图片描述

三、分析生成的hex文件

  • 记事本打开hex文件,是一串十六进制字符

在这里插入图片描述
(1)扩展线性地址记录
扩展线性地址记录 (hex文件的第一排十六进制也叫做32位地址记录或HEX386记录
这些记录包含数据地址的高16位
扩展线性地址记录总是有2个数据字节,外观如下

内容描述
:020000040800F2
02这个记录当中数据字节的数量
0000地址域,对于扩展线性地址记录,这个域总是0000
04记录类型04(扩展X线性地址记录)
0800是地址的高16位
F2是这个记录的校验和,计算方法:01h+NOT(02h+00h+00h+04h+08h+00h)
  • 当一个扩展线性地址记录被读取,存储于数据域的扩展线性地址被保存,它被应用于从IntelHEX文件读取来的随后的记录
  • 线性地址保持有效,直到它被另外一个扩展线性地址记录所改变
  • 通过把记录当中的地质域与被移位的来自扩展线性地址记录的地址数据相加获得数据记录的绝对存储器地址

(2)数据部分

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

llaaaatt[dd…]

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

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

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

四、总结

整体来说,在keil下创建汇编语言的STM32工程,步骤相对还是容易明白的,对于程序的调试阶段按照老师的说明也可以成功调试出来。所谓前人栽树,后人乘凉。有了前面博主的博客,我的工程才能成功创建出来。

最后

以上就是现代汉堡为你收集整理的在keil下创建汇编语言的STM32工程一、新建项目二、编写汇编语言源代码并编译三、分析生成的hex文件四、总结的全部内容,希望文章能够帮你解决在keil下创建汇编语言的STM32工程一、新建项目二、编写汇编语言源代码并编译三、分析生成的hex文件四、总结所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部