课件-03J第3章ARM指令系统.ppt.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
课件-03J第3章ARM指令系统.ppt.ppt

ARM 嵌入式系统 第3章 ARM指令系统 ARM微处理器的指令系统 ARM指令的寻址方式 ARM微处理器的指令集概述 ARM指令集 Thumb指令集简介及应用场合 ARM指令的寻址方式 根据指令中给出的地址码字段寻找真实操作数地址的方式。ARM处理器支持的寻址方式有: 立即寻址 寄存器寻址 寄存器移位寻址 寄存器间接寻址 基址寻址 多寄存器寻址 堆栈寻址 块拷贝寻址 相对寻址 ARM指令的寻址方式 立即寻址 操作数本身在指令中给出,只要取出指令也就取到了操作数。这个操作数被称为立即数 ADD R0,R0,#1 ;R0←R0+1 AND R8,R7,#0xFF ;R8←R7[7:0] ADD R0,R0,#3f ;R0←R0+0x3f 立即数要求以“#”为前缀,对于以十六进制表示的立即数,还要求在“#”后加上“0x”或“” ARM指令的寻址方式 寄存器寻址 寄存器中的数值作为操作数 ADD R0,R1,R2 ;R0←R1+R2 ARM指令的寻址方式 寄存器移位寻址 ARM集特有。第二个操作数先进行移位操作。 ADD R3,R2,R1,LSL #3 ;R3←R2+8*R1 LSL:逻辑左移(Logical Shift Left) LSR:逻辑右移(Logical Shift Right) ASR:算术右移(Arithmetic Shift Right) ROR:循环右移(Rotate Right) RRX:扩展为1的循环右移(Rotate Right eXtended by 1 place ) ARM指令的寻址方式 寄存器间接寻址 以寄存器中的值作为操作数的地址,而操作数本身存放在存储器中 LDR R0,[R1] ;R0←[R1] STR R0,[R1] ;[R1]←R0 ARM指令的寻址方式 基址寻址 将基址寄存器的内容与指令中给出的地址偏移量相加,形成操作数的有效地址。基址寻址常用于访问基地址附近的存储单元。包括基址加偏移和基址加索引寻址。 基址加偏移-前索引寻址 LDR R0,[R1,#4] ;R0←[R1+4] 基址加偏移-带自动索引的前索引寻址 LDR R0,[R1,#4]! ;R0←[R1+4]、R1←R1+4 基址加偏移-后索引寻址 LDR R0,[R1],#4 ;R0←[R1]、R1←R1+4 基址加索引寻址 LDR R0,[R1,R2] ;R0←[R1+R2] ARM指令的寻址方式 多寄存器寻址 一条指令可以完成多个寄存器值的传送。可以用一条指令完成传送最多16个通用寄存器的值。 LDMIA R0,{R1,R2,R3,R4} ;R1←[R0],R2←[R0+4],R3←[R0+8],R4←[R0+12] 地址增加在先(IB):STMIB,LDMIB 地址增加在后(IA):STMIA,LDMIA 地址减少在先(DB):STMDB,LDMDB 地址减少在后(DA):STMDA,LDMDA I:Increment D:Decrement B:Before A:After ARM指令的寻址方式 堆栈寻址 堆栈是一种数据结构,按先进后出(First In Last Out,FILO)的方式工作,使用一个称作堆栈指针的专用寄存器指示当前的操作位置,堆栈指针总是指向栈顶。 当堆栈指针指向最后压入堆栈的数据时,称为满堆栈(Full Stack),而当堆栈指针指向下一个将要放入数据的空位置时,称为空堆栈(Empty Stack)。 同时,根据堆栈的生成方式,又可以分为递增堆栈(Ascending Stack)和递减堆栈(Decending Stack),当堆栈由低地址向高地址生成时,称为递增堆栈,当堆栈由高地址向低地址生成时,称为递减堆栈。这样就有四种类型的堆栈工作方式,ARM微处理器支持这四种类型的堆栈工作方式,即: ARM指令的寻址方式 堆栈寻址 满递增堆栈(FA): 堆栈指针指向最后压入的数据,且由低地址向高地址生成。 入栈:STMFA,出栈:LDMFA 满递减堆栈(FD): 堆栈指针指向最后压入的数据,且由高地址向低地址生成。 入栈:STMFD,出栈:LDMFD 空递增堆栈(EA): 堆栈指针指向下一个将要放入数据的空位置,且由低地址向高地址生成。 入栈:STMEA,出栈:LDMEA 空递减堆栈(ED): 堆栈指针指向下一个将要放入数据的空位置,且由高地址向低地址生成。 入栈:STMED,出栈:LDMED ARM指令的寻址方式 STMFA r13!, {r0-r5} ; Push onto a

文档评论(0)

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

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

1亿VIP精品文档

相关文档