ARM中LDR B BX BL BLX指令的研究
2013-03-07 16:00
1506 查看
原来的文章有点乱,所以稍微整理了一下有用的要点:
(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
(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
相关文章推荐
- 【摘录】arm指令中mov和ldr的区别介绍
- arm汇编ldr,str,b,bl指令
- arm指令中mov和ldr的区别
- ARM中的ldr指令(发现有些网友说的是错的啊)
- ARM中LDR伪指令与LDR加载指令
- ARM汇编指令:LDR伪指令和LDR装载指令的区别
- ARM汇编中ldr伪指令和ldr指令(转载)
- arm指令中mov和ldr有什么区别?
- arm汇编中ldr指令中出现的等号作用
- ARM汇编中B跳转指令和LDR跳转的区别
- ARM中LDR伪指令与LDR加载指令
- arm指令中mov和ldr有什么区别
- ARM汇编中B跳转指令和LDR跳转的区别 【转】
- arm指令中mov和ldr的区别
- ARM汇编—ldr加载指令和ldr伪指令的用法
- ARM汇编中的LDR指令总结
- ARM指令LDR和ARM伪指令LDR
- ARM指令ADR和LDR浅析
- ARM MOV和 LDR指令关系
- ARM 2011-11-13 22:08 LDR 与ADR指令