ARM指令跳转范围多大

这篇文章主要介绍了ARM指令跳转范围多大,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

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指令跳转范围多大”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/208313.html

(0)
上一篇 2021年12月7日
下一篇 2021年12月7日

相关推荐

发表回复

登录后才能评论