您的位置:首页 > 其它

ARM指令跳转范围

2014-09-30 00:00 246 查看
摘要: 如题

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 值的影响。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: