电子发烧友App

硬声App

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

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

3天内不再提示
电子发烧友网>电子资料下载>嵌入式开发>Thumb指令集之Thumb跳转指令

Thumb指令集之Thumb跳转指令

2017-10-19 | rar | 0.2 MB | 次下载 | 1积分

资料介绍

 Thumb指令集中的跳转指令分以下6种类型。
  ① 无条件跳转,其跳转空间为±2KB。
  ② 条件跳转,其跳转空间为±256B。
  ③ 带返回的跳转指令,其跳转空间为±4MB。
  ④ 带状态切换的跳转指令(是否进行状态切换可以在程序中设定选择)。
  ⑤ 带返回和状态切换的跳转指令(是否进行状态切换可以在程序中设定选择)。
  ⑥ 第二种形式的带返回和状态切换的跳转指令。
  下面详细介绍各指令的特点及用途。
  11.3.1 跳转指令B
  Thumb中有两个分支跳转指令的变体,第一个变体与ARM版本指令相似,可条件执行,跳转被限制在有符号8位立即数所表示的范围内,或者是±256B。第二个变体不可条件执行(没有条件码部分),但扩展了有效跳转范围,跳转范围为有符号11位立即数表示的范围,即±2048B。
  条件分支指令是Thumb指令中惟一可以条件执行的指令。
  首先来介绍可条件执行的跳转指令B(1)。
  (1)编码格式
  可条件执行的跳转指令的编码格式如图11.1所示。
  Thumb指令集之Thumb跳转指令
  图11.1 B(1)指令编码格式
  (2)指令的语法格式
  B《cond》 《target_address》
  ① 《cond》
  指定指令的执行条件。条件助记符与ARM中相同。
  ② 《target_address》
  指定程序跳转的目标地址。指令通过下面的方法计算目标地址。
  · 将指令中包含的8位有符号数左移一位。
  · 将结果符号扩展为32位。
  · 将得到的值加到PC寄存器中,即得到跳转的目标地址。
  有条件的跳转指令可以实现±256B范围的程序跳转。
  (3)指令操作的伪代码
  if ConditionPass{cond} then
  PC=PC+{SignExtend(Signed_immed_8)《《1}
  (4)指令的使用
  为了得到正确的signed_immed_8,汇编器需要执行以下的操作步骤。
  ① 首先形成跳转的基地址。该跳转的基地址是跳转指令地址加4。也就是说,跳转指令的基地址即当前程序指针寄存器的值。
  ② 从跳转的目标地址中减去基地址形成跳转偏移量。该偏移量应为偶数(因为Thumb指令为半字对齐)。
  ③ 如果跳转偏移量超出-256~+254B范围,汇编器产生一个错误。
  ④ 将产生的跳转偏移量除以2放入指令编码中的signed_immed_8域。
  注意如果该指令的条件域为AL,即指令编码条件域为0b1110时,程序产生未定义指令异常。当指令的条件域为NV,即指令编码条件域为0b1111时,指令等价于SWI指令。
  (5)ARM指令集中的跳转指令
  该指令与ARM指令集中B《cond》 《target_address》基本相似,所不同的是ARM指令集中,偏移量左移两位而Thumb指令集中偏移量左移一位。另外,处理器在ARM和Thumb状态下所读取的PC值也是不同的。
  下面介绍无条件跳转指令B(2)。
下载该资料的人也在下载 下载该资料的人还在阅读
更多 >

评论

查看更多

下载排行

本周

  1. 1TC358743XBG评估板参考手册
  2. 1.36 MB  |  330次下载  |  免费
  3. 2开关电源基础知识
  4. 5.73 MB  |  6次下载  |  免费
  5. 3100W短波放大电路图
  6. 0.05 MB  |  4次下载  |  3 积分
  7. 4嵌入式linux-聊天程序设计
  8. 0.60 MB  |  3次下载  |  免费
  9. 5基于FPGA的光纤通信系统的设计与实现
  10. 0.61 MB  |  2次下载  |  免费
  11. 6基于FPGA的C8051F单片机开发板设计
  12. 0.70 MB  |  2次下载  |  免费
  13. 751单片机窗帘控制器仿真程序
  14. 1.93 MB  |  2次下载  |  免费
  15. 8基于51单片机的RGB调色灯程序仿真
  16. 0.86 MB  |  2次下载  |  免费

本月

  1. 1OrCAD10.5下载OrCAD10.5中文版软件
  2. 0.00 MB  |  234315次下载  |  免费
  3. 2555集成电路应用800例(新编版)
  4. 0.00 MB  |  33564次下载  |  免费
  5. 3接口电路图大全
  6. 未知  |  30323次下载  |  免费
  7. 4开关电源设计实例指南
  8. 未知  |  21548次下载  |  免费
  9. 5电气工程师手册免费下载(新编第二版pdf电子书)
  10. 0.00 MB  |  15349次下载  |  免费
  11. 6数字电路基础pdf(下载)
  12. 未知  |  13750次下载  |  免费
  13. 7电子制作实例集锦 下载
  14. 未知  |  8113次下载  |  免费
  15. 8《LED驱动电路设计》 温德尔著
  16. 0.00 MB  |  6653次下载  |  免费

总榜

  1. 1matlab软件下载入口
  2. 未知  |  935054次下载  |  免费
  3. 2protel99se软件下载(可英文版转中文版)
  4. 78.1 MB  |  537796次下载  |  免费
  5. 3MATLAB 7.1 下载 (含软件介绍)
  6. 未知  |  420026次下载  |  免费
  7. 4OrCAD10.5下载OrCAD10.5中文版软件
  8. 0.00 MB  |  234315次下载  |  免费
  9. 5Altium DXP2002下载入口
  10. 未知  |  233046次下载  |  免费
  11. 6电路仿真软件multisim 10.0免费下载
  12. 340992  |  191185次下载  |  免费
  13. 7十天学会AVR单片机与C语言视频教程 下载
  14. 158M  |  183278次下载  |  免费
  15. 8proe5.0野火版下载(中文版免费下载)
  16. 未知  |  138040次下载  |  免费