AT&T汇编leave学习
来源:互联网 发布:2016淘宝联盟使用教程 编辑:程序博客网 时间:2024/06/05 00:48
最近在看c程序的编译出来的汇编文件,发现涉及到函数调用的地方,在返回时有的时候使用的leave,有的时候直接使用的是popl %ebp。
在AT&T汇编中,leave等效于以下汇编指令:
movl %ebp, %esp
popl %ebp
为什么有的时候会使用leave,有的时候直接使用popl %ebp?这个问题一开始我也没搞懂,后来通过分析堆栈才有点清醒。
二者的差别就在于是否使用 movl %ebp, %esp。这句的作用是用来恢复堆栈的栈顶指针,是不是堆栈的栈顶指针没有变化的时候,
就可以不用恢复,直接使用popl指令了?这个疑惑经过验证被证实了。
在AT&T汇编中,leave等效于以下汇编指令:
movl %ebp, %esp
popl %ebp
为什么有的时候会使用leave,有的时候直接使用popl %ebp?这个问题一开始我也没搞懂,后来通过分析堆栈才有点清醒。
二者的差别就在于是否使用 movl %ebp, %esp。这句的作用是用来恢复堆栈的栈顶指针,是不是堆栈的栈顶指针没有变化的时候,
就可以不用恢复,直接使用popl指令了?这个疑惑经过验证被证实了。
main函数是一个最特殊的函数调用,就以它的调用过程为准。
原C代码如下:/*stack.c*/#include <stdio.h>int main(){return 0;}
通过gcc -S -o stack.s stack.c得到汇编代码.file"stack.c".text.globlmain.typemain, @functionmain:.LFB0:.cfi_startprocpushl%ebp.cfi_def_cfa_offset 8.cfi_offset 5, -8movl%esp, %ebp.cfi_def_cfa_register 5movl$0, %eax/*将返回值保存在eax中*/popl%ebp/*由于在该函数中,没有使用到栈,所以esp未变化,不需要恢复。*/.cfi_def_cfa 4, 4.cfi_restore 5ret.cfi_endproc.LFE0:.sizemain, .-main.ident"GCC: (GNU) 4.6.2 20111027 (Red Hat 4.6.2-1)".section.note.GNU-stack,"",@progbits
将c代码修改如下:#include <stdio.h>int main(){int c = 1;return 0;}对应的汇编代码如下:.file"stack.c".text.globlmain.typemain, @functionmain:.LFB0:.cfi_startprocpushl%ebp/*原堆栈栈顶存放着原栈帧的ebp*/.cfi_def_cfa_offset 8.cfi_offset 5, -8movl%esp, %ebp/*将原堆栈地址放在ebp中,即新的栈帧的地址*/.cfi_def_cfa_register 5subl$16, %esp/*堆栈发生变化*/movl$1, -4(%ebp)movl$0, %eaxleave/*等效于 movl %ebp, esp; popl %ebp 首先需要恢复原栈顶指针,然后再根据栈顶指针恢复原栈帧的ebp*/.cfi_restore 5.cfi_def_cfa 4, 4ret.cfi_endproc.LFE0:.sizemain, .-main.ident"GCC: (GNU) 4.6.2 20111027 (Red Hat 4.6.2-1)".section.note.GNU-stack,"",@progbits以上可以很清楚地看出leave的作用,和什么时候用leave,什么使用可以直接使用popl。
0 0
- AT&T汇编leave学习
- AT&T汇编leave指令
- AT&T汇编指令enter、leave、call、ret
- AT&T汇编enter、leave、call、ret指令
- AT&T 汇编学习
- AT&T 汇编学习
- AT&T汇编学习笔记
- AT&T格式汇编学习
- part4.AT&T汇编学习
- iOS-学习-AT&T汇编
- at&t汇编学习(一)
- AT&T学习笔记汇编之函数
- AT&T学习笔记汇编之内核
- AT&T汇编学习笔记之数据类型
- AT&T汇编学习笔记之字符串
- AT&T学习笔记汇编之call
- AT&T汇编学习总结-1
- AT&T学习笔记汇编之调用汇编库
- android开发必备知识
- Task(Activity栈) 详解
- 根文件系统的建立
- Android 如何把状态栏信号格改为5格
- Android中PopupWindow显示在指定位置
- AT&T汇编leave学习
- Reverse words in a String leetcode
- 乐观锁与悲观锁
- Application类
- nignx 日志切割
- Android中再按一次退出和完美退出整个应用程序
- 使用 CAS 在 Tomcat 中实现单点登录
- 如何打包Python脚本使用的Python库[C++嵌入Python]
- Linux子系统系列-SPI