ARM体系结构与编程(第2版)第4章说课.ppt

  1. 1、本文档共26页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
本章介绍如何编写ARM和Thumb汇编语言程序,同时介绍ARM汇编编译器armasm的使用方法。 * 4.1 伪 操 作 伪操作不像机器指令那样在计算机运行期间由机器执行,它是在汇编程序对源程序汇编期间由汇编程序处理的。宏是一段独立的程序代码。在程序中通过宏指令调用该宏。当程序被汇编时,汇编程序将对每个宏调用进行展开,用宏定义体取代源程序中的宏指令。本节介绍以下类型的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的浮点寄存器定义名称。 * 4.1.2 数据定义伪操作 数据定义(Data Definition)伪操作包括以下具体的伪操作。 LTORG:声明一个数据缓冲池(Literal Pool)的开始。 MAP:定义一个结构化的内存表(Storage Map)的首地址。 FIELD:定义结构化的内存表中的一个数据域(Field)。 SPACE:分配一块内存单元,并用0初始化。 DCB:分配一段字节的内存单元,并用指定的数据初始化。 DCD及DCDU:分配一段字的内存单元,并用指定的数据初始化。 DCDO:分配一段字的内存单元,并将各单元的内容初始化成该单元相对于静态基值寄存器的偏移量。 * 4.1.2 数据定义伪操作 DCFD及DCFDU:分配一段双字的内存单元,并用双精度的浮点数据初始化。 DCFS及DCFSU:分配一段字的内存单元,并用单精度的浮点数据初始化。 DCI:分配一段字节的内存单元,用指定的数据初始化,指定内存单元中存放的是代码,而不是数据。 DCQ及DCQU:分配一段双字的内存单元,并用64位的整数数据初始化。 DCW及DCWU:分配一段半字的内存单元,并用指定的数据初始化。 DATA:在代码段中使用数据。现已不再使用,仅用于保持向前兼容。 * 4.1.3 汇编控制伪操作 汇编控制(Assembly Control)伪操作包括下面的伪操作: IF、ELSE及ENDIF WHILE及WEND MACRO及MEND MEXIT * 4.1.4 数据帧描述伪操作 栈中数据帧描述伪操作主要用于调试,这里不介绍这部分内容。感兴趣的读者可以参考ARM的相关资料。 * 4.1.5 信息报告伪操作 信息报告(Reporting)伪操作包括下列具体的伪操作: ASSERT INFO OPT TTL及SUBT * 4.1.6 其他的伪操作 这些杂类的伪操作包括: CODE16及CODE32 EQU AREA ENTRY END ALIGN EXPORT或GLOBAL IMPORT EXTERN GET或INCLUDE * 4.1.6 其他的伪操作 INCBIN KEEP NOFP REQUIRE REQUIRE8及PRESERVE8 RN ROUT * 4.2 ARM汇编语言伪指令 ARM中伪指令不是真正的ARM指令或者Thumb指令,这些伪指令在汇编编译器对源程序进行汇编处理时被替换成对应的ARM或者Thumb指令(序列)。ARM伪指令包括ADR、ADRL、LDR和NOP。 1. ADR (小范围的地址读取伪指令) 2.??ADRL(中等范围的地址读取伪指令) 3.??LDR大范围的地址读取伪指令 4.??NOP 空操作伪指令 * 4.3 ARM汇编语言语句的格式 ARM汇编语言语句格式如下: {symbol} {instruction|directive|pseudo-instruction} {; comment} 其中的符号及参数说明如下: instruction为指令。在ARM汇编语言中,指令不能从一行的行头开始。在一行语句中,指令的前面必须有空格或者符号。 directive为伪操作。 pseudo-instruction为伪指令。 symbol为符号。在ARM汇编语言中,符号必须从一行的行头开始,并且符号中不能包含空格。在指令和伪指令中,符号用作地

文档评论(0)

4477769 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档