欢迎来到天天文库
浏览记录
ID:45084243
大小:641.50 KB
页数:93页
时间:2019-11-09
《《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
此文档下载收益归作者所有