这篇文章主要介绍了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指令跳转范围多大”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。