位操作指令

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

位运算指令集AND,OR,XOR,NOT,TEST功能:执行BIT与BIT之间的逻辑运算语法:ANDr/m,r/m/dataORr/m,r/m/dataXORr/m,r/m/dataTESTr/m,r/m/dataNOTr/m影响标志:C,O,P,Z,S(其中C与O两个标志会被设为0)NOT指令不影响任何标志位SHR,SHL,SAR,SAL功能:移位指令语法:SHRr/m,data/CLSHLr/m,data/CLSARr/m,data/CLSALr/m,data/CL影响标志:C,P,Z,S,OROR,ROL,RCR,RCL功能:循环移位指令语法:RORr/m,data/CLROLr/m,data/CLRCRr/m,data/CLRCLr/m,data/CL影响标志:C,P,Z,S,O程序流程控制指令集CLC,STC,CMC功能:设定进位标志语法:CLCSTCCMC标志位:CCLD,STD功能:设定方向标志语法:CLDSTD标志位:DCLI,STI功能:设定中断标志语法:CLISTI标志位:ICMP功能:比较OP1与OP2的值语法:CMPr/m,r/m/data标志位:C,P,A,Z,OJMP功能:跳往指定地址执行语法:JMP地址JXX功能:当特定条件成立则跳往指定地址执行语法:JXX地址注:A:ABOVE,当C=0,Z=0时成立B:BELOW,当C=1时成立C:CARRY,当弁时成立CXZ:CX寄存器的值为0(ZERO)时成立E:EQUAL,当Z=1时成立G:GREATER(大于),当Z=0且S=0时成立L:LESS(小于),当S不为零时成立N:NOT(相反条件),需和其它符号配合使用O:OVERFLOW,O=1时成立P:PARITY,P=11/3页时成立PE:PARITYEVEN,P=1时成立PO:PARITYODD,P=0时成立S:SIGN,S=1时成立Z:ZERO,Z=1时成立LOOP功能:循环指令集语法:LOOP地址LOOPE(Z)地址LOOPNE(Z)地址标志位:无CALL,RET功能:子程序调用,返回指令语法:CALL地址RETRETn标志位:无INT,IRET功能:中断调用及返回指令语法:INTnIRET标志位:在执行INT时,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器7、其他伪指令.externmain.text.global_start_start:'.extern'定义一个外部符号(可以是变量也可以是函数),上面的代码表示表文本文件中引用的main是一个外部函数。'.text'表示下面的语句都属于代码段'.global'将本文件中的某个程序标号定义为全局的,如‘_start’就是个全局函数MRS(读状态寄存器)MRSr1,CPSR;CPSR---r1MSR(写状态寄存器)MSRcpsr_c,#0xD3;CPSR[7...0]=0xD3STMFDSP!{R8-R9}含义:(1)SP=SP-4字节(2)R9---SP(3)SP=SP-4(4)R8--SPLDMFDSP!{R8-R9,PC}含义:(1)SP--R8(2)SP=SP+4(3)SP--R9(4)SP=SP+4(5)SP--PC(6)SP=SP+4ldmiasp!{r0-r7pc}^^表示将spsr的值赋给cpsrBlable跳转指令PC---lableBLlable带链接跳转指令LR----PC-4,PC---lableBXRm带状态切换跳转指令PC----Rm,切换状态(Rm[0]=1,thumb,Rm[0]=0,ARM)%F2表示跳转到当前指令后面的标号2处%B0表示跳转到当前指令前面的标号0处[-----IF;|-----ELSE;]-----ENDIFIFlogicalexpression[logicalexpressionInstructionsInstructions{ELSE|InstructionsInstructions}]ENDIF(1)GBLL伪指令用于定义一个全局的逻辑变量,并初始化为{False}。GBLLBOOTLOADERBOOTLOADERSETL{TRUE}(2)GET(或INCLUDE)GET伪指令用于将一个源文件包含到当前的源文件中,并将被包含的源文件在当前位置进行汇编处理。可以使用INCLUDE代替GET。INCLUDE..\..\kernel\oal\startup.s(3)IMPORT伪指令用于通知编译器要使用的标号在其他的源文件中定义,但要在当前源文件中引用,而且无论当前源文件是否引用该标号,该标号均会被加入到当前源文件的符号表中。IMPORTBootloaderMainIMPORTMMUSetup(4)BL带返回的跳转指令(5)BEQ表示“相等则跳转”,即当CPSR中的Z标志置位时发生跳转BLabel;程序无条件跳转到标号Label处执行CMPR1,#0;当CPSR寄存器中的Z条件码置位时,程序跳转到标号Label处执行BEQLabel(6)LDR指令的格式为:LDR{条件}目的寄存器,存储器地址LDR指令用于从存储器中将一个32位的字数据传送到目的寄存器中。该指令通常用于从存储器中读取32位的字数据到通用寄存器,然后对数据进行处理。当程序计数器PC作为目的寄存器时,指令从存储器中读取的字数据被当作目的地址,从而可以实现程序流程的跳转。指令示例:LDRR0,[R1];将存储器地址为R1的字数据读入寄存器R0。LDRR0,[R1,R2];将存储器地址为R1+R2的字数据读入寄存器R0。LDRR0,[R1,#8];将存储器地址为R1+8的字数据读入寄存器R0。LDRR0,[R1,R2]!;将存储器地址为R1+R2的字数据读入寄存器R0,并将新地址R1+R2写入R1LDRR0,[R1,#8]!;将存储器地址为R1+8的字数据读入寄存器R0,并将新地址R1+8写入R1。LDRR0,[R1],R2;将存储器地址为R1的字数据读入寄存器R0,并将新地址R1+R2写入R1。LDRR0,[R1,R2,LSL#2]!;将存储器地址为R1+R2×4的字数据读入寄存器R0,并将新地址R1+R2×4写入R1。LDRR0,[R1],R2,LSL#2;将存储器地址为R1的字数据读入寄存器R0,并将新地址R1+R2×4写入R1。(7)STR指令的格式为:STR{条件}源寄存器,存储器地址STR指令用于从源寄存器中将一个32位的字数据传送到存储器中。与LDR对应(8)采用多寄存器寻址方式,一条指令可以完成多个寄存器值的传送。这种寻址方式可以用一条指令完成传送最多16个通用寄存器的值。以下指令:LDMIAR0,{R1,R2,R3,R4};R1←[R0];R2←[R0+4];R3←[R0+8];R4←[R0+12]该指令的后缀IA表示在每次执行完加载/存储操作后,R0按字长度增加,因此,指令可将连续存储单元的值传送到R1~R4。(9)SBC指令的格式为:SBC{条件}{S}目的寄存器,操作数1,操作数2SBC指令用于把操作数1减去操作数2,再减去CPSR中的C条件标志位的反码,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令使用进位标志来表示借位,这样就可以做大于32位的减法。注意不要忘记设置S后缀来更改进位标志。该指令可用于有符号数或无符号数的减法运算。指令示例:SUBSR0,R1,R2;R0=R1-R2-!C,并根据结果设置CPSR的进位标志位(10)BX带状态切换的跳转指令(11)MCR指令的格式为:MCR{条件}协处理器编码,协处理器操作码1,源寄存器,目的寄存器1,目的寄存器2,协处理器操作码2MCR指令用于将ARM处理器寄存器中的数据传送到协处理器寄存器中,若协处理器不能成功完成操作,则产生未定义指令异常。其中协处理器操作码1和协处理器操作码2为协处理器将要执行的操作,源寄存器为ARM处理器的寄存器,目的寄存器1和目的寄存器2均为协处理器的寄存器。指令示例:MCRP3,3,R0,C4,C5,6;该指令将ARM处理器寄存器R0中的数据传送到协处理器P3的寄存器C4和C5中。(12)CMP指令的格式为:CMP{条件}操作数1,操作数2CMP指令用于把一个寄存器的内容和另一个寄存器的内容或立即数进行比较,同时更新CPSR中条件标志位的值。该指令进行一次减法运算,但不存储结果,只更改条件标志位。标志位表示的是操作数1与操作数2的关系(大、小、相等),例如,当操作数1大于操作操作数2,则此后的有GT后缀的指令将可以执行。指令示例:CMPR1,R0;将寄存器R1的值与寄存器R0的值相减,并根据结果设置CPSR的标志位CMPR1,#100;将寄存器R1的值与立即数100相减,并根据结果设置CPSR的标志位(13)批量数据加载/存储指令LDM(或STM)指令的格式为:LDM(或STM){条件}{类型}基址寄存器{!},寄存器列表{∧}LDM(或STM)指令用于从由基址寄存器所指示的一片连续存储器到寄存器列表所指示的多个寄存器之间传送数据,该指令的常见用途是将多个寄存器的内容入栈(SDM)或出栈(LDM)。其中,{类型}为以下几种情况:IA每次传送后地址加1;IB每次传送前地址加1;DA每次传送后地址减1;DB每次传送前地址减1;FD满递减堆栈;ED空递减堆栈;FA满递增堆栈;EA空递增堆栈;{!}为可选后缀,若选用该后缀,则当数据传送完毕之后,将最后的地址写入基址寄存器,否则基址寄存器的内容不改变。STMFDR13!,{R0,R4-R12,LR};将寄存器列表中的寄存器(R0,R4到R12,LR)存入堆栈LDMFDR13!,{R0,R4-R12,PC};将堆栈内容恢复到寄存器(R0,R4到R12,LR)(14)ORR指令的格式为:ORR{条件}{S}目的寄存器,操作数1,操作数2ORR指令用于在两个操作数上进行逻辑或运算,并把结果放置到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令常用于设置操作数1的某些位。指令示例:ORRR0,R0,#3;该指令设置R0的0、1位,其余位保持不变。(15)BIC指令的格式为:BIC{条件}{S}目的寄存器,操作数1,操作数2BIC指令用于清除操作数1的某些位,并把结果放置到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。操作数2为32位的掩码,如果在掩码中设置了某一位,则清除这一位。未设置的掩码位保持不变。指令示例:BICR0,R0,#%1011;该指令清除R0中的位0、1、和3,其余的位保持不变。(16)ADR(小范围的地址读取伪指令)ADRL(中等范围的地址读取伪指令)LDR(大范围的地址读取伪指令)ldrr0,=0xFFFFC000用于将基于PC的地址或基于寄存器的地址读取到寄存器中。///伪指令通过汇编编译器替换成对应的ARM/Thumb指令

1 / 6
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功