- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ARM汇编指令实验
ARM 汇编指令实验一
实验目的
初步学会使用 μVision IDE for ARM 开发环境及ARM 软件模拟器;
通过实验掌握简单 ARM 汇编指令的使用方法。
实验设备
硬件:PC 机一台;
软件:μVision IDE for ARM 集成开发环境,Windows 98/2000/NT/XP。
实验内容
熟悉开发环境的使用并使用 ldr/str,mov 等指令访问寄存器或存储单元;
使用 add/sub/lsl/lsr/and/orr 等指令,完成基本算术/逻辑运算。
实验原理
ARM 处理器共有37 个寄存器:
31 个通用寄存器,包括程序计数器(PC)。这些寄存器都是32 位的;
6 个状态寄存器。这些寄存器也是32 位的,但是只是使用了其中的12 位。
1. ARM 通用寄存器
通用寄存器(R0-R15)可分为三类:
不分组寄存器 R0~R7
不分组寄存器R0~R7 在所有处理器模式下,它们每一个都访问一样的32 位寄存器。它们是真正的通用寄存器,没有体系结构所隐含的特殊用途。
分组寄存器 R8~R14
分组寄存器R8~R14 对应的物理寄存器取决于当前的处理器模式。若要访问特定的物理寄存器而不依赖当前的处理器模式,则要使用规定的名字。
寄存器R8~R12 各有两组物理寄存器:一组为FIQ 模式,另一组为除了FIQ 以外的所有模式。
寄存器R8~R12 没有任何指定的特殊用途,只是在作快速中断处理时使用。寄存器R13,R14 各对应6 个分组的物理寄存器,1 个用于用户模式和系统模式,其它5 个分别用于5 种异常模式。寄存器R13 通常用做堆栈指针,称为SP;寄存器R14 用作子程序链接寄存器,也称为LR。
程序计数器 PC
寄存器R15 用做程序计数器(PC)。在本实验中,ARM 核工作在用户模式,R0~R15 可用。
2. 存储器格式
ARM 体系结构将存储器看作是从零地址开始的字节的线性组合。字节零到字节三放置第一个字(WORD),字节四到字节七存储第二个字,以此类推。
ARM 体系结构可以用两种方法存储字数据,分别称为大端格式和小端格式。
大端格式
在这种格式中,字数据的高位字节存储在低地址中,而字数据的低位字节则存放在高地址中。
小端格式
在这种格式中,字数据的高位字节存储在高地址中,而字数据的低位字节则存放在低地址中。
REALVIEW 基础知识
ENTRY
设置程序默认入口点,一个程序可有多个ENTRY,但一个源文件最多只有一个ENTRY。
EQU
EQU 伪操用于将数字常量、基于寄存器的值和程序中的标号定义为一个字符名称。语法格式:
symbol EQU expression其中,expression 可以是一个寄存器的名字,也可是由程序标号、常量或者32 位的地址常量组成的表达式。symbol 是EQU 伪操作所定义的字符名称。示例:COUNT EQU 0X1FFF
EXTERN/IMPORT
IMPORT(EXTERN 功能完全相同)用于声明在其他模块中定义但需要在本文件中使用的符号。
EXTRN 声明的变量必须是在其他模块中用EXPORT 或GLOBAL 声明过的。语法格式:IMPORT class (symbol, symbol ...)其中,class 为变量的类型,可以为ARM、CODE16、CODE32、DATA、CONST、THUMB;symbol为所声明的变量名。
EXPORT/GLOBAL
EXPORT(GLOBAL 功能完全相同)用于声明在本文件中定义但能在其他模块中使用的变量,相当于定义了一个全局变量。语法格式:EXPORT symbol, symbol...其中,symbol 为所声明的变量名。
AREA
AREA 用于定义一个代码段或数据段,ARM 汇编程序设计采用分段式设计,一个ARM 源程序至少有一个代码段,大的程序会有若干个代码段和数据段。语法格式:AREA segment-name, class-name, attributes ,...其中,segment-name 为所定义段的名称;class-name 为所定义段的类型名称,可以为系统类型(CODE, CONST, DATA, ERAM)或用户定义类型;attributes 为段的属性。
END
END 用于标记汇编文件的结束行,即标号后的代码不作处理。
实验步骤
1. 新建工程
首先在\Keil\ARM\Examples\Mini2410-IV\4.1_asm1 目录下建立文件夹命名为Asm1_a,运行
μVision3 IDE 集成开发环境,选择菜单项“Project - New…- μVision Project”,系统弹出一个对话框,输入相关内容。点击“保存”按钮,将创建一个新工程as
文档评论(0)