您的位置:首页 > 其它

ARM中LDR B BX BL BLX指令的研究

2013-03-07 16:00 1446 查看
原来的文章有点乱,所以稍微整理了一下有用的要点:

(1) LDR作为伪指令的格式:LDR 寄存器, = 数字常量/Label

如:LDR R2,=0x55aa ; 表示将0x55aa送入寄存器R2,等同于MOV R2, 0x55aa;

(2) 通过 B BL BLX BX 可以完成在当前指令向前或者向后32MB的地址空间的跳转。注意这些指令的编码格式,其中只有24位有符号数表示地址,而根据这个指令计算跳转地址的公式为:PC = PC + ( 低24位有符号数符号扩展,并左移两位 )。由于左移了两位,相当于跳转地址为26位(只是低两位一定为零)。由于最高位是符号位,所以这些指令可以完成向前向后 2^25 = 32MB的地址空间的跳转。

当然,如果要长地址跳转的话,就只能直接向PC直接写入跳转地址,也就是MOV PC, <跳转地址>

原文后面所说的不涉及到指令的说明,就此停笔。

原文转自:/article/3639734.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: