ARM指令跳转范围
2014-09-30 00:00
246 查看
摘要: 如题
但是这条指令受格式限制并不能处理任意立即数,只有当这个立即数能够表示为一个8-bit 数值通过循环右移偶数位而得到,才是合法的。例如:
这种方法对目标地址值没有要求,可以是任意有效地址。但是存储目标地址的存储器单元必须在当前指令的±4KB 空间范围内。
注意在计算指令中引用的offset 数值的时候,要考虑处理器流水线中指令预取对PC 值的影响。
ARM指令跳转范围
我们知道ARM的跳转指令(B)是有范围限制的(±32MB),但很多情况下不能保证所有的异常处理函数都定位在向量表的32MB 范围内,需要大于32MB 的长跳转,而且因为向量表空间的限制只能由一条指令完成。这可以通过下面二种方法实现。一)立即数跳转
(a) MOV PC, #imme_value把目标地址直接赋给PC 寄存器。
但是这条指令受格式限制并不能处理任意立即数,只有当这个立即数能够表示为一个8-bit 数值通过循环右移偶数位而得到,才是合法的。例如:
MOV PC, #0x30000000 ;//是合法的,因为0x300000000 可以通过0x03 循环右移4 位而得到。 而 MOV PC, #30003000 ;//就是非法指令。
二)相对地址跳转
(b) LDR PC, [PC+offset]把目标地址先存储在某一个合适的地址空间,然后把这个存储器单元上的32位数据传送给PC 来实现跳转。
这种方法对目标地址值没有要求,可以是任意有效地址。但是存储目标地址的存储器单元必须在当前指令的±4KB 空间范围内。
注意在计算指令中引用的offset 数值的时候,要考虑处理器流水线中指令预取对PC 值的影响。
相关文章推荐
- 关于ARM跳转指令b跳转指令范围为什么为正负32M??
- ARM中跳转指令的范围
- 1.2.17、ARM汇编指令集:数据传输和跳转指令详解
- ARM跳转指令B的反汇编分析
- 关于ARM的B,BL跳转指令
- 关于ARM的B,BL跳转指令
- arm汇编的跳转指令
- ARM指令集中的跳转指令
- arm跳转指令对应的机器码
- ARM汇编中B跳转指令和LDR跳转的区别 【转】
- arm的分支(跳转)指令
- ARM指令集中立即数寻址的范围
- ARM学习笔记2——分支跳转指令
- 关于ARM的B,BL跳转指令
- ARM的B,BL跳转指令
- ARM 指令集>>跳转指令
- ARM汇编中B跳转指令和LDR跳转的区别
- ARM的六大类指令集---跳转指令
- ARM 汇编中跳转指令
- ARM的B,BL跳转指令偏移值计算