- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* SWI:0* TST指令:如果指令的结果为0,则Z=1;不等于0,则Z=0 EQ:Z=1;NE:Z=0 乘(加)法 指 令 指 令 格 式 说 明 操 作 MUL{cond}{S} Rd,Rm,Rs 32位乘法 Rd←Rm*Rs MLA{cond}{S} Rd,Rm,Rs,Rn 32位乘加 Rd←Rm*Rs+Rn UMULL{cond}{S} RdLo,RdHi,Rm,Rs 64位无符号乘法 (RdLo,RdHi) ←Rm*Rs UMLAL{cond}{S} RdLo,RdHi,Rm,Rs 64位无符号乘加 (RdLo,RdHi) ←Rm*Rs+(RdLo,RdHi) SMULL{cond}{S} RdLo,RdHi,Rm,Rs 64位有符号乘法 (RdLo,RdHi) ←Rm*Rs SMLAL{cond}{S} RdLo,RdHi,Rm,Rs 64位有符号乘加 (RdLo,RdHi) ←Rm*Rs+(RdLo,RdHi) MUL R1,R2,R3 ;R1=R2×R3,结果的低32位保存 MLAS R1,R2,R3,R0 ;R1=R2×R3+R0,影响标志位 UMULL R0,R1,R5,R8 ;(R1、R0)=R5×R8 UMLAL R0,R1,R5,R8 ;(R1、R0)=R5×R8+(R1、R0) SMULL R2,R3,R7,R6 ;(R3、R2)=R7×R6 SMLAL R2,R3,R7,R6 ;(R3、R2)=R7×R6+(R3、R2) 注: R不能为R15且 Rd≠Rm ; 可影响N、Z标志位; 32位指令不影响V,C不确定;64位指令V 和C不确定; */95 逻辑运算指令 指 令 格 式 说 明 操 作 AND{cond}{S} Rd, Rn, operand2 逻辑与操作 Rd←Rn operand2 ORR{cond}{S} Rd, Rn, operand2 逻辑或操作 Rd←Rn | operand2 EOR{cond}{S} Rd, Rn, operand2 逻辑异或操作 Rd←Rn ^ operand2 BIC{cond}{S} Rd, Rn, operand2 位清除 Rd←Rn (~operand2) 可标志N和Z。计算Operand2时更新标志C,不影响标志V。 ANDS R0,R0,#0x01 ;取R0的最低位数据,并影响标志位 ORR R0,R0,#0x0F ;将R0的低4位置1 ,其它位不变 EOR R1,R1,#0x0F ;将R1的低4位取反,其它位不变 BIC R1,R1,#0x0F ;将R1的低4位清零,其它位不变 ANDEQ R2,R1,R3 ;若Z=1,则R2=R1R3 BIC R1,R2,R3 ;将R3的反码和R2相逻辑“与” MOV R1,R2,LSR #24 ; 将R2的高8位移入到R3低8位 ORR R3,R1,R3,LSL #8 */95 比较指令 指 令 格 式 说 明 操 作 CMP{cond} Rn, operand2 比较指令 标志←Rn-operand2 CMN{cond} Rn, operand2 负数比较指令 标志←Rn+operand2 TST{cond} Rn, operand2 位测试指令 标志←Rn operand2 TEQ{cond} Rn, operand2 相等测试指令 标志←Rn ^ operand2 不需要使用S后缀,会影响N/Z/C/V标志位;不保存运算结果; CMP R1,#10 ; R1与10比较,并设置相关标志位 CMPGT R1,R2 ;若R110,则比较R1与R2,并设置相关标志位 CMN R0,#1 ;比较R0与-1,判断R0是否为1的补码-1,是则设置Z标志 TST R1,#0x0F ;判断R1的低4位是否为0 TEQ R0,R1 ;较R0与R1是否相等 (不影响V位和C位) TST指令的下一条指令常与EQ、NE条件码配合使用:当所有测试位均为0时,EQ有效(Z=1),否则NE有效(Z=0); 计算R0+1 TEQ指令的下一条指令常与EQ、NE条件码配合使用:当两个数据相等时,EQ有效(Z=1),否则NE有效(Z=0); * */95 存储器访问指令 ARM处理器是典型的RISC处理器,对存储器的访问只能使用加载/存储指令 实现。 ARM的存储空间及I/O空间统一编址,因此对外围I/O及程序数据的访问均需通过加载/存储指令进行。 一、单寄存器操作指令LDR/STR 用于对访问内存变量
文档评论(0)