第4篇 ARM指令集系统1.ppt

  1. 1、本文档共54页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
(2)CMN负数比较指令 CMN{cond} Rn, operand2 功能:CMN指令将寄存器Rn的值加上operand2表示的数值,根据操作结果和寄存器移位情况更新CPSR中的相应条件标志位。 CMN R1,#0x10 (3)TST位测试指令 TST{cond} Rn, operand2 Rn AND OP2 功能:CMN指令将寄存器Rn的值与operand2表示的数值按位作逻辑“与”操作,根据操作结果和寄存器移位情况更新CPSR中的相应条件标志位。 4)TEQ相等测试指令 TEQ{cond} Rn, operand2 Rn EOR op2 功能:TEQ指令将寄存器Rn的值与operand2表示的数值按位作逻辑“异或”操作,根据操作结果和寄存器移位情况更新CPSR中的相应条件标志位。 4.1.2 乘法指令 ARM乘法指令完成2个寄存器中数据的乘法,按照保存结果的数据长度可以分为两类:一类为32位的乘法指令,即乘法操作的结果为32位;另一类为64位的乘法指令,即乘法操作的结果为64位。 32位乘法指令 (1)MUL MUL{cond}{S} Rd, Rm, Rs MUL指令实现两个32位的数(可以为无符号数,也可为有符号数)的乘积(Rm * Rs )并将结果存放到一个32位的寄存器Rd中; 如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 例如: MULS R0,R1,R2 ;R0=R1*R2,结果影响CPSR (2)MLA MLA{cond}{S} Rd, Rm, Rs, Rn Rd=Rm*Rs+Rn MLA指令实现两个32位的数(可以为无符号数,也可为有符号数)的乘积,再将乘积(Rm * Rs )加上第3个操作数Rn,并将结果存放到一个32位的寄存器Rd中;如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 例如: MLA R0,R1,R2,R3 ;R0=R1*R2+R3 64位乘法 (1)UMULL UMULL{cond}{S} RdLo, RdHi, Rm, Rs RdHi RdLo=Rn*Rs UMULL指令实现两个32位无符号数的乘积,乘积结果的高32位存放到一个32位的寄存器的RdHi,乘积结果的低32位存放到另一个32位的寄存器的RdLo;如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 例如: UMULL R0,R1,R2,R3 ;R1(高位),R0(低位)=R2*R3 (2)UMLAL UMLAL{cond}{S} RdLo, RdHi, Rm, Rs RdHi ,RdLo=Rm*Rs+ RdHi ,RdLo UMLAL指令将两个32位无符号数的64位乘积结果与由(RdHi: RdLo)表示的64位无符号数相加,加法结果的高32位存放到寄存器RdHi中,乘积结果的低32位存放到寄存器RdLo中;如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 例如: UMLAL R0,R1,R2,R3 R0=R2*R3的低32位+R0 R1=R2*R3的高32位+R1 其中R0-R3全为无符号数 (3)SMULL SMULL{cond}{S} RdLo, RdHi, Rm, Rs SMULL指令实现两个32位有符号数的乘积,乘积结果的高32位存放到一个32位的寄存器的RdHi,乘积结果的低32位存放到另一个32位的寄存器的RdLo;如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 例子 MVN R0,#0x0 MOV R1,#0x1 UMULL R2,R3,R1,R0 SMULL R4,R5,R1,R0 (4)SMLAL SMLAL{cond}{S} RdLo, RdHi, Rm, Rs SMLAL指令将两个32位有符号数的64位乘积结果与由(RdHi: RdLo)表示的64位无符号数相加,加法结果的高32位存放到寄存器RdHi中,乘积结果的低32位存放到寄存器RdLo中;如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 4.2 ARM分支指令 分支指令用于实现程序流程的跳转,在ARM程序中有两种方法可以实现程序流程的跳转: 使用专门的分支指令。 直接向程序计数器PC写入跳转地址值。 通过向程序计数器PC写入跳转地址值,可以实现在4GB的地址空间中的任意跳转,在跳转之前结合使用MOV?? LR,PC等类似指令,能够保存程序的返回地址值,从而实现在4GB连续地址空间的子程序调用。 分支指令B 分支指令B可以实现跳转到指定的地址执行程序。 指令的汇编语法格式如下: B{cond} target_ad

文档评论(0)

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

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

1亿VIP精品文档

相关文档