实验二 ARM汇编指令实验.doc
文本预览下载声明
实验二 ARM汇编指令实验
一、 实验目的
(1)学会使用μVision IDE for ARM 软件工程配置及使用方法;
(2)掌握简单ARM 汇编指令的使用方法。
二、 实验设备
(1)硬件:嵌入式实验平台一套、仿真器一个、PC机一台;
(2)软件:μVision IDE for ARM集成开发环境,Windows 98/2000/NT/XP。
三、 实验内容
(1)熟悉开发环境的使用并使用ldr/str,mov 等指令访问寄存器或存储单元;
(2)使用add/sub/lsl/lsr/and/orr 等指令,完成基本算术/逻辑运算;
(3)使用ARM指令ADD,MOV,CMP,B 编制程序计算1+2+3+…+N 的值。
四、 实验原理
ARM 处理器共有37个寄存器:
??31个通用寄存器,包括程序计数器(PC)。这些寄存器都是32 位的;
??6个状态寄存器。这些寄存器也是32 位的,但是只是使用了其中的12 位。
1. ARM通用寄存器
通用寄存器(R0-R15)可分为三类:
??不分组寄存器R0~R7;
??分组寄存器 R8~R14;
??程序计数器 PC。
(1)不分组寄存器 R0~R7
不分组寄存器R0~R7在所有处理器模式下,它们每一个都访问一样的32 位寄存器。它们是真正的通用寄存器,没有体系结构所隐含的特殊用途。
(2)分组寄存器 R8~R14
分组寄存器R8~R14对应的物理寄存器取决于当前的处理器模式。若要访问特定的物理寄存器而不依赖当前的处理器模式,则要使用规定的名字。
寄存器R8~R12 各有两组物理寄存器:一组为FIQ 模式,另一组为除了FIQ 以外的所有模式。寄存器R8~R12 没有任何指定的特殊用途,只是在作快速中断处理时使用。寄存器R13,R14 各对应6个分组的物理寄存器,1个用于用户模式和系统模式,其它5个分别用于5 种异常模式。寄存器R13 通常用做堆栈指针,称为SP;寄存器R14用作子程序链接寄存器,也称为LR。
(3)程序计数器 PC
寄存器R15 用做程序计数器(PC)。在本实验中,ARM核工作在用户模式,R0~R15 可用。
2. REALVIEW基础知识
μVision3 IDE 集成了REALVIEW汇编器AARM、编译器CARM、链接器LARM,若采用GNU编译器则需要下载安装相应的工具包。实验代码均按照REALVIEW的语法和规则来书写。关于AARM、CARM 和LARM的规范和具体使用,可参照μVision3 IDE 所带的帮助文档。这里简单介绍几个相关基本知识:
??ENTRY
设置程序默认入口点,一个程序可有多个ENTRY,但一个源文件最多只有一个ENTRY。
??EQU
EQU伪操用于将数字常量、基于寄存器的值和程序中的标号定义为一个字符名称。语法格式:
symbol EQU expression
其中,expression可以是一个寄存器的名字,也可是由程序标号、常量或者32 位的地址常量组成的表达式。symbol是EQU伪操作所定义的字符名称。示例:COUNT EQU 0X1FFF
??EXTERN/IMPORT
IMPORT(EXTERN功能完全相同)用于声明在其他模块中定义但需要在本文件中使用的符号。EXTRN声明的变量必须是在其他模块中用EXPORT或GLOBAL声明过的。语法格式:
?? I MPORT 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. 新建工程
首先建立文件夹命名为Asm1_a,运行μVision3
显示全部