实验二_ARM汇编语言程序设计

合集下载

基于arm的汇编实验报告

基于arm的汇编实验报告

竭诚为您提供优质文档/双击可除基于arm的汇编实验报告篇一:汇编实验报告实验一(1)熟悉汇编语言程序调试环境及顺序程序设计一、实验目的及要求:1.学习及掌握汇编语言源程序的书写格式和要求,明确程序中各段的功能和相互之间的关系。

2.学会使用eDIT、mAsm、LInK、Debug等软件工具。

3.熟练掌握在计算机上建立、汇编、连接、调试及运行程序的方法。

二、熟悉汇编语言程序调试环境1.汇编语言源程序的建立本例中给出的程序是要求从内存中存放的10个无符号字节整数数组中找出最小数,将其值保存在AL寄存器中。

设定源程序的文件名为Abc。

DATAsegmenTbuFDb23h,16h,08h,20h,64h,8Ah,91h,35h,2bh,7Fh cneQu$-buFDATAenDscoDesegmenTAssumecs:coDe,Ds:DATAsTART:pushDsxoRAx,AxpushAxmoVAx,DATAmoVDs,AxmoVbx,oFFseTbuFmoVcx,cnDeccxmoVAL,[bx]IncbxLp:cmpAL,[bx]JbenexTmoVAL,[bx]nexT:IncbxDeccxJnZLpmoVAh,4chInT21hcoDeenDsenDsTART键入以下命令:c:\>eDITAbc.Asm此时屏幕的显示状态如图1所示。

1图1用eDIT编辑Abc.Asm程序窗口程序输入完毕后一定要将源程序文件存入盘中,以便进行汇编及连接,也可以再次调出源程序进行修改。

2.将源程序文件汇编成目标程序文件一般情况下,mAsm汇编程序的主要功能有以下3点:(1)检查源程序中存在的语法错误,并给出错误信息。

(2)源程序经汇编后没有错误,则产生目标程序文件,扩展名为.obJ。

(3)若程序中使用了宏指令,则汇编程序将展开宏指令。

源程序建立以后,在Dos状态下,采用宏汇编程序mAsm 对源程序文件进行汇编,其操作过程如图2所示。

ARM汇编语言程序设计

ARM汇编语言程序设计

是由物理寄存器r1来存放r0所代表的值。
Chavezwang@
计算机学院嵌入式实验室
19
北京理工大学珠海学院
嵌入式系统设计及应用开发
内联汇编中虚拟寄存器举例
int main(void) #include <stdio.h> void test_inline_register(void) { int i; int r5,r6,r7; __asm { MOV i,#0 loop: MOV r5,#0 MOV r6,#0 MOV r7,#0 ADD i,i,#1 CMP i,#3 BNE loop } }
北京理工大学珠海学院
嵌入式系统设计及应用开发
何时使用内联汇编和嵌入型汇编

程序中使用饱和算术运算(Saturating arithmetic),如SSAT16 和 USAT16指令。

程序中需要对协处理器进行操作。 在C或C++程序中完成对程序状态寄存器的操作
注:使用内联汇编编写的程序代码效率也比较高
③ 不能在程序中使用“.”或{PC}得到当前指令地址值。
④ 在16进制常量前加“0x”。
⑤ 建议不要对堆栈进行操作。
Chavezwang@
计算机学院嵌入式实验室
16
北京理工大学珠海学院
嵌入式系统设计及应用开发
内联汇编的限制2
⑥ 编译器可能会使用r12和r13寄存器存放编译的中间结果, 在计算表达式值可能会将寄存器r0~r3、r12及r14用于子程 序调用。另外在内联汇编中设置程序状态寄存器CPSR中的 标志位NZCV时,要特别小心。内联汇编中的设置很可能会 和编译器计算的表达式的结果冲突。
编译器使用一套规则的来设置寄存器的用法

第4章ARM汇编语言程序设计.

第4章ARM汇编语言程序设计.

第4章ARM汇编语言程序设计本章介绍如何编写ARM和thumb汇编语言程序。

同时介绍ARM汇编编译器armasm的使用方法。

4.1伪操作ARM 汇编语言源程序中语句由指令、伪操作和宏指令组成。

在ARM中伪操作称为derective,这里为保持和国内在IBM PC汇编语言中对名词翻译的一致性derective称为伪操作;同样在ARM中宏指令被称为pseudo-instructlon,这里将其称为宏指令,宏指令也是通过伪操作定义的。

本节介绍伪操作和宏指令。

伪操作不像机器指令那样在计算机运行期间由机器执行,它是在汇编程序肘源程序汇编期间由汇编程序处理的。

宏是一段独立的程序代码。

在程序中通过宏指令调用该宏。

当程序被汇编时,汇编程序将对每个宏调用作展开,用宏定义体取代源程序中的宏指令。

本节介绍以下类型的ARM伪操作和宏指令。

●符号定义(Symbol definition伪操作。

●数据定义(Data definition)伪操作。

●汇编控制(Assembly control)伪操作。

●框架描述(Frame description)伪操作。

●信息报告(Reporting)伪操作。

●其他(Miscellaneous)伪操作。

4.1.1符号定义伪操作符号定义(Symbol definition)伪操作用于定义ARM汇编程序中的变量,对变量进行赋值以及定义寄存器名称。

包括以下伪操作。

●GBLA、GBLL及GBLS声明全局变量。

●LCLA.LcLL及LCLS 声明局部变量。

●SETA.SETL及SETS 给变量赋值。

●RLIST为通用寄存器列表定义名称。

●CN为协处理器的寄存器定义名称。

●CP为协处理器定义名称。

●DN及SN为VFP的寄存器定义名称。

FN为FPA的浮点寄存器定义名称。

1 GBLA GBLL及GBLSGBLA GBLL及GBLS伪操作用于声叫个ARM程序中的全局变量,并将其初始化。

GBLA伪操作声明一个全局的算术变量,并将其初始化成0。

02实验二 ARM汇编语言程序设计

02实验二 ARM汇编语言程序设计

实验二 ARM汇编语言程序设计一、实验目的1.了解ARM汇编语言的基本框架,学会使用ARM的汇编语言编程2.掌握ARM汇编指令二、实验设备1. EL-ARM-830教学实验箱,PentiumII以上的PC机,仿真器电缆。

2. PC操作系统WIN98或WIN2000或WINXP, ADS1.2集成开发环境,仿真器驱动程序。

三、汇编语言简介1.ARM汇编的一些简要的书写规范ARM汇编中,所有标号必须在一行的顶格书写,其后面不要添加“:”,而所有指令均不能顶格书写。

ARM汇编对标识符的大小写敏感,书写标号及指令时字母大小写要一致。

在ARM汇编中,ARM指令、伪指令、寄存器名等可以全部大写或者全部小写,但不要大小写混合使用。

注释使用“;”号,注释的内容由“;”号起到此行结束,注释可以在一行的顶格书写。

详细的汇编语句及规范请参照ARM汇编的相关书籍、文档。

2. ARM汇编语言程序的基本结构在ARM汇编语言程序中,是以程序段为单位来组织代码。

段是相对独立的指令或数据序列,具有特定的名称。

段可以分为代码段的和数据段,代码段的内容为执行代码,数据段存放代码运行时所需的数据。

一个汇编程序至少应该有一个代码段,当程序较长时,可以分割为多个代码段和数据段,多个段在程序编译链接时最终形成一个可执行文件。

可执行映像文件通常由以下几部分构成:◆一个或多个代码段,代码段为只读属性。

◆零个或多个包含初始化数据的数据段,数据段的属性为可读写。

◆零个或多个不包含初始化数据的数据段,数据段的属性为可读写。

链接器根据系统默认或用户设定的规则,将各个段安排在存储器中的相应位置。

源程序中段之间的相邻关系与执行的映象文件中的段之间的相邻关系不一定相同。

3. 简单的小例子下面是一个代码段的小例子AREA Init,CODE,READONLYENTRYLDR R0, =0x3FF5000LDR R1, 0x0fSTR R1, [R0]LDR R0, =0x3F50008LDR R1, 0x1STR R1, [R0]……END在汇编程序中,用AREA指令定义一个段,并说明定义段的相关属性,本例中定义了一个名为Init的代码段,属性为只读。

第四章_ARM指令系统实验

第四章_ARM指令系统实验

第四章ARM指令系统实验实验一、ARM汇编语言程序实验一、实验目的1.掌握ARM7TDMI汇编语言指令的用法,能编写简单的ARM汇编语言程序。

2.掌握指令的条件执行和使用LDR/STR指令完成存储器的访问。

二、实验设备硬件:PC机软件:Windows98/XP/2000系统,ADS1.2集成开发环境三、实验内容使用LDR指令读取0x400031000上的数据,将数据加1,若结果小于10,则使用STR指令把结果写回原地址,若结果大于等于10,则把0写回原地址。

使用ADS1.2软件仿真,单步、全速运行程序,设置断点,打开寄存器窗口(Processor Registers )监视R0、R1的值,打开存储器窗口(Memory )监视0x400031000的值。

四、实验预习要求1.仔细阅读教材第四章中ARM指令系统的内容;2.熟悉ADS1.2工程编辑和AXD调试的内容。

五、实验步骤1.启动ADS1.2,使用ARM Executable Image工程模板建立一个工程,工程名称ADS2。

2.建立ARM汇编源程序LJZ2.S,编写实验程序,然后添加到工程中。

3.设置工程连接地址RO Base 为0x400000000,RW Base 为0x400030000。

设置调试入口地址Image entry point 为0x400000000。

4.编译连接工程,选择[Project]-〉[Debug],启动AXD进行软件仿真调试。

5.打开寄存器窗口((Processor Registers )选择Current项监视R0、R1的值,打开存储器窗口(Memory )设置观察地址为0x400031000,显示方式Size为32位,监视0x400031000的值。

6.可以单步运行程序,可以设置断点/取消断点,或者全速运行程序,停止程序运行,调试时观察寄存器和0x400031000的值,运行结果分别如图4-1到4-7所示。

图4-1 Memory 窗口设置图4-2 Memory 窗口显示格式设置图4-3 Register 窗口设置图4-4 单步调试开始窗口画面图4-5 单步调试第一循环画面图4-6 单步调试第三循环画面图4-7 单步调试第十次循环结果六、实验参考程序程序清单4-1 ARM指令实验程序LJZ2.S; 文件名:LJZ2.S; 功能:使用LDR、STR指令对变量NumCount进行加1操作; 说明:使用ARMulate软件仿真调试NumCount EQU 0x40003100 ; 定义变量NumCountAREA Example2,CODE,READONLYENTRYMAIN LDR R1,=NumCount ;使用LDR伪指令装载NumCount的地址;到R0。

ARM汇编语言程序设计

ARM汇编语言程序设计
13
使用局部标号的例子:
例1 无作用范围字符 01 SUBS r0,r0,#1
BNE %B 01
;每次循环使r0=r0-1 ;跳转到01标号去执行
例2 作用范围字符为NAME
ROUT NAME
; NAME作用范围
01NAME SUBS r0,r0,#1
;每次循环使r0=r0-1
BNE %B 01NAME ;跳转到01NAME标号去执行
Labeladd add r0,r0,r1
;
Str1
SETS
“This is a string.”
BKPT ;断点
标签: welcomefun , strarm , Labeladd, Str1
指令/伪操作/伪指令: STMFD , DCB , add , SETS
操作数:其他部分
9
注意: ARM程序中,指令、伪指令、伪操作、寄存 器助记符可以全部为大写或小写,但大小写不能混合 使用。
; “Welcom to ARM world!”字符串
LDMFD
sp!,{pc}
;恢复寄存器值
7
Adrstrarm ;adrstrarm标签
DCD strarm ;保存strarm的地址
AREA constdatasec, DATA, READONLY,ALIGN=0
;数据段,名称为constdatasec, 属性为只读
ENDP ;函数main结束
EXPORT main
;导出main函数供外部调用
;引入三个C运行时库函数和ARM库
IMPORT _main
IMPORT __main
IMPORT _printf
IMPORT ||Lib$$Request$$armlib||, WEAK

第3章ARM汇编语言程序设计

第3章ARM汇编语言程序设计

2.局部变量定义伪操作LCLA、LCLL和LCLS
(1)语法格式 LCLA、LCLL和LCLS伪指令用于定义一个 ARM程序中的局部变量并将其初始化。 语法格式如下: <lclx> <variable> (2)使用说明 (3)示例
3.变量赋值伪操作SETA、SETL和SETS
(1)语法格式 伪指令SETA、SETL和SETS用于给一个已 经定义的全局变量或局部变量赋值。 语法格式如下: Variable <setx> expr (2)使用说明 (3)示例
(2)用于定义局部变量的LCLA、LCLL和 LCLS。
(3)用于对变量赋值的SETA、SETL和 SETS。
(4)为通用寄存器列表定义名称的RLIST。
1.全局变量定义伪操作GBLA、GBLL和GBLS
(1)语法格式 GBLA、GBLL和GBLS伪操作用于定义一个 ARM程序中的全局变量并将其初始化。 语法格式如下: <gblx> <variable> (2)使用说明 (3)示例
4.通用寄存器列表定义伪操作RLIST
(1)语法格式 RLIST伪操作可用于对一个通用寄存器列 表定义名称,使用该伪操作定义的名称可在 ARM指令LDM/STM中使用。 语法格式如下: Name RLIST {list-of-registers} (2)使用说明 (3)示例
3.2.3 数据定义(Data Definition)伪操作
{label} DCFS{U} fpliteral{,fpliteral}
(2)使用说明 (3)示例
5.DCFD(或DCFDU)
(1)语法格式 DCFD(或DCFDU)伪指令用于为双精度
的浮点数分配一片连续的字存储单元并用伪指 令中指定的表达式初始化。

嵌入式实验报告

嵌入式实验报告

实验一 ARM汇编语言程序设计一、实验目的1.了解IAR Embedded Workbench 集成开发环境2.掌握ARM汇编指令程序的设计及调试二、实验设备1.PC操作系统WIN98或WIN2000或WINXP,ADSI.2集成开发环境,仿真驱动程序三、实验内容1.熟悉IAR Embedded Workbench 集成开发环境2.理解下列程序,新建工程,加入下面的程序,并观察实验结果,解释程序实现的功能分析:该程序实现的功能是程序功能:Y = A*B+C*D+E*F程序代码:AREA Examl, CODE,READONLY ;定义一个代码段ENTRY ;程序入口MOV R0,#0;设置R0寄存器的值为0MOV R8,#0;设置R8寄存器的值为0ADR R2,N;将R2寄存器的值设为数据域N的地址LDR R1,[R2];将以R2的值为地址的数据读入R1MOV R2,#0;设置R2的值为0ADR R3,C; 将R3寄存器的值设为数据域C的地址ADR R5,X; 将R5寄存器的值设为数据域X的地址LOOPLDR R4,[R3,R8];将R3+R8的数据读入R4LDR R6,[R5,R8];将R5+R8的数据读入R6MUL R9,R4,R6;R9 = R4*R6ADD R2,R2,R9;R2 = R2+R9ADD R8,R8,#4;R8 = R8+4ADD R0,R0,#1;R0 = R0+1CMP R0,R1;比较R0和R1的值BLT LOOP;R0<R1的话执行循环N DCD 0X03;C DCD 0X01,0X02,0X03,0X04,0X05,0X06;X DCD 0X01,0X02,0X03,0X04,0X05,0X06;END程序结果:各个寄存器的结果执行结果如下:3.实现1+2+3+4+····+100,求的值,并保存在地址0x90018的地址里面程序代码:MOV R0,#100;设置R0寄存器的值为100LDR R2,=0X90018;设置R2寄存器指向地址0x90018MOV R1,#0;设置R1的值为0MOV R3,#0;设置R3的值为0LOOPADD R3,R3,R0;R3 = R3+R0SUB R0,R0,#1;R0 = R0-1CMP R0,R1;将R0和R1的值比较BNE LOOP;不相等的话继续执行循环STR R3,[R2];将R3的值装入到R2指向的地址块中。

arm实验汇编语言编程技巧实验.

arm实验汇编语言编程技巧实验.

大连理工大学软件学院《嵌入式系统结构》实验报告组号: 552 实验箱编号: 21008552实验时间: 12 年10 月 11日实验室:嵌入式实验室实验台:Embest Edukit-III平台指导教师:邱铁成绩:实验2:汇编语言编程技巧实验一、实验目的和要求通过本次实验对ARM汇编语言编程的技巧进行训练,提高编写代码的速度与效率。

二、实验原理和内容1. 编写程序实现20!,将得到的64位结果送入[R9:R8]中。

原理:由1开始64位累乘(UMULL),高位存于R9中,低位存于R8中,每次用乘数对R8内数进行64位乘法,对R9进行普通乘法将R9乘后的值与原值相加继续存于R9,累乘20次。

2. 判断下列情况是否能够实现:如果能实现请写出程序代码1N=1,C=1,V=12N=0,C=1,V=13N=1,C=0,V=14Z=1,C=1,V=1原理:算数,逻辑等运算出的结果对标志位的影响3. 实现寄存器的高位和低位的互换,例如第0位和第31位互换……。

原理:R1内存有原值,每次让其与上#1得到最后一位的值,若为1则在原为空的R4的相应位上赋值1,之后R1右移一位,重复操作。

三、主要仪器设备及软件编程环境主要仪器设备:PC机软件编程环境:Embest IDE 2004集成开发环境,Windows 98/2000/NT/XP四、实验步骤与编程第一题:.global _start.text_start:MOV R9,#0MOV R8,#1MOV R0,#2MOV R1,#0mov r2,#0LOOP:UMULL R2,R1,R8,R0 MOV R8,R2MLA R9,R0,R9,R1 ADD R0,R0,#1CMP R0,#21BNE LOOPEND:B END.END第二题:.global _start.text_start:MOV R9,#0MOV R8,#0MOV R7,#1MOV R0,#2MOV R1,#0MOV R2,#0MOV R3,#0UMULL R2,R1,R7,R0 MOV R7,R2UMULL R3,R2,R8,R0 ADDS R8,R3,R1MUL R9,R0,R9ADC R9,R9,R2ADD R0,R0,#1CMP R0,#24BNE LOOPEND:B END.END第三题:(1).global _start.text_start:MOV R0,#0X80000000 ADDS R1,R0,#0X80000000 TEQ R0,#0X12B END.END(3).global _start.text_start:MOV R0,#-0XBFFFFFFF MOV R1,#-0XBFFFFFFF ADDS R2,R1,R0 END:B END.END(2)(4).global _start.text_start:MOV R0,#1MOV R1,#1MOV R0,R0,ROR #1 MOV R1,R1,ROR #1 ADDS R2,R1,R0 END:B END第四题:.global _start.text_start:LDR R0,=0x55555555 MOV R2,#1MOV R3,#32MOV R8,#1MOV R9,#0MOV R10,#2MOV R5,#1LOOP1:MOV R1,R0AND R1,R1,R8 MOV R6,R5LOOP2:MOV R1,R1,ROR #1 SUBS R6,R6,R2 BNE LOOP2ADD R5,R5,R10 ORR R4,R4,R1 MOV R8,R8,LSL #1 SUBS R3,R3,R2 BNE LOOP1 END:B END.END。

ARM汇编语言程序设计教学学习教案

ARM汇编语言程序设计教学学习教案
➢ 标号域用来表示指令的地址、变 量、过程名、数据的地址和常量。
➢ 标号是一个自行设计的标识符或 名称,语句标号可以是大小写字 母混合,通常以字母开头,由字 母、数字(shùzì)、下划线等组成。
➢ 语句标号不能与寄存器名、指令 助记符、伪指令(操作)助记符、 变量名同名。
➢ 语句标号必须第8页在/共164一页 行的开头书写, 不能留空格。

8_24第175页表/共16示4页 一个八进制数。
➢ ASCII的表示:有些值可以使用
第十六页,共164页。
➢ 逻辑常量只有两种取值情况: {TRUE}和{FALSE},注意带大 括号。
➢ 字符串常量为一个固定的字符 串,一般(yībān)用于程序运行时 的信息提示。
➢ 字符常量由单引号表示,包括C 语言中的转义字符,如’\n’。
常见的符号定义伪操作有如下(rúxià) 几种:
GBLA、GBLL、GBLS LCLA、LCLL和LCLS
第20页/共164页
SETA、SETL、SETS
第二十一页,共164页。
1. 全局变量声明(shēngmíng)GBLA、 GBLL和GBLS
格 式:GBLA(GBLL或GBLS)全局变量名 功 能:GBLA、GBLL和GBLS伪操作用于定义一个ARM程序中
第3页/共164页
第四页,共164页。
4.1.1汇编语言(huì biān yǔ yán)的基本概念
第4页/共164页
第五页,共164页。
4.1.2汇编语言(huì biān y1.ǔ 汇yá编n语)源言(程huì序biā的n yǔ组yá成n)源程
序的结构
AREA Init,CODE, READONLY
LCLS Test6 ;定义一个局部的字符串变量,变量 名为Test6 Test6 SETS “Testing” ;将该变量赋值为“Testing”

ARM汇编语言程序设计

ARM汇编语言程序设计

ARM 指令系统
4.1.1 符号定义伪指令
常见的符号定义伪指令有如下几种:
— 用于定义全局变量的GBLA、GBLL和GBLS。 — 用于定义局部变量的LCLA、LCLL和LCLS。 — 用于对变量赋值的SETA、SETL、SETS。 — 为通用寄存器列表定义名称的RLIST。
1、 GBLA、GBLL和GBLS
表达式的值为当前数据域在内存表 中所占的字节数。
FIELD伪指令常与MAP伪指令配合使用来定义结
构 化 的 内 存 表 。 MAP 伪 指 令 定 义 内 存 表 的 首 地 址 , FIELD伪指令定义内存表中的各个数据域,并可以为 每个数据域指定一个标号供其他的指令引用。
注意 MAP和FIELD伪指令仅用于定义数据结
DCD(DCDU)用于分配一片连续的字存储单元并 用指定的数据初始化。
SPACE 用于分配一片连续的存储单元
MAP 用于定义一个结构化的内存表首地址
FIELD 用于定义一个结构化的内存表的数据域
1、 DCB(DCB也可用“=”代替)
语法格式: 标号 DCB 表达式
DCB伪指令用于分配一片连续的字节 存储单元并用伪指令中指定的表达式初 始化。其中,表达式可以为0~255的数 字或字符串。
HandleReserved # 4
HandleIRQ
#4
HandleFIQ
#4
ARM 指令系统
4.1.3 汇编控制伪指令
汇编控制伪指令用于控 制汇编程序的执行流程
常用的汇编控制伪指令包括 : — IF、ELSE、ENDIF — WHILE、WEND — MACRO、MEND — MEXIT
1 IF、ELSE、ENDIF (等价于[ | ] )

ARM汇编语言程序设计

ARM汇编语言程序设计

DCB
语法格式: {标号} DCB 体现式
体现式取值范围:-128~255旳数字或字符串。 DCB:“=”
Nullstring DCB “Null string”,0 ;构造一种以0结尾旳字符串
DCW(或DCWU)
语法格式: {标号} DCW(或DCWU) 体现式
DCW:半字对齐 DCWU:不严格半字对齐。 体现式取值范围:-32768~65535
SPACE objectsize
;全局旳数字变量objectsize ,为0 ;将该变量赋值为0xff ;引用该变量
statusB
GBLL statusB ;全局旳逻辑变量statusB ,为{False} SETL {TRUE} ;将该变量赋值为真
全局:作用范围为包括该变量旳源程序
LCLA、LCLL和LCLS
;包括源文件file1.s ;包括源文件file2.s ;包括源文件file3.s
伪指令
ADR ADRL LDR NOP
ADR-小范围旳地址读取伪指令
语法格式 ADR{cond} register, expr cond:可选旳指令执行条件 register:目旳寄存器 expr:基于PC或寄存器旳地址体现式,取值范围: 地址非字对齐,-255~255 地址字对齐,-1020~1020
{寄存器列表}
Context RLIST {r0-r6,r8,r10-r12,r15}
;将寄存器列表名称定义为Context ,可在ARM指令 LDM/STM中经过该名称访问寄存器列表。排列顺序无 关
数据定义伪操作
DCB DCW(DCWU) DCD(DCDU) DCFD(DCFDU) DCFS(DCFSU) SPACE MAP FIELD

实验二 ARM汇编语言编程实验.doc

实验二 ARM汇编语言编程实验.doc

实验二:ARM 汇编语言编程实验一、实验目的1、掌握ADT IDE ARM 开发环境中基本的工程设置以及程序编译方法。

2、掌握ADT IDE ARM 开发环境中基本的程序调试方法。

3、掌握基本的ARM 汇编语言编程方法。

二、实验内容用汇编语言编写一个程序实现如下目的:从源地址拷贝num 个字(num*4个字节)的数据到目的地址dst 中。

三、预备知识1、ARM 汇编语言的基础知识。

2、程序调试的基础知识和方法。

四、实验设备1、硬件:JXARM9-2440教学实验箱、PC 机。

2、软件:PC 机操作系统Windows 98(2000、XP)+ADT IDE 开发环境。

五、基础知识ADT IDE 集成了GNU 汇编器arm-elf-as 、编译器arm-elf-gcc 和链接器arm-elf-ld 。

在ADT IDE 中编写的程序必须符合GNU 的语法规则。

下面介绍一些基本的GNU 汇编知识以及本实验用到的ARM 汇编指令。

1、GUN 汇编语言语法及规则1)_start_start 为程序默认入口点,代码段默认起始地址为0x800,如果需要修改可以在链接脚本文件中指定。

2)标号语法:symbol:symbol 为定义的符号。

说明:上述代码定义一个标号,它表示程序中当前的指令或数据地址。

如果在程序中出现两个相同的标号,汇编器将会产生一个警告,且只有第一个标号有效。

课程名称 ARM 体系结构 实验成绩 指导教师 冯灵霞实 验 报 告 院系 信息工程学院班级计算机科学与技术(嵌入式) 学号 姓名 日期2、GNU汇编语言伪操作1).equ伪操作语法:.equ symbol,exprexpr为基于寄存器的地址值、程序中的标号、32位的地址常量或位的常量。

symbol为.equ 伪操作为expr定义的字符名称。

说明:该操作符为数字常量、基于寄存器的值和程序中的标号定义一个字符名称,相当于C语言中的宏定义。

示例:.equ USERMODE,0x102).global伪操作符语法:.global symbolsymbol为声明的符号的名称。

ARM实验报告综合实验

ARM实验报告综合实验

ARM实验报告综合实验摘要:ARM微处理器已经在各种电子产品中得到广泛应用。

本实验旨在通过对ARM实验板的详细学习,深入理解和掌握ARM微处理器的工作原理及应用。

通过搭建实验平台,完成基本的指令执行、数据传输和I/O操作等功能。

通过实验,掌握ARM汇编语言的基本语法和实现方法,同时提升对嵌入式系统的理解和应用能力。

关键词:ARM微处理器、实验平台、指令执行、数据传输、I/O操作、汇编语言1.引言ARM(Advanced RISC Machines)微处理器是一种精简指令集(RISC)的微处理器架构,以其高性能、低功耗和广泛应用等特点受到了广泛的关注和应用。

本实验旨在通过对ARM实验板的学习和研究,深入理解ARM微处理器的工作原理和应用。

2.实验目的2.1理解ARM微处理器的工作原理;2.2掌握ARM汇编语言的基本语法和实现方法;2.3学习搭建实验平台,完成指令执行、数据传输和I/O操作等功能;2.4提升对嵌入式系统的理解和应用能力。

3.实验内容3.1搭建实验平台3.2学习ARM汇编语言通过阅读相关资料,了解ARM汇编语言的基本语法和寄存器等特点,了解ARM微处理器的指令集和指令执行方式。

3.3编写实验程序根据实验指导书中的要求,编写实验程序,包括基本的指令执行、数据传输和I/O操作等功能实现。

3.4调试和测试经过编写程序后,需要进行调试和测试,确保程序能够正确执行,并达到预期的功能。

4.实验结果通过实验,成功搭建了ARM实验平台,并且实现了基本的指令执行、数据传输和I/O操作等功能。

通过对ARM汇编语言的学习和实践,掌握了其基本语法和实现方法。

5.结论本实验通过对ARM实验板的学习和研究,深入理解了ARM微处理器的工作原理和应用。

通过搭建实验平台和编写实验程序,进一步掌握了ARM 汇编语言的基本语法和实现方法。

通过调试和测试,验证了程序的正确性和功能实现。

通过本实验,提升了对嵌入式系统的理解和应用能力。

汇编语言程序设计 基于arm体系结构 pdf

汇编语言程序设计 基于arm体系结构 pdf

汇编语言程序设计基于arm体系结构pdf1. 引言1.1 概述汇编语言程序设计是计算机科学中重要的一环,它提供了对底层硬件的直接控制能力。

在这个数字化时代,我们生活在嵌入式系统和移动设备无处不在的时代。

ARM体系结构作为一种广泛应用于嵌入式系统和移动设备中的处理器架构,需求人员必须具备ARM汇编语言的基本开发技巧。

1.2 文章结构本文将深入探讨ARM体系结构下汇编语言程序设计的基础知识及其实践应用。

文章分为五个主要部分:- ARM体系结构概述:简要介绍ARM体系结构的发展历程、关键特点以及应用领域。

- 汇编语言基础知识:详细讲解ARM汇编语言中数据类型与运算指令、寄存器与内存访问、分支和循环指令等基本概念。

- ARM汇编语言程序设计实例解析:通过实例解析阐述ARM汇编语言程序结构与组成部分、寄存器使用示范以及内存访问案例分析等内容。

- 实践应用与未来展望:分享ARM汇编语言在嵌入式系统开发中的应用实例,并展望ARM技术的发展趋势和面临的挑战。

- 总结与建议:对文章进行总结,并给出学习ARM汇编语言程序设计的建议。

1.3 目的本文旨在帮助读者全面了解ARM体系结构下汇编语言程序设计的基本原理和操作方法。

通过学习此类知识,读者可以掌握ARM汇编语言的核心概念和技巧,提升在嵌入式系统、移动设备等领域中的开发能力。

同时,本文也将分享一些实践经验和未来发展趋势,为读者提供更多参考和启示。

无论是初学者还是有一定经验的开发人员,都可以从本文中获益并得到有益的指导。

2. ARM体系结构概述:2.1 发展历程:ARM(Advanced RISC Machine)体系结构起源于上世纪80年代末,最初由英国公司Acorn Computer开发。

早期的ARM处理器主要用于个人电脑领域。

随着技术的不断进步和市场需求的扩大,ARM逐渐应用于各种移动设备和嵌入式系统中,并取得了巨大成功。

2.2 关键特点:ARM体系结构有一些关键特点使其在市场上受到广泛认可。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验二ARM汇编语言程序设计
实验目的
1、了解ARM汇编语言程序的结构特点
2、了解ARM汇编语言程序的编写方法
3、掌握用ARM汇编语言设计简单程序
实验仪器设备及软件
ARM实验箱,计算机,ADS程序开发软件
实验原理
1、存储空间的格式
ARM920将存储空间视为从0开始由字节组成的线性集合,字节0-3中保存了第一个字,字节4-7中保存了第二个字,依此类推。

字节还可以按小端格式或大端格式排列。

ARM实验箱中存储器的配置见附录C。

2、ARM的寄存器
ARM状态下任何时刻都可以看到16个通过寄存器(r0-r15),1或2个状态寄存器(CPSR,SPSR),在特权模式下会切换到具体模下的寄存器组。

每个寄存器都是32位的,并且每个通用寄存器都可以作为数据处理的源数据或目标数据寄存器。

因此可以编写出更精简的程序。

3、ARM指令的条件执行
状态寄存器中的N,Z,C,V是数据处理指令影响的标志。

几乎每条ARM指令可以根据状态位或状态位的逻辑运算有条件执行。

条件执行的指令后缀参考教材。

4、桶形移器
ARM的桶形移位器,使ARM指令的中第二个操作数非常录活。

利用移位器,一条ARM 指令可以完成更多功能。

移位操作有:
LSL 逻辑左移
LSR 逻辑右移
ASL 算术左移
ASR 算术右移
ROR 循环右移
RRX 带扩展循环右称
实验内容
1、把内存中ramaddr开始的ramword个字清零
(1)用后变址法
ramaddr equ 0x31000000
ramword equ 64
clrram
mov r0,#0
mov r1,#ramword
ldr r2,=ramaddr
clrram1
str r0,[r2],#4
subs r1,r1,#1
bne clrram1
mov pc,lr
LTORG
(2)用前变址法
clrrambak
mov r0,#0
mov r1,#ramword
ldr r2,=ramaddr-4
clrram2
str r0,[r2,#4]!
subs r1,r1,#1
bne clrram2
mov pc,lr
LTORG
2、把寄存器中,r0-r12的32位无符号32位数进行求和,和的低32位保存在r1中,高32位保存在r0中。

add13b
adds r1,r0,r1
mov r0,#0
adc r0,r0,#0
adds r1,r1,r2
adc r0,r0,#0
adds r1,r1,r3
adc r0,r0,#0。

mov pc,lr
以上程序在主程序完成初始化后调后。

打开寄存器,内存窗口等,观察程序执行前后的变化,及执行过程中的一些状态,并记录。

实验步骤
1、打开超级终端
2、打开H-JTAG,搜索ARM,
3、在D:\ARM\arm2中打开asm2.mcp文件进入metrowerks codeWarrior forARM Developer
Suite V1.2中,点击Debug开始编译。

4、编译成功后进入AXD环境中,要先将超级终端进入Vivi环境中,再点击options,并点
击configure Target,进行设置。

点击Add添加C:\Program Files中点击H-JTAG文件夹中打开H-JTAG.dll。

然后点击OK。

5、在2410INT.S文件中设置断点(位置“;//呼叫主应用程序 b Main ”),然后点击
Processor V iews,选择Register和Memory两个。

单步执行时跳入aa.s文件。

在Memory Start address中输入0x31000000.此时,进行清零
把0x31000000开始的内存256字节清零。

6.单步执行时,可以清楚的看到Memory中每当执行完str r0,[r2],就有四个字节(32位)的数据被清理。

直到清零256个字节。

7、调试完毕,整理实验箱,并放回原位。

实验程序及调试过程
实验思考题
1、在子程序调用时,子程序的下一条语句的地址保存在哪里?
2、编写程序计算r0-r12中16位二进制无符号数的和,每个寄存器中保存两个16位二进制无符号数。

答:1、在子程序调用时,子程序的下一条语句的地址保存在r0=0x310001594。

相关文档
最新文档