ARM汇编伪指令与伪操作.ppt_第1页
ARM汇编伪指令与伪操作.ppt_第2页
ARM汇编伪指令与伪操作.ppt_第3页
ARM汇编伪指令与伪操作.ppt_第4页
ARM汇编伪指令与伪操作.ppt_第5页
已阅读5页,还剩48页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

6.1汇编语言伪指令,ARM汇编器支持ARM伪指令,伪指令可以像其它ARM指令一样使用,这些伪指令在汇编阶段被翻译成ARM或者Thumb指令(或指令序列)。ARM伪指令包含LDR、ADRL、ADR、NOP等。,注意:ARM伪指令不属于ARM指令集中的指令,是为了编程方便而定义的。,LDR伪指令用于加载32位的立即数或一个地址值到指定寄存器。,LDRcondregister,=expr|label_expr,常量或地址表达式,注意:与ARM指令的LDR相比,伪指令的LDR的参数有“=”号。,1.大范围地址读取伪指令LDR,目标寄存器,应用示例1(加载常量):,LDRR2,=0 xFF0;MOVR2,#0 xFF0LDRR0,=0 xFF000000;MOVR0,#0 xFF000000,应用示例2(加载地址):,.LDRR1,=InitStack.InitStackMOVR0,LR.,使用伪指令将程序标号InitStack的地址存入R1,2.中等范围地址读取伪指令ADRL,ADRL伪指令将基于PC相对偏移的地址值或基于寄存器相对偏移的地址值读取到寄存器中,比ADR伪指令可以读取更大范围的地址。,地址表达式expr的取指范围:当地址值是字节对齐时,其取指范围为-64K64K;当地址值是字对齐时,其取指范围为-256K256K;,ADRLcondregister,expr,目标寄存器,地址表达式,3.小范围地址读取伪指令ADR,ADR伪指令将基于PC相对偏移的地址值或基于寄存器相对偏移的地址值读取到寄存器中。,ADRcondregister,expr,目标寄存器,地址表达式,地址表达式expr的取指范围:当地址值是字节对齐时,其取指范围为-255255;当地址值是字对齐时,其取指范围为-10201020;,.ADRR0,Delay.DelayMOVR0,R14.,应用示例1:,使用伪指令将程序标号Delay的地址存入R0,ADRR0,DISP_TAB;加载转换表地址LDRBR1,R0,R2;使用R2作为偏移量,进行查表DISP_TABDCB0 xC0,0 xF9,0 xA4,0 xB0,0 x99,0 x92,0 x82,应用示例2(查表程序):,4.空操作伪指令NOP,NOP是空操作伪指令,在汇编时将会被替代成ARM中的空操作。,NOP,例6-4用软件实现延时5个时钟周期。.Delay5NOPNOPNOPNOPNOP.,6.2ARM汇编语言伪操作,伪操作是ARM汇编语言程序里的一些特殊的指令助记符,其作用主要是为完成汇编程序做各种准备工作,对源程序运行汇编程序处理,而不是在计算机运行期间由处理器执行。伪操作只是汇编过程中起作用,一旦汇编结束,伪操作也就随之消失。,在ARM的汇编程序中,伪操作主要有符号定义伪操作、数据定义伪操作、汇编代码控制伪操作、汇编信息报告控制伪操作、指令集类型标识伪操作、文件包含伪操作和其他类型伪操作等。,6.3.1符号定义伪操作,符号定义伪操作用于定义ARM汇编程序中的变量、对变量赋值及定义寄存器的别名等操作。常见的符号定义伪操作有如下几种。(1)局部变量定义LCLA、LCLL及LCLS(2)全局变量定义GBLA、GBLL及GBLS(3)变量赋值伪操作SETA、SETL及SETS(4)给通用寄存器列表定义名称RLIST(5)VFP寄存器名称定义DN、SN(6)FPA浮点寄存器名称定义FN(7)协处理器名称定义CP(8)协处理器寄存器名称定义CN,GBLATest1Test1SETA0 xaaGBLLTest2Test2SETLTRUEGBLSTest3Test3SETS“Testing”,应用示例:,例6-11将寄存器列表R0、R1、R2、R5、R7、R10、R11、R12的名称定义为Reglist。ReglistRLISTR0-R2,R5,R7,R10-R12,4.给通用寄存器列表定义名称RLIST,RLIST伪操作用于给一个通用寄存器列表定义名称,使用该伪操作定义的名称可以在LDM/STM中使用。,nameRLISTregisters_list,6.3.2数据定义伪操作,数据定义伪操作一般用于为特定的数据分配存储单元,同时可完成已分配存储单元的初始化。常见的数据定义伪操作有如下几种。,(1)DCB用于分配一片连续的字节存储单元并用指定的数据初始化。(2)DCW/DCWU用于分配一片连续的半字存储单元并用指定的数据初始化。(3)DCD/DCDU用于分配一片连续的字存储单元并用指定的数据初始化。(4)DCFS/DCFSU用于为单精度的浮点数分配一片连续的字存储单元并用指定的数据初始化。(5)DCFD/DCFDU用于为双精度的浮点数分配一片连续的字存储单元并用指定的数据初始化。,(6)DCQ/DCQU用于分配一片以8字节为单位的连续的存储单元并用指定的数据初始化。(7)LTORG声明一个数据缓冲池。(8)SPACE用于分配一片连续的存储区域并将其初始化为0。(9)MAP用于定义一个结构化的内存表首地址。(10)FIELD用于定义一个结构化的内存表的数据域。(11)DCDO将内存单元的内容初始化为相对地址。(12)DCI分配用于存放代码的内存单元。,DCB:DISPTABDCB0 x33,0 x43,0 x76,0 x12DCB-120,20,36,55ERRSTRDCB“Send,dataiserror!”,0,DCD:AREAWord,CODE,READONLYnumEQU20ENTRYstartLDRR0,=srcLDRR1,=dstMOVR2,#numwordcopyLDRR3,R0,#4STRR3,R1,#4SUBSR2,R2,#1BNEwordcopystopBstopAREABlockData,DATA,READWRITEsrcDCD1,2,3,4,5,6,7,8,1,2,3,4,5,6,7,8,1,2,3,4dstDCD0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0END,LTORG:例6-22(1)声明一个数据缓冲池用来存储0 xAABBCCDD。LDRR0,=0 xAABBCCDDEORR1,R1,R0BSUB_proLTORG(2)用LTORG伪操作定义数据缓冲池。AREAExample,CODE,READONLY_startBLfun_sub1fun_sub1LDRR0,=0 xAABBCCDDMOVPC,LRLTORGEND,SPACE:AREAData,DATA,READWRITEDataBufSPACE1000,MAP、FIELD:例6-25(1)定义一个结构化的内存表,其首地址固定为0 x300,该结构化内存表包含4个域,Fdata1长度为4字节,Fdata2长度为8字节,Fdata3长度为100字节,Fdata4长度为200字节。MAP0 x300Fdata1FIELD4Fdata2FIELD8Fdata3FIELD100Fdata4FIELD200,MAP、FIELD:(2)分析下面LDR指令实现的功能。MAP4,R12FIELD4FdataFIELD4LDRR0,Fdata,MAP、FIELD:,6.3.3汇编代码控制伪操作,汇编代码控制伪操作用于控制汇编程序的执行流程,常用的汇编控制伪操作包括以下几条:1.IF条件编译伪操作;2.WHILE条件编译伪操作;3.MACRO宏定义伪操作,IF、ELSE、ENDIF伪操作能根据条件的成立与否来决定是否对一段程序代码进行编译。语法格式:IFlogical-expression程序代码AELSE程序代码BENDIF,1.IF条件编译伪操作,例6-28IFUART0=ONBLUART0_initELSEBLUART1_initENDIF,WHILE、WEND伪操作能根据条件的成立与否决定是否对一段程序代码进行重复编译,直到WHILE后面的逻辑表达式不成立为止。语法格式:WHILElogical-expression程序代码WEND,2.WHILE条件编译伪操作,例6-29counterSETA100WHILEcounter0.counterSETAcounter-1WEND,MACRO、MEND伪操作可以将一段代码定义为一个整体,称为宏,然后就可以在程序中通过宏指令多次调用该段代码。MACRO标志宏定义的开始,MEND标志宏定义的结束。语法格式:MACRO$labelmacroname$parameter,$parameter程序代码段MEND,3.MACRO宏定义伪操作,#definePI3.1415926#defineS(r)PI*r*rmain()floata,area;a=3.6;area=S(a);printf(“r=%fnarea=%fn”,a,area);,C语言宏定义和使用,与C语言中的define相似,仅在源程序中做字符替换以MACRO指示符开始,以MEND结束。,例6-30MACRO$labelTestAndBranch$dest,$reg,$cc$labelCMP$reg,#0B$cc$destMEND,TestTestAndBranchNonZero,R0,NENonZero,TestCMPR0,#0BNENonZeroNonZero,6.3.5指令集类型标识伪操作,指令集类型标识伪操作用来告诉编译器所处理的是32位的ARM指令还是16位的Thumb指令,实现这一操作的操作符有ARM、CODE32、THUMB、CODE16。,例6-35AREAToThumb,CODE,READONLYENTRYARMstartADRR0,into_thumb+1BXR0THUMBinto_thumbMOVSR0,#10,6.3.6文件包含伪操作,文件包含伪操作包括两类:一类是将一个源文件包含到当前源文件中,并将被包含的文件在其当前位置进行汇编处理;另一类是也将一个源文件包含到当前源文件中,但被包含文件不进行汇编处理。,GET伪操作用于将一个源文件包含到当前的源文件中,并将被包含的源文件在当前位置进行汇编处理。可以使用INCLUDE代替GET。,1文件包含GET或INCLUDE,例6-36:AREAExample,CODE,READONLYGETinclude_s.sGETC:testinclude_init.s,INCBIN伪操作将一个文件包含到当前源文件中,该文件按原样包含,不进行汇编处理。可以使用INCBIN来包含可执行文件、文字或其他数据。,2文件原样包含INCBIN,例6-37:AREAExample,CODE,READONLYINCBINtest1.datINCBINc:testtest2.txt,6.3.7其他类型伪操作,对齐方式设置ALIGN段属性定义伪操作AREA源程序结尾标识END声明程序的入口点ENTRY定义常量或标号名称EQU声明全局标号EXPORT或GLOBAL将符号导出到目标文件EXPORTAS外部符号声明IMPORT和EXTERN保留局部符号KEEP禁止使用浮点指令NOFP指定段的相关性REQUIRE堆栈八字节对齐REQUIRE8和PRESERVE8局部变量范围定义ROUT,ALIGN伪操作通过用零或NOP指令进行填充来使当前位置与指定的边界对齐。应用示例:AREAExample,CODE,READONLYSTARTLDRR0,=sdfjk.MOVPC,LRsdfjkDCB0X56ALIGNSUBIMOVR1,R3.MOVPC,LR,1.对齐方式设置ALIGN,段属性定义伪操作AREA用于定义一个代码段或数据段,AREA伪操作指示汇编器汇编新的代码段或数据段。ARM程序采用分段式设计,一个ARM源程序至少需要一个代码段,大的程序可以包含多个代码段和数据段。,2段属性定义伪操作AREA,AREAThumbSub,CODE,READONLYENTRYCODE32headerADRR0,start+1BXR0CODE16startMOVR0,#10MOVR1,#3BLdoaddstopBstopdoaddADDR0,R0,R1MOVPC,LREND,END伪操作用于通知编译器已经到了源程序的结尾。,3源程序结尾标识END,ENTRY伪操作用于指定汇编程序的入口点。在一个完整的汇编程序中至少要有一个ENTRY,但在一个源文件里不能使用多个ENTRY。重释:一个程序(可以包含多个源文件)中至少要有一个ENTRY,可以有多个ENTRY,但一个源文件中最多只有一个ENTRY。,4声明程序的入口点ENTRY,EQU伪操作用于为程序中的常量、标号等定义一个等效的字符名称。应用示例:TestEQU50AddrEQU0 x55,5定义常量或标号名称EQU,EXPORT伪操作用于在程序中声明一个全局的标号,该标号可在其他的文件中引用。应用示例:AREAInit,CODE,READONLYEXPORTStestEND,6EXPORT(注:汇编源程序中用),EXTERN伪操作用于通知编译器

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论