keil下编译代码并生成hex文件


)

一.在keil下创建工程项目

1.创建项目

点击project,new uvision project 创建项目 命名文件 选择芯片,stm32f103vE,然后点ok cmsis下选择core device下startup ,后面选择ok

2.添加源文件

右击source group 1 ,点击add new item to group 之后弹窗里面选择文件类型,点击asm files.s 添加汇编文件,输入文件名,点击add

二.代码编写,编译与调试

1.代码编写

在test.s里面添加代码

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.程序编译

点击options for target 在output界面下勾选create hex file 才能生成hex文件 在 Debug界面下,勾选 Use Simulator,因为在后面我们要进行虚拟调试,后OK 保存设置 由于仿真软件和keil的关系我们需要搭载一个debug.ini文件 或者调试debug界面下的相关参数

3.程序调试

运行之后可以得到预期值r5,r6,r7,r8的值与程序设置一样

三.分析生成的Hex文件

打开hex文件并分析

1.扩展线性地址记录

扩展线性地址记录(hex 文件的第一排十六进制)也叫作 32 位地址记录或 HEX386 记录

这些记录包含数据地址的高 16 位

扩展线性地址记录总是有两个数据字节,外观如下(这里我通过标记方便对应原始数据):

:020000040800F2

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

当一个扩展线性地址记录被读取,存储于数据域的扩展线性地址被保存,它被应用于从 Intel HEX 文件读取来的随后的记录

线性地址保持有效,直到它被另外一个扩展地址记录所改变

通过把记录当中的地址域与被移位的来自扩展线性地址记录的地址数据相加获得数据记录的绝对存储器地址

2.数据部分

Intel HEX 由任意数量的十六进制记录组成。每个记录包含 5 个域,它们按一定格式排列::llaaaatt[dd…]cc

每一组字母对应一个不同的域,每一个字母对应一个十六进制编码的数字

每一个域由至少两个十六进制编码数字组成,它们构成一个字节,就像以下描述的那样: :llaaaatt[dd…]cc

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

文件尾

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

:00000001FF

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

四.总结

通过本次搭建虚拟仿真让我更加了解到keil的大致功能,希望能更加深入学习keil相关知识。

经验分享 程序员 微信小程序 职场和发展