- 1、本文档共8页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验二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为定义的符号。
说明:上述代码定义一个标号,它表示程序中当前的指令或数据地址。如果在程序中出现两个相同的标号,汇编器将会产生一个警告,且只有第一个标号有效。
2、GNU汇编语言伪操作
1).equ伪操作
语法:
.equ symbol,expr
expr为基于寄存器的地址值、程序中的标号、32位的地址常量或位的常量。symbol为.equ伪操作为expr定义的字符名称。
说明:该操作符为数字常量、基于寄存器的值和程序中的标号定义一个字符名称,相当于C语言中的宏定义。
示例: .equ USERMODE,0x10
2).global伪操作符
语法:
.global symbol
symbol为声明的符号的名称。它是区分大小写的。
说明:该操作符声明一个可以被其它文件引用的全局符号,相当于C语言中的全局变量。
示例:.global Main
3).text伪操作符
语法:
.text {subsection}
subsection为代码段子段,可选参数。
说明:该操作符将操作符开始的代码编译到代码段或代码段子段中。
示例:.text
4).end伪操作符
语法:
.end
说明:该操作符标记当前汇编文件的结束行,即标号后的代码不作处理。
示例:.end
5).ltorg伪操作符
语法:
.ltorg
说明:该操作符用于在当前段的当前地址产生一个文字池。
示例:.ltorg
3、存储器访问指令
1)LDR和STR指令
说明:LDR/STR指令用于加载寄存器和存储寄存器。它们的使用比较复杂,现仅列举本实验用到的一些使用方法。
示例:
LDR r3,[r0],#4 /*从r0表示的地址中读取数据到r3中,然后将r0加4*/
STR r3,[r1],#4 /*将r3中的数据保存到r1表示的地址中,然后将r1加4*/
2)LDMIA和STMIA指令
说明:LDMIA/STMIA指令用于加载多个寄存器和存储多个寄存器。它们的使用比较复杂,现仅列举本实验用到的一些使用方法。
示例:
LDMIA r0!,{r4-r11} /*从r0表示的地址中取出8个数据分别放到到r4-r11中*/
STMIA r1!,{r4-r11} /*将r4-r11中的数据保存到r1表示的起始地址中*/
4、程序分支指令
1)B指令
说明:B指令为ARM分支指令,将引起处理器转移到指定标号处执行。
示例:
B Label /*处理器转移到Label 标号处执行*/
BEQ stop /*Z标志置位则转移到stop 标号处执行,否则继续执行下一条指令*/
BNE octcopy/*Z标志清零则转移到octcopy标号处执行,否则继续执行下一条指令*/
5、其它指令
1)SUBS指令
说明:该指令由SUB指令加上S后缀组成,S后缀标志根据执行结果更新条件标志码。
示例:
SUBS r3,r3,#1
2)MOVS指令
说明:该指令由MOV指令加上S后缀组成,S后缀标志根据执行结果更新条件标志码。
示例:
MOVS r3,r2,LSR#3 /*将r2右移3位即除以8,然后赋值给r3*/
6、链接脚本文件
一个程序通过.text、.data以及.bass等伪指令设定其所属的段,其中text段为代码段,data段为已经初始化的数据段,bass段为尚未初始化的数据段。因此,程序编写好以后,必须告诉编译器怎样组织其中的各个段,各段的起始地址是多少。这些设置在软件仿真器中可能没有多少作用,但是如果该程序必须运行在具体硬件平台
文档评论(0)