这篇文章主要介绍了ARM指令跳转范围多大,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
创新互联-专业网站定制、快速模板网站建设、高性价比盐池网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式盐池网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖盐池地区。费用合理售后完善,10余年实体公司更值得信赖。
我们知道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指令跳转范围多大”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!