本文主要是介绍linux函数调用中栈空间使用原则的验证,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
参考了实验楼linux第一课
预备知识:
%esp堆栈指针 %edp基址指针(使用时类似临时栈底指针),两者配合使得函数的调用过程能够合理的无冲突的利用栈空间
例如新的调动之前会将原来的ebp入栈,然后新的edp=esp,此时edp就相当于old esp,这样在子函数返回时就可以从edp中取回原来的esp,然后出栈原来的edp,栈得以恢复
其中%为取寄存器值
pushl是指定了命令操作范围b=byte,w=word,l=long,因为对于一些寄存器汇编器是知道其长度的,但有些内存单元的实际长度是需要指定的
.file "test1.c"
.text
.globl f1
.type f1, @function
f1:
.LFB0:
.cfi_startproc
pushl %ebp
.cfi_def_cfa_offset 8
.cfi_offset 5, -8
movl %esp, %ebp
.cfi_def_cfa_register 5
movl 8(%ebp), %eax
addl $3, %eax
popl %ebp
.cfi_restore 5
.cfi_def_cfa 4, 4
ret
.cfi_endproc
.LFE0:
.size f1, .-f1
.globl f2
.type f2, @function
f2:
.LFB1:
.cfi_startproc
pushl %ebp
.cfi_def_cfa_offset 8
.cfi_offset 5, -8
movl %esp, %ebp
.cfi_def_cfa_register 5
subl $4, %esp//
movl 8(%ebp), %eax
movl %eax, (%esp)
call f1
leave
.cfi_restore 5
.cfi_def_cfa 4, 4
ret
.cfi_endproc
.LFE1:
.size f2, .-f2
.globl main
.type main, @function
main:
.LFB2:
.cfi_startproc
pushl %ebp
.cfi_def_cfa_offset 8
.cfi_offset 5, -8
movl %esp, %ebp
.cfi_def_cfa_register 5
subl $4, %esp
movl $5, (%esp)
call f2
addl $2, %eax
leave
.cfi_restore 5
.cfi_def_cfa 4, 4
ret
.cfi_endproc
.LFE2:
.size main, .-main
.ident "GCC: (Ubuntu 4.8.2-19ubuntu1) 4.8.2"
.section .note.GNU-stack,"",@progbits
这篇关于linux函数调用中栈空间使用原则的验证的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!