ldr是比较复杂的指令 :
ldr r2,str @把str的内容777给r2
str:
,word 777
如果是含有=,是伪代码
分两种情况:
1)ldr r0,=0x123 @立即数
2)ldr r0,=str @把str标号所在的地址给r2,相当于c语言的指针(链接时候决定)
所以函数调用时候,有多种方法:
a)直接取出test标号地址,用ldr pc,=test调用(不能用ldr pc,test,经过测试,会死机)
mov lr,pc
ldr pc,=test
注意:要和ldr r15,show区别开来,因为show标号处本身存是个函数地址 .word 0xc3e1528c,并不是像test那样的函数入口,所以要ldr r15,show取出内容,而这个内容本身又是地址,相当于c语言的函数指针
b)间接取出test标号地址,用mov pc,r0调用
ldr r0,=test
mov lr,pc
mov pc,r0
c)用”b label”调用,b 跳转只能跳转标签
mov lr,pc
b test
c)用”bl “调用
bl test
完整代码:
abc:
mov ip,sp
stmfd sp!,{fp,ip,lr,pc}
sub fp,ip,#4
@ldr r0,=test
mov lr,pc
ldr pc,=test
@mov pc,r0
sub sp ,fp,#12
ldmfd sp,{fp,sp,pc}
test:
mov ip,sp
sub sp,sp,#12
str r14,[sp]
str ip,[sp,#4]
str fp,[sp,#8]
sub fp,ip,#4
ldr r0,=fmt
mov r14,r15
ldr r15,show
ldr lr,[fp,#-8]
ldr ip,[fp,#-4]
ldr fp,[fp,#0]
mov sp,ip
mov r15,r14
show:
.word 0xc3e1528c
fmt:
.asciz “hello!\n”