《ARM指令系统》PPT课件

《ARM指令系统》PPT课件

ID:45084243

大小:641.50 KB

页数:93页

时间:2019-11-09

《ARM指令系统》PPT课件_第1页
《ARM指令系统》PPT课件_第2页
《ARM指令系统》PPT课件_第3页
《ARM指令系统》PPT课件_第4页
《ARM指令系统》PPT课件_第5页
资源描述:

《《ARM指令系统》PPT课件》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、ARM嵌入式系统 第3章ARM指令系统ARM微处理器的指令系统ARM指令的寻址方式ARM微处理器的指令集概述ARM指令集Thumb指令集简介及应用场合ARM指令的寻址方式根据指令中给出的地址码字段寻找真实操作数地址的方式。ARM处理器支持的寻址方式有:立即寻址寄存器寻址寄存器移位寻址寄存器间接寻址基址寻址多寄存器寻址堆栈寻址块拷贝寻址相对寻址ARM指令的寻址方式立即寻址操作数本身在指令中给出,只要取出指令也就取到了操作数。这个操作数被称为立即数ADDR0,R0,#1;R0←R0+1ANDR8,R7,#0xFF;R8←R7[7:0]ADDR0,R0,#&3f;R0←R0+0x3f立即数要求以“#

2、”为前缀,对于以十六进制表示的立即数,还要求在“#”后加上“0x”或“&”ARM指令的寻址方式寄存器寻址寄存器中的数值作为操作数ADDR0,R1,R2;R0←R1+R2ARM指令的寻址方式寄存器移位寻址ARM集特有。第二个操作数先进行移位操作。ADDR3,R2,R1,LSL#3;R3←R2+8*R1LSL:逻辑左移(LogicalShiftLeft)LSR:逻辑右移(LogicalShiftRight)ASR:算术右移(ArithmeticShiftRight)ROR:循环右移(RotateRight)RRX:扩展为1的循环右移(RotateRighteXtendedby1place)0LSL

3、0LSRASRRORARM指令的寻址方式寄存器间接寻址以寄存器中的值作为操作数的地址,而操作数本身存放在存储器中LDRR0,[R1];R0←[R1]STRR0,[R1];[R1]←R0ARM指令的寻址方式基址寻址将基址寄存器的内容与指令中给出的地址偏移量相加,形成操作数的有效地址。基址寻址常用于访问基地址附近的存储单元。包括基址加偏移和基址加索引寻址。基址加偏移-前索引寻址LDRR0,[R1,#4];R0←[R1+4]基址加偏移-带自动索引的前索引寻址LDRR0,[R1,#4]!;R0←[R1+4]、R1←R1+4基址加偏移-后索引寻址LDRR0,[R1],#4;R0←[R1]、R1←R1+4

4、基址加索引寻址LDRR0,[R1,R2];R0←[R1+R2]ARM指令的寻址方式多寄存器寻址一条指令可以完成多个寄存器值的传送。可以用一条指令完成传送最多16个通用寄存器的值。LDMIAR0,{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,LDMDAI:IncrementD:DecrementB:BeforeA:AfterARM指令的寻址方式堆栈寻址堆栈是一种数据结构,按先

5、进后出(FirstInLastOut,FILO)的方式工作,使用一个称作堆栈指针的专用寄存器指示当前的操作位置,堆栈指针总是指向栈顶。当堆栈指针指向最后压入堆栈的数据时,称为满堆栈(FullStack),而当堆栈指针指向下一个将要放入数据的空位置时,称为空堆栈(EmptyStack)。同时,根据堆栈的生成方式,又可以分为递增堆栈(AscendingStack)和递减堆栈(DecendingStack),当堆栈由低地址向高地址生成时,称为递增堆栈,当堆栈由高地址向低地址生成时,称为递减堆栈。这样就有四种类型的堆栈工作方式,ARM微处理器支持这四种类型的堆栈工作方式,即:ARM指令的寻址方式堆栈寻

6、址满递增堆栈(FA):堆栈指针指向最后压入的数据,且由低地址向高地址生成。入栈:STMFA,出栈:LDMFA满递减堆栈(FD):堆栈指针指向最后压入的数据,且由高地址向低地址生成。入栈:STMFD,出栈:LDMFD空递增堆栈(EA):堆栈指针指向下一个将要放入数据的空位置,且由低地址向高地址生成。入栈:STMEA,出栈:LDMEA空递减堆栈(ED):堆栈指针指向下一个将要放入数据的空位置,且由高地址向低地址生成。入栈:STMED,出栈:LDMEDARM指令的寻址方式STMFAr13!,{r0-r5};PushontoaFullAscendingStackLDMFAr13!,{r0-r5};Po

7、pfromaFullAscendingStackSTMFDr13!,{r0-r5};PushontoaFullDescendingStackLDMFDr13!,{r0-r5};PopfromaFullDescendingStackSTMEAr13!,{r0-r5};PushontoanEmptyAscendingStackLDMEAr13!,{r0-r5};PopfromanEmptyAscend

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。