[其他ST产品] keil环境下基于STM32汇编程序的编写

[复制链接]
775|21
 楼主| 等你下课 发表于 2022-8-30 23:25 | 显示全部楼层 |阅读模式
一,创建一个新工程1.创建工程
点击project,选择New uvison Project
watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBARkRGT0VWRVI=,size_15,color_FFFFFF,t_70,g_se,x_16.jpg
命名文件并保存

 楼主| 等你下课 发表于 2022-8-30 23:27 | 显示全部楼层
选择芯片,我选的是STM32F103VE,然后点击ok
33282630e2c55423bd.png
 楼主| 等你下课 发表于 2022-8-30 23:28 | 显示全部楼层
CMSIS下选择CORE;Device下Startup,选完后点击
45056630e2cabb3fa8.png
 楼主| 等你下课 发表于 2022-8-30 23:29 | 显示全部楼层
二, 添加源文件

右击Source Group1,点击add New item to Groupz'Source Group1'

81430630e2ce757916.png


选择文件类型,这里点击Asm Files(.s)添加汇编文件,再输入文件名,并点击Add
 楼主| 等你下课 发表于 2022-8-30 23:31 | 显示全部楼层
24532630e2d3cad80b.png
点击Source Group1左边的加号,看到test1.s,说明添加成功
 楼主| 等你下课 发表于 2022-8-30 23:33 | 显示全部楼层
 楼主| 等你下课 发表于 2022-8-30 23:34 | 显示全部楼层
三,汇编程序

代码

  1. AREA MYDATA, DATA
  2.        
  3. AREA MYCODE, CODE
  4.         ENTRY
  5.         EXPORT __main

  6. __main
  7.         MOV R0, #10
  8.         MOV R1, #11
  9.         MOV R2, #12
  10.         MOV R3, #13
  11.         ;LDR R0, =func01

  12.         BL        func01
  13.         ;LDR R1, =func02
  14.         BL        func02
  15.        
  16.         BL         func03
  17.         LDR LR, =func01
  18.         LDR PC, =func03
  19.         B .
  20.                
  21. func01
  22.         MOV R5, #05
  23.         BX LR
  24.        
  25. func02
  26.         MOV R6, #06
  27.         BX LR
  28.        
  29. func03
  30.         MOV R7, #07
  31.         MOV R8, #08       
  32.         BX LR
 楼主| 等你下课 发表于 2022-8-30 23:35 | 显示全部楼层
程序编译

首先点击options for target,然后在output下面勾选,creaate Hex File
8177630e2e6183289.png
 楼主| 等你下课 发表于 2022-8-30 23:37 | 显示全部楼层
在Debug界面下,勾选Use Simulator,因为在后面要进行虚拟调试,点OK
21765630e2ea12db3f.png
 楼主| 等你下课 发表于 2022-8-30 23:38 | 显示全部楼层
 楼主| 等你下课 发表于 2022-8-30 23:39 | 显示全部楼层
点击Rebuild进行编译
64000630e2ef5eb38b.png
 楼主| 等你下课 发表于 2022-8-30 23:40 | 显示全部楼层
编译成功
4535630e2f36e28eb.png
 楼主| 等你下课 发表于 2022-8-30 23:41 | 显示全部楼层
程序调试
点击右上角的图标进入调试界面
94521630e2fb09804e.png
 楼主| 等你下课 发表于 2022-8-30 23:44 | 显示全部楼层
运行时有些错误
99498630e30744e18c.png
 楼主| 等你下课 发表于 2022-8-30 23:47 | 显示全部楼层
修改dialog
29986630e310e8d6a4.png
 楼主| 等你下课 发表于 2022-8-30 23:48 | 显示全部楼层
再次调试,结果符合预期
81002630e3169dd2e9.png
 楼主| 等你下课 发表于 2022-8-30 23:50 | 显示全部楼层
五,分析生成的HEX文件

用记事本打开hex文件,是一串十六进制字符
81743630e31bd07f35.png
 楼主| 等你下课 发表于 2022-8-30 23:51 | 显示全部楼层
1.扩展线性地址记录

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

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

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

:020000040800F2
 楼主| 等你下课 发表于 2022-8-30 23:51 | 显示全部楼层
内容
25060630e320af3ca6.png
当一个扩展线性地址记录被读取,存储于数据域的扩展线性地址被保存,它被应用于从 Intel HEX 文件读取来的随后的记录

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

通过把记录当中的地址域与被移位的来自扩展线性地址记录的地址数据相加获得数据记录的绝对存储器地址
 楼主| 等你下课 发表于 2022-8-30 23:52 | 显示全部楼层
2.数据部分
Intel HEX 由任意数量的十六进制记录组成。每个记录包含 5 个域,它们按一定格式排列::llaaaatt[dd...]cc

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

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

:llaaaatt[dd…]cc
您需要登录后才可以回帖 登录 | 注册

本版积分规则

54

主题

538

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部