您的位置:首页 > 其它

屌丝学arm汇编-06-thumb模式下ldr和bl一起使用需要注意的

2016-09-04 23:25 344 查看
</pre>1.arm在thumb模式下,pc = pc + 4;但是bl指令在thumb的指令为4byte,这个是个特殊情况,如果我在bl指令之前获取pc的指针,那么其值是否会仍然遵守pc = pc + 4?<p></p><p>2.bl指令执行跳转的时候,lr = 下条指令 + 1,那么我直接ldr 一个 指令标号和数据段的标号,是否仍然是这样?</p><p>演示代码地址:http://download.csdn.net/detail/losting_boy/9621625</p><p><span style="font-family:monospace; white-space:pre; background-color:rgb(240,240,240)"></span></p><pre name="code" class="html">    area    ldr_bl,code,readonly
entry
start
ldr r0,= sub1 + 1
bx r0
b .
code16
sub1
mov lr,pc
bl	sub2
bl	sub2

ldr	r0,=buf
ldr r1,=sub2
sub2
mov pc,lr (T

area	data1,data,readwrite
buf	DCD 0
end
实验证明:

(1)arm在thumb模式下,pc = pc + 4,无视下条指令是2字节还是4字节,都是依然成立。

(2)ldr加载数据段的标号是原地址,如果加载代码段的标号,则是 标号地址 + 1;

(3)bl指令之后,lr = bl所处地址 + 4 + 1;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  arm 汇编