- 1、本文档共61页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
西安电子科技大学计算机学院 嵌入式系统 第六讲 ARM指令详细介绍 ARM指令集编码 指令分类 数据处理指令 load/store指令 跳转指令 CPSR处理指令 异常产生指令 协处理器指令 6.1 数据处理指令 数据传送指令(2条) 算术运算指令(6条) 逻辑运算指令(4条) 比较指令(2条) 测试指令(2条) 乘法指令(6条) 6.1.1 数据传送指令 MOV指令 MOV指令的格式为: MOV{条件}{S} 目的寄存器,源操作数 MOV指令可完成从另一个寄存器、被移位的寄存器或将一个立即数加载到目的寄存器。其中S选项决定指令的操作是否影响CPSR中条件标志位的值,当没有S时指令不更新CPSR中条件标志位的值。指令示例: MOV R1,R0 MOV R1,R0,LSL #3 6.1.1 数据传送指令 MVN指令 MVN指令的格式为: MVN{条件}{S} 目的寄存器,源操作数 MVN指令可完成从另一个寄存器、被移位的寄存器、或将一个立即数加载到目的寄存器。与MOV指令不同之处是在传送之前按位被取反了,即把一个被取反的值传送到目的寄存器中。其中S决定指令的操作是否影响CPSR中条件标志位的值,当没有S时指令不更新CPSR中条件标志位的值。指令示例: MVN R0,#0 6.1.2 算术运算指令 ADD指令 ADD指令的格式为: ADD{条件}{S} 目的寄存器,操作数1,操作数2 ADD指令用于把两个操作数相加,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。 指令示例: ADD R0,R1,R2 ADD R0,R1,#256 ADD R0,R2,R3,LSL#1 6.1.2 算术运算指令 ADC指令 ADC指令的格式为: ADC{条件}{S} 目的寄存器,操作数1,操作数2 ADC指令用于把两个操作数相加,再加上CPSR中的C条件标志位的值,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。 以下指令序列完成两个128位数的加法,第一个数存放在寄存器R7~R4,第二个数存放在寄存器R11~R8,运算结果存放在寄存器R3~R0: ADDS R0,R4,R8 ; 加低端的字 ADCS R1,R5,R9 ; 加第二个字,带进位 ADCS R2,R6,R10 ; 加第三个字,带进位 ADC R3,R7,R11 ; 加第四个字,带进位 6.1.2 算术运算指令 SUB指令 SUB指令的格式为: SUB{条件}{S} 目的寄存器,操作数1,操作数2 SUB指令用于把操作数1减去操作数2,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令可用于有符号数或无符号数的减法运算。 指令示例: SUB R0,R1,R2 ; R0 = R1 - R2 SUB R0,R1,#256 ; R0 = R1 - 256 SUB R0,R2,R3,LSL#1 ; R0 = R2 - (R3 1) 6.1.2 算术运算指令 SBC指令 SBC指令的格式为: SBC{条件}{S} 目的寄存器,操作数1,操作数2 SBC指令用于把操作数1减去操作数2,再减去CPSR中的C条件标志位的非,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。 以下指令序列实现64减法(R1,R0)-(R3,R2) SUBS R0,R0,R2 SBC R1,R1,R3 6.1.2 算术运算指令 RSB指令 RSB指令的格式为: RSB{条件}{S} 目的寄存器,操作数1,操作数2 RSB指令称为逆向减法指令,用于把操作数2减去操作数1,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。指令示例: RSB R0,R1,R2 RSB R0,R1,#256 RSB R0,R2,R3,LSL#1 6.1.2 算术运算指令 RSC指令 RSC指令的格式为: RSC{条件}{S} 目的寄存器,操作数1,操作数2 RSC指令用于把操作数2减去操作数1,再减去CPSR中的C条件标志位,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令使用进位标志来表示借位,这样就可以做大于32位的减法。 下列指令实现64位数据的负数 RSB
您可能关注的文档
- 概率论与数里理统计_Chapter_1习题解答.ppt
- 360品牌管家核心模型.ppt
- 需求分析与系统设计文档(龚家骧).ppt
- 关爱乐助自强-叶雄.ppt
- 第2章(2) TMS320C54xx的封装_引脚_基本硬件设计.ppt
- 潛在客戶開發与管理-进阶课程.ppt
- 第二篇国际结算方式——信用证(第六章)下.ppt
- 06s胆碱能受体阻断药.ppt
- 青少版新概念英语课件.ppt
- 第一章电子商务安全导论(修改).ppt
- 2024年中国钽材市场调查研究报告.docx
- 2024年中国不锈钢清洗车市场调查研究报告.docx
- 2024年中国分类垃圾箱市场调查研究报告.docx
- 2024年中国水气电磁阀市场调查研究报告.docx
- 2024年中国绿藻片市场调查研究报告.docx
- 2010-2023历年初中毕业升学考试(青海西宁卷)数学(带解析).docx
- 2010-2023历年福建厦门高一下学期质量检测地理卷.docx
- 2010-2023历年初中数学单元提优测试卷公式法(带解析).docx
- 2010-2023历年初中毕业升学考试(山东德州卷)化学(带解析).docx
- 2010-2023历年初中毕业升学考试(四川省泸州卷)化学(带解析).docx
文档评论(0)