电子发烧友App

硬声App

0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示
电子发烧友网>电子资料下载>ARM>数据处理指令之SUB减操作指令分析

数据处理指令之SUB减操作指令分析

2017-10-18 | rar | 0.6 MB | 次下载 | 1积分

资料介绍

6.3 SUB减操作指令
  1.指令的编码格式
  SUB(Subtract)减操作指令,从寄存器《Rn》中减去《shifter_operand》表示的数值,并将结果保存到目标寄存器《Rd》中,并根据指令的执行结果设置CPSR中相应的标志位。
  指令的编码格式如图6.4所示。
  数据处理指令之SUB减操作指令分析
  图6.4 EOR指令的编码格式
  2.指令的语法格式
  SUB{《cond》}{S} 《Rn》,《Rn》,《shifter_operand》
  ① 《cond》
  为指令编码中的条件域。它指示指令在什么条件下执行。当《cond》忽略时,指令为无条件执行(cond=AL(Alway))。
  ② 《S》
  S位(bit[20])决定指令的执行是否影响CPSR中的条件域。当S位清0时,指令执行不影响CPSR。当S位置位时(并且不是r15),则有以下规则。
  · 如果结果为负,则标志位N置位;否则清0(也就是说N等于结果的第31位)。
  · 如果结果为0,则标志位Z置位;否则清0。
  · 当操作定义为算术操作(ADD、ADC、SUB、SBC、RSB或RSC)时,标志位C设置为ALU的进位输出;否则设置为移位器的进位输出。如果不需要移位,则保持C。
  · 在非算术操作中,标志位V保持原值。在算术操作中,如果有从第30位到第31位的溢出,则置位;如果不发生溢出,则清0。仅当算术操作中操作数被认为是2的补码的有符号数时,这个标志位才有意义,而且指示结果超出范围。
  若指令中的目标寄存器《Rd》为r15,则当前处理器模式对应的SPSR的值被复制到CPSR寄存器中。用户模式和系统模式下,由于没有相应的SPSR,指令的执行结果不可预知。
  ③ 《Rd》
  指定目标寄存器。
  ④ 《Rn》
  指定第一个源操作数寄存器。
  ⑤ 《shifter_operand》
  使用ARM的通用寻址模式确定第二个源操作数。它影响指令编码格式中的I(bit[25])位和shifter_operand(bits[11∶0])位。
  注意在操作时要特别小心C标志位的设置。当C=1时,表示减操作没有借位发生;当C=0时,说明减操作发生了借位。也就是说C标志位在这里被用作了非借位标志。
  3.指令操作的伪代码
  指令操作的伪代码如下面程序段所示。
  If ConditionPassed{cond} then
  Rd=Rn - shifter_operand
  If S==1 and Rd==r15 then
  CPSR=SPSR
  Else if S==1 then
  N flag=Rd[31]
  Z flag=if Rd==0 then 1 else 0
  C flag=NOT BorrowForm{Rn – shifter_operand}
  V flag=OverflowFrom{Rn – shifter_operand}
  4.指令举例
  【例6.3】SUB指令举例。
  (1)R0=R1-R2
  SUB R0, R1, R2
  (2)R0=R1-256
  SUB R0, R1, #256
  (3)R0=R2-(R3《《1)
  SUB R0, R2, R3,LSL#1
 
下载该资料的人也在下载 下载该资料的人还在阅读
更多 >

评论

查看更多

下载排行

本周

  1. 1东芝BiCD集成电路硅单片TB67S109AFNAG数据手册
  2. 1.93 MB   |  5次下载  |  免费
  3. 2SP3060A/30120A/30160A/30320A/30520A系列数字合成扫频仪使用说明书
  4. 4.16 MB   |  3次下载  |  1 积分
  5. 3具有双通道 DC-DC转换器、由串行接口控制的9通道电机驱动器TPIC2010数据表
  6. 1.15MB   |  2次下载  |  免费
  7. 4USB Type-C PD快充协议智能触发芯片FS312B数据手册
  8. 0.75 MB   |  1次下载  |  免费
  9. 5USB Type_C PD快充协议智能触发芯片FS8025B数据手册
  10. 1.29 MB   |  1次下载  |  免费
  11. 6触摸按键PCB 设计要点V01
  12. 1.42 MB  |  1次下载  |  免费
  13. 75V升压充电两串锂电池充电管理IC FS4058数据手册
  14. 2.98 MB   |  次下载  |  免费
  15. 8真关断同步升压IC FS2009数据手册
  16. 2.08 MB   |  次下载  |  免费

本月

  1. 1DCDC原理详解
  2. 0.98 MB   |  63次下载  |  免费
  3. 2allegro快速入门教程
  4. 1.98 MB   |  36次下载  |  免费
  5. 3FU-7(807)胆机原理图
  6. 11.93 MB   |  25次下载  |  1 积分
  7. 4用于汽车应用的高压电源管理IC TPS65311-Q1数据表
  8. 1.05MB   |  22次下载  |  免费
  9. 5电子元件基础知识介绍
  10. 8.76 MB   |  13次下载  |  2 积分
  11. 6华为海思Ascend 310芯片的资料说明
  12. 0.12 MB   |  10次下载  |  10 积分
  13. 7GD32F10x系列MCU用户手册
  14. 11.5MB   |  9次下载  |  免费
  15. 86A 输出电流同步降压稳压器TPS65286数据表
  16. 2.05MB   |  6次下载  |  免费

总榜

  1. 1matlab软件下载入口
  2. 未知  |  935083次下载  |  免费
  3. 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
  4. 1.48MB  |  420045次下载  |  免费
  5. 3Altium DXP2002下载入口
  6. 未知  |  233067次下载  |  免费
  7. 4电路仿真软件multisim 10.0免费下载
  8. 340992  |  191308次下载  |  免费
  9. 5十天学会AVR单片机与C语言视频教程 下载
  10. 158M  |  183308次下载  |  免费
  11. 6labview8.5下载
  12. 未知  |  81567次下载  |  免费
  13. 7Keil工具MDK-Arm免费下载
  14. 0.02 MB  |  73785次下载  |  免费
  15. 8NI LabVIEW中实现3D视觉的工具和技术
  16. 未知  |  70088次下载  |  免费