- 1、本文档共54页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[计算机]第4章 ARM指令集系统1
(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
您可能关注的文档
- [计算机]测试计划的编写提示.doc
- [计算机]测试驱动开发.ppt
- [计算机]淘宝店铺如何引流量_淘宝心级卖家7天流量升400。很快。.doc
- [计算机]淘宝店铺运营系统方案.doc
- [计算机]深入了解Oracle自动内存管理ASMM.pdf
- [计算机]深圳新创云终端L10 省电 省钱 省空间.doc
- [计算机]添加一个系统调用.doc
- [计算机]游戏设计数值入门.doc
- [计算机]漫谈商务社交和社会化招聘.pdf
- [计算机]瀑布旅游资源评价与广州增城白水仙瀑开发.pdf
- 2025年长沙银行浏阳支行社会招聘考试备考题库及答案解析.docx
- 2025年浙商银行成都分行社会招聘考试备考题库及答案解析.docx
- 2025中国农业科学院烟草研究所高层次人才招聘5人考试备考题库及答案解析.docx
- 2025中国冶金地质总局二局 国冶二局(福建)集团有限公司招聘10人考试备考题库及答案解析.docx
- 2025中国宗教杂志社招聘3人考试备考题库及答案解析.docx
- 2025年长沙银行益阳支行社会招聘考试备考题库及答案解析.docx
- 2025中国农业科学院农田灌溉研究所第二批招聘14人(河南)考试备考题库及答案解析.docx
- 2025中国农业科学院郑州果树研究所青年英才招聘3人考试备考题库及答案解析.docx
- 【统编版】高中语文必修上册第1单元2.1《立在地球边上放号》精美课件(23张PPT).pptx
- 【统编版】高一语文必修上册第一单元2.1《立在地球边上放号》优质课(26张PPT)课件.pptx
最近下载
- 牛津自然拼读oxfordphonicsLevel2Unit4Lesson2课件.pptx VIP
- 《梅花易数》预测实战方法.pdf VIP
- 医院地震应急演练脚本.docx VIP
- EPLAN笔记-EPLAN笔记-EPLAN笔记-EPLAN笔记.pdf VIP
- 污水处理厂应急预案.doc VIP
- 防火封堵工程施工与验收记录表(附件8)模板.pdf VIP
- 公路工程高程横坡计算程序(2011表格版).xls VIP
- BS EN 1822-1-2019 高效空气过滤器(EPA,HEPA和ULPA).第1部分:分类性能试验标记.pdf VIP
- 皇极经世预言未来的原理.pdf VIP
- 牛津自然拼读课件OPW PPT L2 U4 Lesson1.pptx VIP
文档评论(0)