如何动态调试来学习ARM汇编 5 sp(r13)寄存器
本帖最后由 havenow 于 2021-3-20 18:34 编辑栈用来存储临时数据,使用push,pop指令来和栈交互,push和pop是一系列其他的内存相关指令的别名,而不是实际指令,使用push和pop是为了操作简便。
一条数据(32bit)将被放置的实际地址由栈指针定义,这个地址存储在sp寄存器中。
sp可能会指向栈中当前(最新)的的项,或者指向当前项的下一可用的内存槽。
sp当前指向栈中的最后一个项(full实现)
sp指向栈的下一个空白内存槽(empty实现),数据将首先被放置到这里
下面总结了不同栈实现方式,可以使用下表来描述在不同情况下,存储多个指令和载入多个指令在不同情形下是如何使用的
下面是一个使用full descending栈的例子
.text
.global main
main:
mov r0, #2
push {r0}
mov r0, #3
pop {r0}
bx lr
执行mov r0, #2指令后,sp的地址是0xfffefac0,r0是2
执行执行push {r0}指令后,sp的地址是0xfffefac0 – 4 = 0xfffefabc,r0是2
执行mov r0, 3指令后,sp的地址是没改变,r0是3;只是用来改变r0的值
执行pop {r0}指令后,sp的地址是0xfffefabc + 4 = 0xfffefac0,r0是2
pop指令被执行,sp从地址0xfffefabc读取4字节的数据,让后sp寄存器0xfffefabc + 4。
可以看到gdb(cef)中栈的视图是
不错的分享.感谢学习.``` 十分牛逼的教程,但是我知道你们看不懂的 持续学习中
页:
[1]